<?xml version="1.0" encoding="utf-8"?>
<!-- generator="Kukkaisvoima version 7" -->
<rss version="2.0"
xmlns:content="http://purl.org/rss/1.0/modules/content/"
xmlns:wfw="http://wellformedweb.org/CommentAPI/"
xmlns:dc="http://purl.org/dc/elements/1.1/"
>
<channel>
<title>vmx: en</title>
<link>http://vmx.cx/cgi-bin/blog/index.cgi</link>
<description>Blog of Volker Mische</description>
<pubDate>Fri, 06 Jan 2012 17:02:24 +0200</pubDate>
<lastBuildDate>Fri, 06 Jan 2012 17:02:24 +0200</lastBuildDate>
<generator>http://23.fi/kukkaisvoima/</generator>
<language>en</language>
<item>
<title>The future of GeoCouch and CouchDB
</title>
<link>http://vmx.cx/cgi-bin/blog/index.cgi/the-future-of-geocouch-and-couchdb%3A2012-01-06%3Aen%2CCouchDB%2CGeoCouch%2CErlang%2Cgeo</link>
<comments>http://vmx.cx/cgi-bin/blog/index.cgi/the-future-of-geocouch-and-couchdb%3A2012-01-06%3Aen%2CCouchDB%2CGeoCouch%2CErlang%2Cgeo#comments</comments>
<pubDate>Fri, 06 Jan 2012 17:02:24 +0200</pubDate>
<dc:creator>Volker Mische</dc:creator>
<category>en</category>
<category>CouchDB</category>
<category>GeoCouch</category>
<category>Erlang</category>
<category>geo</category>
<guid isPermaLink="false">http://vmx.cx/cgi-bin/blog/index.cgi/the-future-of-geocouch-and-couchdb%3A2012-01-06%3Aen%2CCouchDB%2CGeoCouch%2CErlang%2Cgeo/</guid>
<description><![CDATA[ 
 [...]]]></description>
<content:encoded><![CDATA[

<p>The CouchDB world is currently full of “The future of CouchDB” blog posts. It started with the <a href="http://damienkatz.net/2012/01/the_future_of_couchdb.html">blog post from Damien Katz</a> the creator of CouchDB. Of course <a href="https://twitter.com/oltonn/status/154908935789355008">people were also concerned</a> about the future of GeoCouch. No worries, it will be good.</p>

<h3>The future of Apache CouchDB</h3>

<p>The reactions were quite different. People who are not deeply involved with the CouchDB community think that this means the end of Apache CouchDB. My reaction was positive, <a href="https://twitter.com/vmische/status/154892687844192257">I tweeted</a>:</p>

<p><blockquote>“It’s good to see the Damien is so open to [the] world”</blockquote></p>

<p>The reason was, that for me it was pretty clear that it would happen, and I was just happy that Damien officially made the cut.</p>

<p>The reactions from CouchDB community members where pretty much what <a href="http://till.klampaeckel.de/blog/archives/178-The-future-of-CouchDB.html">Till Klampäckel describes in his blog post</a>. You could see it comming after <a href="http://blog.couchbase.com/couchbase-2011-year-review">Couchbase announced</a> that they are not the CouchDB company and that their product won’t be Apache CouchDB compatible.</p>

<p>I agree with Till here, the way Damien wrote his blog post, isn’t the best imaginable. For outsiders, it really seems to be the end of Apache CouchDB, but it is not. For me it just shows, why foundations like the Apache Foundation are such a great idea. Even if the original creator leaves the project, it still lives on.</p>

<p>Apache CouchDB has a lot of contributers and the mailing lists and IRC channel is busy as always. That CouchDB has a future is also shown by the <a href="http://blog.cloudant.com/the-future-of-couchdb">blog post from Cloudant</a>. They will keep supporting Apache CouchDB.</p>

<h3>The future of GeoCouch</h3>

<p>After this quick recap what happened so far, it’s time to talk about the future of GeoCouch. As you may know, I work for Couchbase on the integration of spatial functionality into their product.</p>

<p>Currently the overlap between Apache CouchDB and the version Couchbase uses internally is still quite huge, but it will diverge more and more in the future. Thus it will get harder and harder to maintain a single version that supports Apache CouchDB and Couchbase.</p>

<p>The good news is, that GeoCouch is pretty much a data structure only. It's an <a href="http://en.wikipedia.org/wiki/R-tree">R-tree</a> that stores JSON documents. This can easily be used by CouchDB and Couchbase. Perhaps small wrappers will be needed, but those should be minimal.</p>

<p>The easiest way to understand how the future looks like is in a small illustration:</p>
<div class="figure">
  <img src="/blog/2012-01-06/geocouch-couchdb-couchbase.png" width="399" height="292" alt="Illustration of GeoCouch and its relation to CouchDB and Couchbase"/>
  <p class="caption">GeoCouch's core is the R-tree, it's the same code for CouchDB and Couchbase. On top of it there will be code that is specific to either CouchDB or Couchbase.</p>
</div>

<p>This means that the majority of the devlopment I do for Couchbase will also improve the GeoCouch you can use for CouchDB.</p>

<h3>Conclusion</h3>

<p>The future of all three, Apache CouchDB, Couchbase and GeoCouch looks bright.</p>
]]></content:encoded>
<wfw:commentRss>http://vmx.cx/cgi-bin/blog/index.cgi/the-future-of-geocouch-and-couchdb%3A2012-01-06%3Aen%2CCouchDB%2CGeoCouch%2CErlang%2Cgeo/feed/</wfw:commentRss>
</item>
<item>
<title>FOSS4G 2011: Report
</title>
<link>http://vmx.cx/cgi-bin/blog/index.cgi/foss4g-2011%3A2011-09-20%3Aen%2CCouchDB%2CGeoCouch%2CMapQuery%2CErlang%2CJavaScript%2Cgeo</link>
<comments>http://vmx.cx/cgi-bin/blog/index.cgi/foss4g-2011%3A2011-09-20%3Aen%2CCouchDB%2CGeoCouch%2CMapQuery%2CErlang%2CJavaScript%2Cgeo#comments</comments>
<pubDate>Tue, 20 Sep 2011 16:11:16 +0200</pubDate>
<dc:creator>Volker Mische</dc:creator>
<category>en</category>
<category>CouchDB</category>
<category>GeoCouch</category>
<category>MapQuery</category>
<category>Erlang</category>
<category>JavaScript</category>
<category>geo</category>
<guid isPermaLink="false">http://vmx.cx/cgi-bin/blog/index.cgi/foss4g-2011%3A2011-09-20%3Aen%2CCouchDB%2CGeoCouch%2CMapQuery%2CErlang%2CJavaScript%2Cgeo/</guid>
<description><![CDATA[ 
 [...]]]></description>
<content:encoded><![CDATA[

<p>The <a href="http://2011.foss4g.org/">FOSS4G 2011</a> is over now. Time for a small report. The crowd was amazing and it was again the ultimate gathering of the Free and Open Source for Geospatial developer tribe. Solid presentations and great evenings.</p>

<h3>My talk: The State of GeoCouch</h3>

<p>I'm really happy how <a href="http://2011.foss4g.org/sessions/state-geocouch">my talk</a> went, I really enjoyed it. The were lots of people (although there was a talk from Frank Warmerdam at the same time) asking interesting questions at the end.
</p>

<p>The talk is not only about <a href="https://github.com/couchbase/geocouch">GeoCouch</a> but also gives you an overview of some of the features it leverages from <a href="http://couchdb.apache.org/">Apache CouchDB</a>. In the end you should have an overview why you might want to use GeoCouch for your next project.
</p>
<p>You can get the slides right here.</p>
<ul>
  <li>The slides (download optimized)
<a href="/blog/2011-09-20/the-state-of-geocouch.pdf">as PDF</a> (licensed under
<a href="http://creativecommons.org/licenses/by/3.0/de/">CC-BY-3.0-de</a>).</li>
  <li>The slides with comments
<a href="/blog/2011-09-20/the-state-of-geocouch.html">as HTML</a> (licensed under
<a href="http://creativecommons.org/licenses/by/3.0/de/">CC-BY-3.0-de</a>).</li>
  <li><a href="http://www.fosslc.org/drupal/content/state-geocouch">The slides with audio</a>. It’s the recording of the actual talk at the conference.</li>
</ul>

<h3>Other talks</h3>

<p>I was happy to see that there was <a href="http://2011.foss4g.org/sessions/new-geodata-tool-set-couchdb-and-nodejs">another talk about GeoCouch</a>. Other talks I really enjoyed were:</p>
<ul>
  <li><a href="http://2011.foss4g.org/sessions/cartoset-new-foss-create-highly-visual-geo-portals">CartoSet, a new FOSS to create highly visual geo portals</a>: So many true things were said, e.g. get the data from the customer first, before you start building anything.
  </li>
  <li><a href="http://2011.foss4g.org/sessions/introduction-opensource-webmapping-beyond-google-maps">Introduction to OpenSource WebMapping: Beyond Google Maps</a>: A very nice introduction off the full stack for web mapping. From the database, over the server to the client. It's for people that have no clue that they could have maps on their own infrastructure.
  </li>
  <li><a href="http://2011.foss4g.org/sessions/comparing-geoext-mapquery-and-legato-technical-and-collaborative-point-view">Comparing GeoExt, MapQuery and Legato from a technical and collaborative point of view</a>: A good comparison between <a href="http://geoext.org/">GeoExt</a>, <a href="http://mapquery.org/">MapQuery</a> and <a href="http://www.legato.net">Legato</a>. I especially liked the “Bodo”-test.
  </li>
  <li><a href="http://2011.foss4g.org/sessions/beyond-vectors-adapting-remote-sensing-research-environmental-monitoring-open-source-hardwa">Beyond vectors: Adapting remote sensing research for environmental monitoring with open source hardware and software: Citizen mapping the BP oil spill with balloons and kites</a>: Kite and balloon mapping is just awesome. It's kind of the OpenStreetMap for raster data.
  </li>
  <li><a href="http://2011.foss4g.org/sessions/geoglobaldomination-musical">GeoGlobalDomination: The Musical</a>: One of the highlights was the GeoGlobalDomination musical. <a href="http://vimeo.com/29203100">Grab the video</a> while it's hot.
  </li>
</ul>
<p>And of course there were also great talks from in the plenary sessions from <a href="http://twitter.com/pwramsey">Paul Ramsey</a> about <a href="http://2011.foss4g.org/sessions/why-do-you-do-exploration-open-source-business-models">Why do you do that? An exploration of open source business models</a> and <a href="http://twitter.com/schuyler">Schuyler Erle's</a> so funny lightning talk about <a href="http://2011.foss4g.org/sessions/pivoting-monetize-mobile-hyperlocal-social-gamification-going-viral">Pivoting to Monetize Mobile Hyperlocal Social Gamification by Going Viral</a>
</p>

<h3>Code Sprint</h3>

<p>At the code sprint I was working on MapQuery together with <a href="http://twitter.com/stvno">Steven Ottens</a> and <a href="http://twitter.com/h0st1le">Justin Penka</a>. Steven was working on TMS support, Justin on a 6 minutes tutorial and I on making manual adding of features possible.
</p>
<p>The OpenLayers developers did the migration from Subversion to Git for their development. OpenLayers is <a href="https://github.com/openlayers">now available</a> on Github.
</p>
<p>And luckily there was a fire alarm in between to take a <a href="http://wiki.osgeo.org/images/f/f7/Code-sprint-foss4g2011.png">group photograph</a>.
</p>

<h3>Future of the FOSS4G</h3>

<p>I really hope there won't be a yearly FOSS4G conference for the whole of the US. There should be regional events, as I think one big one would draw the attention away from the international conference. Why should you fly to Beijing for the FOSS4G 2012 if you can meet the majority of the developers in the US as well?
</p>

<h3>Final words</h3>

<p>The FOSS4G was great. It was organized well and people were always out in the evenings. The only minor nitpick is that many people working remote had the city of their company in the name badge and not the one they live in. It seems that the original for you had to fill was confusing. So for next year it should perhaps say “Location where you live”. Hence I still don't believe that there were more Dutch than German people at the conference (Tik hem aan, ouwe! ;)
</p>
]]></content:encoded>
<wfw:commentRss>http://vmx.cx/cgi-bin/blog/index.cgi/foss4g-2011%3A2011-09-20%3Aen%2CCouchDB%2CGeoCouch%2CMapQuery%2CErlang%2CJavaScript%2Cgeo/feed/</wfw:commentRss>
</item>
<item>
<title>WhereCampEU 2011 Berlin
</title>
<link>http://vmx.cx/cgi-bin/blog/index.cgi/wherecampeu-2011%3A2011-05-29%3Aen%2CGeoCouch%2COpenLayers%2CMapQuery%2Cconference%2Cgeo</link>
<comments>http://vmx.cx/cgi-bin/blog/index.cgi/wherecampeu-2011%3A2011-05-29%3Aen%2CGeoCouch%2COpenLayers%2CMapQuery%2Cconference%2Cgeo#comments</comments>
<pubDate>Sun, 29 May 2011 19:34:40 +0200</pubDate>
<dc:creator>Volker Mische</dc:creator>
<category>en</category>
<category>GeoCouch</category>
<category>OpenLayers</category>
<category>MapQuery</category>
<category>conference</category>
<category>geo</category>
<guid isPermaLink="false">http://vmx.cx/cgi-bin/blog/index.cgi/wherecampeu-2011%3A2011-05-29%3Aen%2CGeoCouch%2COpenLayers%2CMapQuery%2Cconference%2Cgeo/</guid>
<description><![CDATA[ 
 [...]]]></description>
<content:encoded><![CDATA[

<p>The <a href="http://wherecamp.eu/">WhereCampEU 2011</a> is <a href="http://twitter.com//vmische/status/74658918307069953">just over now</a>, so it's time to get my impression and notes from the sessions written down. But first I'd like to thank all the organizers and attendees for this great event and the geobeers in the evenings.</p>

<h2>Geo Databases</h2>

<p>The WhereCamp is also a chance to meet people you haven't seen for a long time. Exactly this was the case with <a href="http://twitter.com/sabman">Shoaib Burq</a>. We know each other from being a member of the <a href="http://2009.foss4g.org/about_us/">FOSS4G 2009 organizing committee</a>.</p>

<p>As there were still a few free slots, we decided to make session that is simply called "Geo Databases". I didn't expect many people to show up, as there were other sessions with way catchier names.</p>

<p>I ran late as I didn't find the room where my session was supposed to be. But luckily Shoaib was already presenting a rough outline on what will be talked about (we haven't talked about what we want to do upfront). So I happily joined the crowd and started to moderate things a bit. And it was just amazing, the room was packed with people even sitting on the floor. A rough guess would b,e that it was half of the attendees.</p>

<p>We discussed a bit about one of my favourite topics, the question of how much should be done within a geospatial database and what should be done outside of it. It then led to the problem that doing a lot within the database is easy (and fast) on a single instance, but as soon as you want to distribute your database, you might get into trouble.</p>

<p>To conclude, the atmosphere was good and people seemed to have enjoyed it (at least some were telling me so :) I'm happy that it went this well. Shoaib has kindly taken some notes and <a href="https://gist.github.com/994992">put on Github</a>.</p>

<h2>Web Mapping Libraries</h2>

<p>On the second day the program wasn't as packed as on the first day, so I decided to make another session called "Web Mapping Libraries". The Again I didn't expect too many people to show up and this time I was right. It was a good crowd nonetheless.</p>

<p>What I wanted to find out was why people create new web mapping libraries instead of just improving existing ones like <a href="http://openlayers.org">OpenLayers</a>. This was also triggered by <a href="http://www.slideshare.net/pmbatty/to-g-or-not-to-g">Slide 54</a> from <a href="http://twitter.com/pmbatty">Peter Batty</a>'s talk, where he compares OpenLayers to Google Maps. The two things that were catching my attention were "lightweight" and "extra mobile features". Those two can be solved. <a href="http://twitter.com/erilem">Eric Lemoine</a> demonstrated a <a href="http://twitter.com/erilem/status/73499259458170880">29KB (gzipped) version of OpenLayers</a> including the mobile features that were added at the <a href="http://openlayers.org/blog/2011/04/02/61/">Lausanne Code Sprint</a>.</p>

<p>In the session it was just great to hear the impressions for what I call "web neogeo people" (people are web developers, designers and general people that like to visualize data) as opposed to "old school GIS people" (that know all kinds of OGC standards and dream about the axis confusion at night).</p>

<p>Things we've identified were (<a href="http://twitpic.com/53mdmq">photo version</a>):</p>

<ul>
<li>Documentation</li>
<li>Default Look</li>
<li>Usability</li>
<li>Examples are not good</li>
<li>No explanation of the general architecture</li>
</ul>

<h3>Documentation</h3>

<p>The main source of documentation are the <a href="http://dev.openlayers.org/apidocs/">API docs</a>. They describe every function of the library. One problem is that it isn't really clear what exactly you can pass in when one parameter is an options object (<a href="http://dev.openlayers.org/apidocs/files/OpenLayers/Layer/TMS-js.html#OpenLayers.Layer.TMS.Constructor">Example</a>.</p>

<p>The lack of documentation with a nice introduction was also mentioned. Though I don't fully agree, there is some <a href="http://docs.openlayers.org/">really nice documentation in prose</a>, but it seems that people easily miss it (I especially like e.g. the page about <a href="http://docs.openlayers.org/library/spherical_mercator.html">Spherical Mercator</a>).</p>

<h3>Default look</h3>

<p>I agree that the default look of OpenLayers looks a bit out dated. The main buttons look like from the early 2000's and the layer switcher isn't nice either.</p>

<p>On the one hand, you can change the look <a href="http://support.mapbox.com/kb/mapping-101/openlayers-themes">if you want to</a> (<a href="http://mapbox.github.com/webintegration">example</a> (scroll down)), or code the controls with any UI library you'd like to use (this is what GeoExt/MapQuery does).</p>

<h3>Usability</h3>

<p>I'm not really sure what this one was about, but I think it was about the complexity of OpenLayers. You need to have quite a bit GIS knowledge before you can get started. Don't get me wrong, I love OpenLayers for what it does and it's huge amount of features, though it comes to a price for newbies.</p>

<p>Again this is where I think GeoExt/MapQuery can help. They can build an easy to use API around the most common functionality like: display a GeoJSON file on a Google base map that shows a popup when I click on the geometry.</p>

<h3>Examples are not good</h3>

<p>It's nice to have a whole bunch of examples, though in the case of OpenLayers they are a bit misleading. I use them a lot to see how things work. Though they are not always well drafted idiomatic OpenLayers examples, but rather some source showing how a specific feature works. And this is exactly what they are. If you implement a new feature, you create API documentation and a working example.</p>

<p>For me they are more like acceptance tests, rather than good howtos for newbies.</p>

<h3>No explanation of the general architecture</h3>

<p>This one was mostly about "how do things work". One point was about vector layers. They are really powerful and you can compose them out of several parts with things like strategies and formats. It's not easy to understand how they fit together.</p>

<p>I think there was also another point, but I don't recall it. Let me know if you were at the session and remember it :)</p>

<h2>Conclusion</h2>

<p>I had a great time at the WhereCampEU 2011 and it was definitely worth going there.
If you have anything to add to the notes about the session, please do so.</p>
]]></content:encoded>
<wfw:commentRss>http://vmx.cx/cgi-bin/blog/index.cgi/wherecampeu-2011%3A2011-05-29%3Aen%2CGeoCouch%2COpenLayers%2CMapQuery%2Cconference%2Cgeo/feed/</wfw:commentRss>
</item>
<item>
<title>FOSSGIS, GeoCouch and MapQuery
</title>
<link>http://vmx.cx/cgi-bin/blog/index.cgi/fossgis-geocouch-mapquery%3A2011-04-19%3Aen%2CCouchDB%2CGeoCouch%2CMapQuery%2Cgeo</link>
<comments>http://vmx.cx/cgi-bin/blog/index.cgi/fossgis-geocouch-mapquery%3A2011-04-19%3Aen%2CCouchDB%2CGeoCouch%2CMapQuery%2Cgeo#comments</comments>
<pubDate>Tue, 19 Apr 2011 14:23:11 +0200</pubDate>
<dc:creator>Volker Mische</dc:creator>
<category>en</category>
<category>CouchDB</category>
<category>GeoCouch</category>
<category>MapQuery</category>
<category>geo</category>
<guid isPermaLink="false">http://vmx.cx/cgi-bin/blog/index.cgi/fossgis-geocouch-mapquery%3A2011-04-19%3Aen%2CCouchDB%2CGeoCouch%2CMapQuery%2Cgeo/</guid>
<description><![CDATA[ 
 [...]]]></description>
<content:encoded><![CDATA[

<p>Two weeks ago I had the chance to give a talk about GeoCouch and MapQuery at the <a href="http://www.fossgis.de/konferenz/2011/">FOSSGIS 2011</a>. Most of the people who read this Blog are probably aware of <a href="https://github.com/couchbase/geocouch/">GeoCouch</a>, but not so much of <a href="http://gitorious.org/mapquery/">MapQuery</a>. For me these two projects are tightly connected and therefore deserve a quick introduction/update.</p>

<h2>GeoCouch</h2>

<p>GeoCouch, a spatial index for CouchDB gains, more and more attention. One of the reason is that the installation recently got way easier for developers as well as for normal users. You now can <a href="http://blog.couchbase.com/new-release-geocouch-extension">install GeoCouch as an extension</a> right next to your already existing CouchDB instance. You may also <a href="http://www.couchbase.com/downloads">download a binary of Couchbase-Server</a>, which already includes GeoCouch. And finally there's the brand new <a href="http://www.iriscouch.com/">Iris Couch</a> hosting as well (previously known as the CouchOne hosting). So getting started with GeoCouch is easier than ever before.</p>

<p>Some people might have wondered about the state/future of GeoCouch, especially after the merger of CouchOne with Membase to Couchbase. I will keep on developing GeoCouch at Couchbase and it is (as it always was) fully open source licensed under the Apache 2.0 License.</p>

<p>The new home for the latest source is the <a href="https://github.com/couchbase/geocouch">Couchbase Github repository</a>.</p>

<h3>OpenStreetMap</h3>

<p>The FOSSGIS was also about OpenStreetMap. The idea to put OpenStreetMap data into GeoCouch is very sensible, but wasn't really done (AFAIK) in a big fashion. Luckily <a href="http://wiki.openstreetmap.org/wiki/User:Joto">Jochen Topf</a> from <a href="http://www.geofabrik.de/">Geofabrik</a> told me about his Projekt <a href="http://wiki.openstreetmap.org/wiki/Osmium">Osmium</a>, which makes it possible to process OSM data with JavaScript. There is already a script to output a Shapefile, so it should be really easy to output GeoJSON, which could be consumed by GeoCouch. So if you (who are currently reading this) have some spare time, please give it a go :)</p>

<h2>MapQuery</h2>

<p>MapQuery is a web mapping framework that builds on <a href="http://openlayers.org/">OpenLayers</a> and <a href="http://jquery.com/">jQuery</a>. The goal is a framework that is just as easy to use as jQuery combined with the power of OpenLayers. It's meant for people that just want to get started with web mapping, but also for those who have already knowledge about OpenLayers and want to have easy integration into their jQuery application.</p>

<p>I was able to show a quick demo of the MapQuery API at the FOSSGIS. I won't publish it here, as things are about to move fast. After over one year of discussions about MapQuery and only little code contributions, it seems that we are finally getting somewhere. That feels so good :)</p>

<p>The wonderful <a href="http://research.geodan.nl/edugis/">EduGIS</a> is build on an early version of MapQuery (<a href="https://gitorious.org/~edugis/mapquery/edugis-mapquery">source code</a>), but will be merged with the most recent version of <a href="https://gitorious.org/~vmx/mapquery/vmx-mapquery">my fork</a>.</p>

<p>Other big news is that the <a href="http://www.wheregroup.com/">WhereGroup</a> hired <a href="http://crischan.net/blog/">Christian Wygoda</a>, who is a committer of the MapQuery project. This also means that <a href="http://twitter.com//mapbender/status/55920881897193472">Mapbender 3 will use MapQuery</a>.</p>

<p>And finally I've also met a developer of a another company that was building a big mapping application based on OpenLayers and jQuery. I don't want disclose it here, as the code isn't open source yet, but the developer told me that it should be easily possible. I will keep in touch with them and hope they will contribute their code to MapQuery.</p>

<p>To get to a conclusion about MapQuery. If you want to stay in touch with the project, please subscribe to the <a href="http://www.osgeo.org/mailman/listinfo/mapquery">official mailing list</a>, this is where things are happening (there's also the little attended IRC channel #mapquery on freenode). If you want to be a user of MapQuery, you should be patient and wait a bit. If you plan to contribute, you can start now. The currently biggest item is moving the EduGIS MapQuery code base over to the MapQuery version of my fork. The "documententation" are the demos.</p>

<h2>FOSSGIS</h2>

<p>As people started to asked about the slides from my presentaion at FOSSGIS, <a href="/blog/2011-04-19/index.html">here they are</a>.</p>

<p>FOSSGIS was a really awesome event, where I met a lot of new people, but also a lot of friends I haven't seen in a while. I'm really looking forward to next year's conference, but also hope that I might see many of the people at this year's <a href="http://2011.foss4g.org/">FOSS4g</a> in Denver.</p>
]]></content:encoded>
<wfw:commentRss>http://vmx.cx/cgi-bin/blog/index.cgi/fossgis-geocouch-mapquery%3A2011-04-19%3Aen%2CCouchDB%2CGeoCouch%2CMapQuery%2Cgeo/feed/</wfw:commentRss>
</item>
<item>
<title>How I met CouchDB
</title>
<link>http://vmx.cx/cgi-bin/blog/index.cgi/how-i-met-couchdb%3A2010-07-14%3Aen%2CCouchDB</link>
<comments>http://vmx.cx/cgi-bin/blog/index.cgi/how-i-met-couchdb%3A2010-07-14%3Aen%2CCouchDB#comments</comments>
<pubDate>Wed, 14 Jul 2010 12:33:42 +0200</pubDate>
<dc:creator>Volker Mische</dc:creator>
<category>en</category>
<category>CouchDB</category>
<guid isPermaLink="false">http://vmx.cx/cgi-bin/blog/index.cgi/how-i-met-couchdb%3A2010-07-14%3Aen%2CCouchDB/</guid>
<description><![CDATA[ 
 [...]]]></description>
<content:encoded><![CDATA[

<p>It was a Saturday in late April 2008, I was sitting on my Laptop in my 5m²
room  down under. Chatting with some German people I used to chat with for
about 8 years by that time. Suddenly I discover that
<a href="http://jan.prima.de/">Jan</a> is there, who I haven't talked with
for years. Wondering why he was in there, he replied that he wanted to brag
about his apache.org email address. This is how I found out about
<a href="http://couchdb.apache.org/">CouchDB</a>.
</p>
<p>After several long discussions with Jan I finally wrapped my head around
the document oriented concept. I was blown away, it was exactly what I would
have liked to use on so many occasions at my one year internship at a
geospatial company. Though CouchDB wasn't ready, I needed spatial indexing.
One week later I
<a href="http://vmx.cx/cgi-bin/blog/index.cgi/couchdb-and-geodata%3A2008-05-03%3Aen%2Cgeo%2CCouchDB">had
a first idea of how such an extension might look like</a>.</p>

<p>And only 2 years later I'm really involved in CouchDB and people actually
<a href="http://pdxapi.com/">start</a>
<a href="http://simonmetson.posterous.com/import-a-bunch-of-geo-location-data-into-geoc">using</a>
<a href="http://vmx.cx/cgi-bin/blog/index.cgi/geocouch-the-future-is-now:2010-05-03:en,CouchDB,Python,Erlang,geo">GeoCouch</a>
:) I'd like to use this blog post to thank the developers and the whole
community, it's been a great time and the
<a href="irc://irc.freenode.net/#couchdb">IRC channel</a> just kicks ass.
You all helped to make CouchDB 1.0 possible!</p>
]]></content:encoded>
<wfw:commentRss>http://vmx.cx/cgi-bin/blog/index.cgi/how-i-met-couchdb%3A2010-07-14%3Aen%2CCouchDB/feed/</wfw:commentRss>
</item>
<item>
<title>Bolsena hacking event
</title>
<link>http://vmx.cx/cgi-bin/blog/index.cgi/bolsena-hacking-event-2010%3A2010-06-11%3Aen%2CCouchDB%2CJavaScript%2Cgeo</link>
<comments>http://vmx.cx/cgi-bin/blog/index.cgi/bolsena-hacking-event-2010%3A2010-06-11%3Aen%2CCouchDB%2CJavaScript%2Cgeo#comments</comments>
<pubDate>Fri, 11 Jun 2010 22:02:24 +0200</pubDate>
<dc:creator>Volker Mische</dc:creator>
<category>en</category>
<category>CouchDB</category>
<category>JavaScript</category>
<category>geo</category>
<guid isPermaLink="false">http://vmx.cx/cgi-bin/blog/index.cgi/bolsena-hacking-event-2010%3A2010-06-11%3Aen%2CCouchDB%2CJavaScript%2Cgeo/</guid>
<description><![CDATA[ 
 [...]]]></description>
<content:encoded><![CDATA[

<p>The <a href="http://wiki.osgeo.org/wiki/Bolsena_Code_Sprint_2010">OSGeo hacking event in Bolsena/Italy</a> was great. Many interesting people
sitting the whole day in front of their laptops surrounded by a beautiful
scenery and nice warm sunny weather. It gets even better when you get meat for
lunch and dinner.</p>

<p>I had the chance to tell people a bit more about
<a href="http://couchdb.apache.org/">CouchDB</a> and
<a href="http://github.com/couchapp/couchapp/">Couchapps</a>,</p>

<p>One project I haven't heard that much before of was
<a href="http://deegree.org/">Degree</a>. They build the whole stack of OGC services
you could imagine. For me it was of interest that they have a
blob storage in their upcoming 3.0 release. The data
isn't flattened into SQL tables but stored as blobs. This sounds like good use
for a CouchDB backend in the future.</p>

<p>I was working with <a href="http://wiki.osgeo.org/wiki/User:Simonp">Simon Pigot</a> on a
<a href="http://geonetwork-opensource.org/">GeoNetwork</a>
re-implementation
based on CouchDB using Couchapp. We got the basic stuff like putting an XML
document into the database, editing it and returning the new document, as well
as fulltext indexing with
<a href="http://github.com/rnewson/couchdb-lucene">couchdb-lucene</a>
work. Next steps are improving the JSON to XML mapping and integrating spatial
search based on <a href="http://github.com/vmx/couchdb">GeoCouch</a>.</p>

<p>The event was really enjoyable, thanks <a href="http://couch.io/">Couchio</a> for
sponsoring the trip, thanks <a href="http://www.ticheler.net/">Jeroen</a> for
organizing it, and thanks all other hackers that made it such a awesome event.
Hope to see you next year!</p>
]]></content:encoded>
<wfw:commentRss>http://vmx.cx/cgi-bin/blog/index.cgi/bolsena-hacking-event-2010%3A2010-06-11%3Aen%2CCouchDB%2CJavaScript%2Cgeo/feed/</wfw:commentRss>
</item>
<item>
<title>FOSS4G 2010: I'm speaking
</title>
<link>http://vmx.cx/cgi-bin/blog/index.cgi/foss4g-2010-im-speaking%3A2010-05-21%3Aen%2CGeoCouch%2CCouchDB%2CErlang%2Cgeo</link>
<comments>http://vmx.cx/cgi-bin/blog/index.cgi/foss4g-2010-im-speaking%3A2010-05-21%3Aen%2CGeoCouch%2CCouchDB%2CErlang%2Cgeo#comments</comments>
<pubDate>Fri, 21 May 2010 14:11:59 +0200</pubDate>
<dc:creator>Volker Mische</dc:creator>
<category>en</category>
<category>GeoCouch</category>
<category>CouchDB</category>
<category>Erlang</category>
<category>geo</category>
<guid isPermaLink="false">http://vmx.cx/cgi-bin/blog/index.cgi/foss4g-2010-im-speaking%3A2010-05-21%3Aen%2CGeoCouch%2CCouchDB%2CErlang%2Cgeo/</guid>
<description><![CDATA[ 
 [...]]]></description>
<content:encoded><![CDATA[

<div class="figure">
  <a href="http://2010.foss4g.org">
    <img src="http://2010.foss4g.org/images/logo_145x90_speaking.jpg"
    alt="FOSS4G Conference - I'm Speaking!"  width="145" height="90"/>
 </a>
</div>

<p>I did it! I'll speak at the <a href="http://2010.foss4g.org/">FOSS4G
Conference 2010</a> (Free and Open Source Software for Geospatial Conference),
6th–9th September in Barcelona about “GeoCouch: A spatial index for CouchDB”.
As soon as the abstract is available online I'll link to it. Hope to see you
there!
</p>
]]></content:encoded>
<wfw:commentRss>http://vmx.cx/cgi-bin/blog/index.cgi/foss4g-2010-im-speaking%3A2010-05-21%3Aen%2CGeoCouch%2CCouchDB%2CErlang%2Cgeo/feed/</wfw:commentRss>
</item>
<item>
<title>Non-validating WKT parser for Erlang
</title>
<link>http://vmx.cx/cgi-bin/blog/index.cgi/non-validating-wkt-parser-for-erlang%3A2010-05-14%3Aen%2CGeoCouch%2CErlang%2Cgeo</link>
<comments>http://vmx.cx/cgi-bin/blog/index.cgi/non-validating-wkt-parser-for-erlang%3A2010-05-14%3Aen%2CGeoCouch%2CErlang%2Cgeo#comments</comments>
<pubDate>Fri, 14 May 2010 20:07:38 +0200</pubDate>
<dc:creator>Volker Mische</dc:creator>
<category>en</category>
<category>GeoCouch</category>
<category>Erlang</category>
<category>geo</category>
<guid isPermaLink="false">http://vmx.cx/cgi-bin/blog/index.cgi/non-validating-wkt-parser-for-erlang%3A2010-05-14%3Aen%2CGeoCouch%2CErlang%2Cgeo/</guid>
<description><![CDATA[ 
 [...]]]></description>
<content:encoded><![CDATA[

<p>The <a href="http://www.opensearch.org/Specifications/OpenSearch/Extensions/Geo/1.0/Draft_2">upcoming OpenSearch Geo
specification</a>
will <a href="http://groups.google.com/group/opensearch/browse_thread/thread/e8cc2a298a36b998/">add support for querying with
WKT</a>
(<a href="http://en.wikipedia.org/wiki/Well-known_text">Well-Known Text</a>). As
I plan to support this specification in
<a href="http://vmx.cx/cgi-bin/blog/index.cgi/geocouch-the-future-is-now:2010-05-03:en,CouchDB,Python,Erlang,geo">GeoCouch</a>,
I was in need of a WKT parser written in Erlang. I tried several
ways to write this parser, but I ended up with writing it manually,
based on the ideas of the fabulous <a href="http://code.google.com/p/mochiweb/source/browse/trunk/src/mochijson2.erl">MochiWeb JSON2
Parser</a></p>

<p>The parser is meant for fast parsing, it is non-validating. This means
that it parses only valid WKT and all other strings that seem to be
valid, but are not. The grammar is simplified to (in <a href="http://www.w3.org/TR/2004/REC-xml-20040204/#sec-notation">EBNF as used for
the XML spec</a>):</p>

<pre><code>wkt ::= item | string  '(' space* item (comma item)* ')'
item ::= string (geom | list | nested_list | item | 'EMPTY')
nested_list ::= space* '(' list (comma list)* ')' | '(' nested_list+ ')'
list ::= '(' geom (comma geom)* ')'
geom ::= space* '(' coord (comma coord)* ')'
coord ::= space* number (space+ number)*
number ::= integer | float 
integer ::=  ('-' | '+')? [0-9]+
float ::= ('-' | '+')? [0-9]+ '.' [0-9]+ exponent?
exponent = 'E' ('-' | '+')? [0-9]+
string ::= [a-zA-Z]+ (space* [a-zA-Z])*
space :== #x20
comma :== ',' space*
</code></pre>

<p>I hope I got the grammar right, leave a comment if not. This means
also strings like <code>this(is(10 20), a test EMPTY)</code> would be parsed to:</p>

<pre><code>{this,[{is,[{10,20}]},{'a test',[]}]}
</code></pre>

<p>A validating parser would be much slower as it would also need to
perform checks on the geometry, e.g. for polygons whether interiors
are really within the exterior ring or not.</p>

<p>The general rule is, a list of coordinates is transformed to a tuple,
a list of coordinates to a list. The geometry name will be an
atom. Here's an example for a polygon:</p>

<pre><code>wkt:parse("POLYGON ((102 103, 204 205, 306 107, 102 103),
                    (12 13, 24 25, 36 17, 12 13),
                    (62 63, 74 75, 86 67, 62 63))").
{polygon,[[{102,103},{204,205},{306,107},{102,103}],
          [{12,13},{24,25},{36,17},{12,13}],
          [{62,63},{74,75},{86,67},{62,63}]]}
</code></pre>

<p>In case you're getting excited now, <a href="http://github.com/vmx/wkt">the source is available at Github</a>,
realeased under the <a href="http://www.opensource.org/licenses/mit-license.php">MIT
License</a>.

<p>If someone plans to write a validating WKT parser for Erlang (please
let me know), I propose using
<a href="http://github.com/seancribbs/neotoma/">neotoma</a> it's really a nice
"<em>packrat parser-generator for Erlang for <a href="http://en.wikipedia.org/wiki/Parsing_expression_grammar">Parsing Expression
Grammars</a> (PEGs)</em>".</p>
]]></content:encoded>
<wfw:commentRss>http://vmx.cx/cgi-bin/blog/index.cgi/non-validating-wkt-parser-for-erlang%3A2010-05-14%3Aen%2CGeoCouch%2CErlang%2Cgeo/feed/</wfw:commentRss>
</item>
<item>
<title>GeoCouch: The future is now
</title>
<link>http://vmx.cx/cgi-bin/blog/index.cgi/geocouch-the-future-is-now%3A2010-05-03%3Aen%2CCouchDB%2CPython%2CErlang%2Cgeo</link>
<comments>http://vmx.cx/cgi-bin/blog/index.cgi/geocouch-the-future-is-now%3A2010-05-03%3Aen%2CCouchDB%2CPython%2CErlang%2Cgeo#comments</comments>
<pubDate>Mon, 03 May 2010 14:25:33 +0200</pubDate>
<dc:creator>Volker Mische</dc:creator>
<category>en</category>
<category>CouchDB</category>
<category>Python</category>
<category>Erlang</category>
<category>geo</category>
<guid isPermaLink="false">http://vmx.cx/cgi-bin/blog/index.cgi/geocouch-the-future-is-now%3A2010-05-03%3Aen%2CCouchDB%2CPython%2CErlang%2Cgeo/</guid>
<description><![CDATA[ 
 [...]]]></description>
<content:encoded><![CDATA[

<p><b>Update:</b> <em>This blog entry is outdated and kepts for historical
reasons. Please do always check for newer blog posts. The up to date
information on how to install and use GeoCouch can be found in
<a href="https://github.com/couchbase/geocouch/#readme">its README</a>.
</em></p>

<p>An idea has become reality. Exactly two years after the
<a href="http://vmx.cx/cgi-bin/blog/index.cgi/couchdb-and-geodata:2008-05-03:en,geo,CouchDB">blog post with the initial vision</a>,
a new version of GeoCouch is finished. It's a huge step forward. The first time
the dependencies were narrowed down to <a href="http://couchdb.apache.org">CouchDB</a>
itself. No <a href="http://www.python.org">Python</a>,
no <a href="http://www.gaia-gis.it/spatialite/">SpatiaLite</a> any longer, it's pure
<a href="http://www.erlang.org">Erlang</a>. GeoCouch is tightly integrated with
CouchDB, so you'll get all the nice features you love about CouchDB.</p>

<h3>Current implementation</h3>

<p>Thanks to the feedback after the FOSS4G 2009 and
<a href="http://vmx.cx/cgi-bin/blog/index.cgi/geocouch-the-future:2009-12-20:en,CouchDB,Python,geo">"GeoCouch: The future" blog entry</a>"
it was clear that people prefer a simple, yet powerful and tightly integrated
approach, rather than having to many external dependencies (which was a
showstopper for quite a few people).</p>

<p>I implemented an R-tree (I call it vtree as the implementation is
subject to change a lot) from scratch. The reason why I haven't used
the <a href="http://github.com/cchandler/RTreeCouchDB">already existing R-Tree implementation available at
Github</a> is that I needed
something to learn Erlang, it doesn't contain test or examples and
that it is always a good idea to implement a data structure yourself
to understand the details/problems. My implementation is far from
being perfect but works good enough for now. The vtree is implemented
as an append-only data structure just as CouchDB's B-trees
are. Currently it doesn't support bulk insertion.</p>

<p>If you want to know details on how to create your own indexer, have a look at
my <a href="http://vmx.cx/couchdb/tutorial/indexer.html">Indexer tutorial</a>.</p>

<h3>Feature set</h3>

<p>Following the "Release early, release often" philosophy currently only points
can be inserted, the only supported query is a bounding box search. Though
other geometries should follow soon.</p>

<h3>Using GeoCouch</h3>

<p>GeoCouch is now <a href="http://github.com/vmx/couchdb/tree/geocouch">hosted
at Github</a>. Giving GeoCouch a go is easy:</p>

<pre><code>git clone http://github.com/vmx/couchdb.git
cd couchdb
./bootstrap
./configure
make dev
./utils/run
</code></pre>

<p>To try the spatial features when it's up and running is easy as well. Just add
a <code>spatial</code> property and a named function to your Design Document as you
would to for
<a href="http://wiki.apache.org/couchdb/Formatting_with_Show_and_List">show or list functions</a>:</p>

<pre><code>function(doc) {
    if (doc.loc) {
        emit(doc._id, {
            type: "Point",
            coordinates: [doc.loc[0], doc.loc[1]]
        });
    }
};
</code></pre>

<p>All you need to do is emitting <a href="http://geojson.org">GeoJSON</a> as the value
(Remember that <code>point</code> is the only supported geometry at the moment), the
key is currently ignored.</p>

<pre><code>curl -X PUT http://127.0.0.1:5984/places
curl -X PUT -d '{"spatial":{"points":"function(doc) {\n    if (doc.loc) {\n        emit(doc._id, {\n            type: \"Point\",\n            coordinates: [doc.loc[0], doc.loc[1]]\n        });\n    }};"}}' http://127.0.0.1:5984/places/_design/main
</code></pre>

<p>Before a bounding box query can return anything, you need to insert Documents
that contain a location.</p>

<pre><code>curl -X PUT -d '{"loc": [-122.270833, 37.804444]}' http://127.0.0.1:5984/places/oakland
curl -X PUT -d '{"loc": [10.898333, 48.371667]}' http://127.0.0.1:5984/places/augsburg
</code></pre>

<p>And finally you can make a bounding box request:</p>

<pre><code>curl -X GET 'http://localhost:5984/places/_design/main/_spatial/points/%5B0,0,180,90%5D'
</code></pre>

<p>This one should return only <code>augsburg</code>:</p>

<pre><code>{"query1":[{"id":"augsburg","loc":[10.898333,48.371667]}]}
</code></pre>

<h3>Next steps</h3>

<p>The development of GeoCouch was quite slow in the past, but it gets up
to speed as my diploma thesis (comparable to a master's thesis) will be
about GeoCouch. Additionally <a href="http://www.couch.io/">Couchio</a> kindly
supports the development.</p>

<p>The next steps are (in no particular order):</p>

<ul>
<li>Better R-tree (better splitting algorithm, bulk operations)</li>
<li>Supporting more geometries</li>
<li>Polygon search</li>
<li>Improving CouchDB's plugin capabilities</li>
</ul>

<h3>Thanks</h3>

<p>I'd like to thank all the people that kept me motivated over the past two
years with their tremendous feedback. Special thanks go to
<a href="http://jan.prima.de/">Jan Lehnardt</a> for getting me onto the Couch,
<a href="http://cameronshorter.blogspot.com/">Cameron Shorter</a> for introducing me
into the geospatial open source business and all people from
<a href="http://www.couch.io/">Couchio</a> for the
great two weeks in Oakland.</p>
]]></content:encoded>
<wfw:commentRss>http://vmx.cx/cgi-bin/blog/index.cgi/geocouch-the-future-is-now%3A2010-05-03%3Aen%2CCouchDB%2CPython%2CErlang%2Cgeo/feed/</wfw:commentRss>
</item>
<item>
<title>Processing PDF files: Auto advance
</title>
<link>http://vmx.cx/cgi-bin/blog/index.cgi/processing-pdf-files-auto-advance%3A2010-02-23%3Aen%2CPython</link>
<comments>http://vmx.cx/cgi-bin/blog/index.cgi/processing-pdf-files-auto-advance%3A2010-02-23%3Aen%2CPython#comments</comments>
<pubDate>Tue, 23 Feb 2010 23:16:33 +0200</pubDate>
<dc:creator>Volker Mische</dc:creator>
<category>en</category>
<category>Python</category>
<guid isPermaLink="false">http://vmx.cx/cgi-bin/blog/index.cgi/processing-pdf-files-auto-advance%3A2010-02-23%3Aen%2CPython/</guid>
<description><![CDATA[ 
 [...]]]></description>
<content:encoded><![CDATA[

<p>Sometimes you need a PDF file that auto advances (auto flip, slide show)
pages after a certain amount of seconds. For example for presenting a
<a href="http://en.wikipedia.org/wiki/Lightning_Talk">Lightning Talk</a> the
<a href="http://en.wikipedia.org/wiki/Ignite_(event)">Ingnite way</a>. There
are several ways to achieve this. Today I've spent hours to find the best way.
</p>

<p>You could just hope that your favourite PDF viewer supports changing slides
automatically in a certain interval
(<a href="http://http://projects.gnome.org/evince/">Evince</a> doesn't). But
you never know which viewer will be used when you rely on other people's
computers. The next step is obvious, try to get the PDF file itself to auto
advance. It is possible as
<a href="http://help.adobe.com/en_US/Acrobat/9.0/Standard/WS58a04a822e3e50102bd615109794195ff-7c68.w.html">Adobe
Acrobat supports such a setting</a> (it seems that even
<a href="http://pcsplace.com/tips-n-tricks/make-powerpoint-like-presentations-from-pdf-documents-with-acrobat-page-transitions/">Acrobat
Reader</a> does, though I can't find that option in my one under Linux), I just
need to find out how.
</p>

<p>After some further research I found out that Latex' hyperref package
<a href="http://agents.felk.cvut.cz/wiki/doku.php?id=tricks:latex">supports it as well</a> (no, I don't speak Czech). So I made some minimal
<a href="http://latex-beamer.sourceforge.net/">Latex Beamer</a> presentation to
give it a try. The important notice that the <code>\hypersetup{pdfpageduration=n}</code> must be the first item within a <code>\begin{frame}</code> was found
<a href="http://xavier.perseguers.ch/fileadmin/download/LaTeX/guidelines.pdf">in
some presentation guidelines</a>. Guess what? It even works with Evince (<a href="/blog/2010-02-23/beamer-autoflip.tex">tex file</a>, <a href="/blog/2010-02-23/beamer-autoflip.pdf">PDF file</a>).
</p>

<p>I'm getting closer. Though my problem is that I create my slides with
<a href="http://www.inkscape.org">Inkscape</a> (resp. <a
href="http://projects.abourget.net/inkscapeslide/">Inkscape Slide</a>), so I
can't really user Latex Beamer for it. But the previously mentioned
presentation guidelines also mention the <code>/Dur</code> entry in the PDF
page object. So it should be easy to add it manually. And it really is. A quick
search through the PDF file generated by Latex you can see that
<code>/Dur</code> occurs a close to <code>/MediaBox</code>. After adding those
<code>/Dur 2</code> to my original presentation PDF file right after
<code>\MediaBox</code> it auto flipped every 2 seconds.
</p>

<p>I could have written a simple script that adds it to the PDF at the right
place, but that sounds pretty fragile. A better approach would be to use a PDF
library that is meant for manipulating PDF files. As my favourite programming
language is Python at the moment, I came across
<a href="http://pybrary.net/pyPdf/">pyPdf</a>. A quick look at the internals
showed that it contains everything I need.</p>

<p>Here's my final solution for the problem of creating auto advancing PDF
slides. A small script that does exactly what I need (and not more). I've
used the Python 3 version of pyPdf, but the script should look similar for
Python 2.x.
</p>

<code><pre>
#!/usr/bin/env python3.1
# Copyright (c) 2010 Volker Mische (http://vmx.cx/)
# Licensed under MIT.

import sys
from pyPdf import PdfFileWriter, PdfFileReader
from pyPdf.generic import NameObject, NumberObject

def main(argv=None):
    if argv is None:
        argv = sys.argv

    if len(argv) != 4:
        print('Usage: setduration.py [duration-in-seconds] [input-pdf]',
              '[output-pdf]')
        return

    pdfin = PdfFileReader(open(argv[2], "rb"))
    pdfout = PdfFileWriter()

    for page in pdfin.pages:
        page[NameObject('/Dur')] = NumberObject(argv[1])
        pdfout.addPage(page)

    outputStream = open(argv[3], "wb")
    pdfout.write(outputStream)

if __name__ == '__main__':
    sys.exit(main())
</pre></code>

]]></content:encoded>
<wfw:commentRss>http://vmx.cx/cgi-bin/blog/index.cgi/processing-pdf-files-auto-advance%3A2010-02-23%3Aen%2CPython/feed/</wfw:commentRss>
</item>
</channel>
</rss>

