<?xml version="1.0" encoding="UTF-8"?>
<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/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>spatial nodes</title>
	<atom:link href="http://blog.minst.net/feed" rel="self" type="application/rss+xml" />
	<link>http://blog.minst.net</link>
	<description>Thoughts of a lost soul</description>
	<lastBuildDate>Thu, 02 Sep 2010 15:45:08 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.0.1</generator>
		<item>
		<title>OSM history in one image</title>
		<link>http://blog.minst.net/2010/09/02/osm-history-in-one-image</link>
		<comments>http://blog.minst.net/2010/09/02/osm-history-in-one-image#comments</comments>
		<pubDate>Thu, 02 Sep 2010 15:45:08 +0000</pubDate>
		<dc:creator>stvn</dc:creator>
				<category><![CDATA[design]]></category>
		<category><![CDATA[OSM]]></category>

		<guid isPermaLink="false">http://blog.minst.net/?p=284</guid>
		<description><![CDATA[OSM coverage of Berlin over time I was asked to design a cover for the thesis of our intern working on crowd quality in OSM. This image is a modification of the nice animations GeoFabrik produce on demand, in this case Berlin. Since it needs to be printed I couldn&#8217;t use the animation itself. Time [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://blog.minst.net/wp-content/uploads/2010/09/berlin-anim2.png" rel="lightbox[284]"><img class="alignnone size-medium wp-image-285" title="Berlin over time" src="http://blog.minst.net/wp-content/uploads/2010/09/berlin-anim2-300x239.png" alt="" width="300" height="239" /></a></p>
<p>OSM coverage of Berlin over time</p>
<p><span id="more-284"></span>I was asked to design a cover for the thesis of our intern working on crowd quality in OSM. This image is a modification of the nice animations <a href="http://www.geofabrik.de/gallery/history/index.html">GeoFabrik </a>produce on demand, in this case Berlin. Since it needs to be printed I couldn&#8217;t use the animation itself. Time moves within the image from left to right. You see that early in OSM-history there was just one highway and over time the data becomes more complete and hopefully more accurate.</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.minst.net/2010/09/02/osm-history-in-one-image/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>kõik &#8211; drawing menu</title>
		<link>http://blog.minst.net/2010/09/01/koik-drawing-menu</link>
		<comments>http://blog.minst.net/2010/09/01/koik-drawing-menu#comments</comments>
		<pubDate>Wed, 01 Sep 2010 18:32:26 +0000</pubDate>
		<dc:creator>stvn</dc:creator>
				<category><![CDATA[GIS]]></category>
		<category><![CDATA[TableTop]]></category>
		<category><![CDATA[design]]></category>
		<category><![CDATA[kõik]]></category>

		<guid isPermaLink="false">http://blog.minst.net/?p=257</guid>
		<description><![CDATA[The first short movie in the kõik on the MS Surface series; the drawing menu: The Surface has been hanging around in our office for a while and we&#8217;ve done lots of interesting small and big projects for it. However they&#8217;ve been pretty fragmented and to show what we could do with the Surface you [...]]]></description>
			<content:encoded><![CDATA[<p>The first short movie in the kõik on the MS Surface series; the drawing menu:</p>
<p><a href="http://blog.minst.net/2010/09/01/koik-drawing-menu"><em>Click here to view the embedded video.</em></a></p>
<p><img title="More..." src="http://blog.minst.net/wp-includes/js/tinymce/plugins/wordpress/img/trans.gif" alt="" /><span id="more-257"></span></p>
<p>The Surface has been hanging around in our office for a while and we&#8217;ve done lots of interesting small and big projects for it. However they&#8217;ve been pretty fragmented and to show what we could do with the Surface you had to use several applications which had many similarities, which was confusing. So we decided that it was time to create an application which would show all our new ideas and developments. Looking for a nice name we came across &#8216;<a href="http://en.wiktionary.org/wiki/k%C3%B5ik">kõik</a>&#8216; which both means everyone and every(thing), which is pretty much sums up what we want to achieve: an application which can be used by everyone and shows everything we do.</p>
<p>It was originally designed for landuse planning. Planners need to be able to move and zoom a map, but also annotate on it. The trouble with touch devices is that there is no difference between drawing and dragging, unlike keyboard/mouse (drawing is left mousebutton and dragging middle for instance). Having to press a button somewhere on the Surface to enable/disable drawing was too confusing, people tend to forget that they pressed them and in what modus they are now.</p>
<p>Having a physical object on the table turned out to be much easier to use and remember. If there was &#8216;the&#8217; object on the table, you could draw and if you want to move the map, you just lift the object and move the map. Having established the object as the drawing-toggle, I then moved all drawing related interaction to a menu activated and related to the object. Currently you can choose the color and line thickness and whether you want to draw a line or polygon or you want to edit existing features, undo/redo actions and add new drawing layers.</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.minst.net/2010/09/01/koik-drawing-menu/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>TileSeeder</title>
		<link>http://blog.minst.net/2010/09/01/tileseeder</link>
		<comments>http://blog.minst.net/2010/09/01/tileseeder#comments</comments>
		<pubDate>Wed, 01 Sep 2010 18:10:06 +0000</pubDate>
		<dc:creator>stvn</dc:creator>
				<category><![CDATA[GIS]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[design]]></category>

		<guid isPermaLink="false">http://blog.minst.net/?p=254</guid>
		<description><![CDATA[Design for a python based GUI program for tile management. (Image taken from the presentation I&#8217;m giving at foss4g 2010) I&#8217;m involved in EduGIS and one of the nice things about this project is that we have hundreds of map layers. However that begins to pose a problem for us; to produce a decent speed [...]]]></description>
			<content:encoded><![CDATA[<p>Design for a python based GUI program for tile management.</p>
<p><a href="http://blog.minst.net/wp-content/uploads/2010/09/app.png" rel="lightbox[254]"><img class="alignnone size-medium wp-image-255" title="TileSeeder mockup" src="http://blog.minst.net/wp-content/uploads/2010/09/app-300x240.png" alt="" width="300" height="240" /></a></p>
<p>(Image taken from the presentation I&#8217;m <a href="http://2010.foss4g.org/presentations_show.php?id=3450">giving</a> at <a href="http://2010.foss4g.org/program.php">foss4g</a> 2010)</p>
<p><span id="more-254"></span>I&#8217;m involved in <a href="http://www.edugis.nl/">EduGIS </a>and one of the nice things about this project is that we have hundreds of map layers. However that begins to pose a problem for us; to produce a decent speed for classes full of schoolkids using it at the same time we are using tiling.</p>
<p>We currently use <a href="http://tilecache.org/">TileCache</a>; a very nice and quick open source tilecaching program. However we keep adding layers and we need those to be quick when students are using them, but we don&#8217;t have the capacity to prerender (seed) everything, nor to do this on the fly. Since we mostly have dutch data, served at dutch students, we figured that we only need to seed a certain set of tiles; the entire country for the higher levels and the rural areas a bit deeper and the urban areas even deeper.</p>
<p>So I came up with the idea to create a desktop application to make it easier to create a complex seed that does more zoomlevels for certain areas and less for others.</p>
<p>Thanks to generous development time invested by Christian there is a first alpha available around foss4g at <a href="http://code.google.com/p/tileseeder/">googlecode</a></p>
]]></content:encoded>
			<wfw:commentRss>http://blog.minst.net/2010/09/01/tileseeder/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Visualizing OpenStreetMap history &#8211; part 2</title>
		<link>http://blog.minst.net/2010/07/16/visualizing-openstreetmap-history-part-2</link>
		<comments>http://blog.minst.net/2010/07/16/visualizing-openstreetmap-history-part-2#comments</comments>
		<pubDate>Fri, 16 Jul 2010 16:10:12 +0000</pubDate>
		<dc:creator>stvn</dc:creator>
				<category><![CDATA[GIS]]></category>
		<category><![CDATA[design]]></category>
		<category><![CDATA[work]]></category>
		<category><![CDATA[OpenStreetMap]]></category>
		<category><![CDATA[OSM]]></category>
		<category><![CDATA[visualization]]></category>

		<guid isPermaLink="false">http://blog.minst.net/?p=214</guid>
		<description><![CDATA[Thanks to the hard work of Vincent we now have a database with the average version and average age of nodes per grid cell. Now we can start to get a feeling of the data. I&#8217;ve rendered both datasets for Amsterdam on a 10x10m grid. In general the idea is that red is bad and [...]]]></description>
			<content:encoded><![CDATA[<p>Thanks to the hard work of Vincent we now have a database with the average version and average age of nodes per grid cell. Now we can start to get a feeling of the data. I&#8217;ve rendered both datasets for Amsterdam on a 10x10m grid. In general the idea is that red is bad and green is good. The younger a node is, the more likely it reflects the current situation in the real world. Also the higher the version number, the more people have been looking at that node and corrected it.</p>
<p>At least that is the theory Martijn tries to work with.</p>
<div id="attachment_215" class="wp-caption alignnone" style="width: 310px"><a href="http://blog.minst.net/wp-content/uploads/2010/07/AgeAdam.png" rel="lightbox[214]"><img class="size-medium wp-image-215" title="OSM node-age" src="http://blog.minst.net/wp-content/uploads/2010/07/AgeAdam-300x212.png" alt="" width="300" height="212" /></a><p class="wp-caption-text">The age in days for OpenStreetMap nodes</p></div>
<p><span id="more-214"></span>You can see a clear pattern emerging here, apparently there are areas which get mapped in a short period of time and never touched again. The white squares just didn&#8217;t have any nodes in it, so they contain no data.</p>
<div id="attachment_216" class="wp-caption alignnone" style="width: 310px"><a href="http://blog.minst.net/wp-content/uploads/2010/07/VersionAdam.png" rel="lightbox[214]"><img class="size-medium wp-image-216" title="OSM node-version" src="http://blog.minst.net/wp-content/uploads/2010/07/VersionAdam-300x212.png" alt="" width="300" height="212" /></a><p class="wp-caption-text">The version of OSM nodes</p></div>
<p>It is more difficult to see patterns here. Whereas with age in days the number gives you an instant grasp of the meaning, the version number is less obvious. We probably need to do a statistical analysis of version numbers in OSM. This way we can attach some (relative) meaning to the average version number.</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.minst.net/2010/07/16/visualizing-openstreetmap-history-part-2/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Visualizing OpenStreetMap history</title>
		<link>http://blog.minst.net/2010/07/06/visualizing-openstreetmap-history</link>
		<comments>http://blog.minst.net/2010/07/06/visualizing-openstreetmap-history#comments</comments>
		<pubDate>Tue, 06 Jul 2010 16:12:07 +0000</pubDate>
		<dc:creator>stvn</dc:creator>
				<category><![CDATA[GIS]]></category>
		<category><![CDATA[design]]></category>
		<category><![CDATA[work]]></category>
		<category><![CDATA[OpenStreetMap]]></category>
		<category><![CDATA[Processing]]></category>

		<guid isPermaLink="false">http://blog.minst.net/?p=207</guid>
		<description><![CDATA[I&#8217;m working with Martijn and Vincent on a way to visualize the history of OpenStreetmap data for their analysis of the &#8216;crowd-quality&#8217; of the data. I used my favorite visualization tool Processing to visualize the history of one node: The red circle is the final location of the node and the path is the order [...]]]></description>
			<content:encoded><![CDATA[<p>I&#8217;m working with Martijn and Vincent on a way to visualize the history of OpenStreetmap data for their analysis of the &#8216;crowd-quality&#8217; of the data. I used my favorite visualization tool <a href="http://processing.org/">Processing </a>to visualize the history of one <a href="http://www.openstreetmap.org/api/0.6/node/46090136/history">node</a>:</p>
<p><a href="http://blog.minst.net/wp-content/uploads/2010/07/tracks2.png" rel="lightbox[207]"><img class="alignnone size-medium  wp-image-210" title="Node: 46090136" src="http://blog.minst.net/wp-content/uploads/2010/07/tracks2-300x225.png" alt="" width="300" height="225" /></a></p>
<p><span id="more-207"></span>The red circle is the final location of the node and the path is the order of changes. You can see that the first changes were much more rough than the last ones.</p>
<p>I also did the same for an entire <a href="http://www.openstreetmap.org/api/0.6/way/10210239/history">way</a>, where the way itself is shown in blue and the versions of the nodes are shown next to the nodes.</p>
<p><a href="http://blog.minst.net/wp-content/uploads/2010/07/tracks1.png" rel="lightbox[207]"><img class="alignnone size-medium wp-image-209" title="Way 10210239" src="http://blog.minst.net/wp-content/uploads/2010/07/tracks1-300x225.png" alt="" width="300" height="225" /></a></p>
<p>The trouble is that it is currently quite difficult to get the full (spatial) history of an area in OpenStreetMap. Once we find a way to do so I hope to generate more and play a bit with different visualization styles and methods.</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.minst.net/2010/07/06/visualizing-openstreetmap-history/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Creating a timelapse movie with ubuntu</title>
		<link>http://blog.minst.net/2009/12/22/creating-a-timelapse-movie-with-ubuntu</link>
		<comments>http://blog.minst.net/2009/12/22/creating-a-timelapse-movie-with-ubuntu#comments</comments>
		<pubDate>Tue, 22 Dec 2009 21:13:43 +0000</pubDate>
		<dc:creator>wordpress</dc:creator>
				<category><![CDATA[Open Source]]></category>
		<category><![CDATA[home]]></category>
		<category><![CDATA[personal]]></category>
		<category><![CDATA[timelapse]]></category>

		<guid isPermaLink="false">http://blog.minst.net/?p=201</guid>
		<description><![CDATA[It has been a while since I made my last timelapse movie and I figured that today was a good day to check the status of linux and timelapsing. A quick google gave me gTimelapse which should allow my to use my dSLR as a timelapse camera. This would give me two advantages over my [...]]]></description>
			<content:encoded><![CDATA[<p>It has been a while since I made my last timelapse movie and I figured that today was a good day to check the status of linux and timelapsing. A quick google gave me <a href="http://ultrawide.wordpress.com/2009/01/27/timelapse-photography-on-linux/">gTimelapse</a> which should allow my to use my dSLR as a timelapse camera. This would give me two advantages over my old set-up (and one disadvantage). My old set-up was a Nikon S4 with a power adapter and a reasonably big SD card. Having a power adapter meant that I could leave it running for months, which gave me for instance:</p>
<p><a href="http://blog.minst.net/2009/12/22/creating-a-timelapse-movie-with-ubuntu"><em>Click here to view the embedded video.</em></a></p>
<p><span id="more-201"></span>But the minimum interval is 30 seconds, making it useless for timelapses of people moving about. Also the quality of the sensor and the lens is not as good as my dSLR. With gTimelapse I can control the interval to anything I like. gTimelapse is rather new so there&#8217;s a bit of fiddling involved, to be able to build it under ubuntu 9.10 you need these packages:</p>
<p><code>sudo apt-get install build-essential libgphoto2-2-dev libwxbase2.8-dev libwxgtk2.8-dev</code></p>
<p>From then on it is pretty straight forward, connect your camera (make sure it is in PTP mode) also ubuntu nowadays mounts it automagically, gTimelapse doesn&#8217;t like that. So unmount the camera using the filemanager and start gTimelapse. Depending on your camera you get all kinds of settings you can fiddle with. (side note I discovered that if you first start gTimelapse and than attach the camera none of the settings appear, but the application still works). Once you&#8217;re happy you can press start and sit back.</p>
<p>Creating a movie is still a lot more complicated I&#8217;m afraid. I still haven&#8217;t found a decent movie editor for linux. Kino is nice but only supports DV camera&#8217;s as far as I can tell, dragging something non-DV gives an eternal Kino Import progress bar kdenlive looks promising, but it kept freezing so I gave up on it for the moment. To just get a short movie I threw mencoder at them:</p>
<p><code>mencoder -nosound -ovc lavc -lavcopts vcodec=mpeg4:mbd=2:mv0:trell:v4mv:cbp:last_pred=3:predia=2:dia=2:vmax_b_frames=2:vb_strategy=1:precmp=2:cmp=2:subcmp=2:preme=2:qns=2 -o test5.avi -mf type=jpeg:fps=5 mf://@files.txt </code></p>
<p>Where files.txt was a list of the filenames of all the images I wanted to include. This resulted in this movie:</p>
<p><a href="http://blog.minst.net/2009/12/22/creating-a-timelapse-movie-with-ubuntu"><em>Click here to view the embedded video.</em></a></p>
<p>This means it possible to create timelapse movies with linux, but postprocessing is still difficult. The next timelapse project I&#8217;ll probably shoot with linux and edit on my mac <img src='http://blog.minst.net/wp-includes/images/smilies/icon_sad.gif' alt=':(' class='wp-smiley' /> </p>
]]></content:encoded>
			<wfw:commentRss>http://blog.minst.net/2009/12/22/creating-a-timelapse-movie-with-ubuntu/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Visualizing gps tracks with Processing</title>
		<link>http://blog.minst.net/2009/12/21/visualizing-gps-tracks-with-processing</link>
		<comments>http://blog.minst.net/2009/12/21/visualizing-gps-tracks-with-processing#comments</comments>
		<pubDate>Mon, 21 Dec 2009 15:04:21 +0000</pubDate>
		<dc:creator>stvn</dc:creator>
				<category><![CDATA[GIS]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[design]]></category>
		<category><![CDATA[work]]></category>
		<category><![CDATA[animation]]></category>
		<category><![CDATA[GPS]]></category>
		<category><![CDATA[Processing]]></category>

		<guid isPermaLink="false">http://blog.minst.net/?p=198</guid>
		<description><![CDATA[At work we got an i-gotU (a GPS logger) as a Christmas present. To show what one can do with it I decided to ask a few people to use their i-gotU to record their travels for two weeks. This resulted in over 42000 locations done by 8 different persons. Each person got his/her own [...]]]></description>
			<content:encoded><![CDATA[<p>At work we got an <a href="http://www.i-gotu.com/">i-gotU</a> (a GPS logger) as a Christmas present. To show what one can do with it I decided to ask a few people to use their i-gotU to record their travels for two weeks. This resulted in over 42000 locations done by 8 different persons. Each person got his/her own color in the visualization to be able to see when people were near one another. Since the office is in Amsterdam and most people live in (different parts of) Amsterdam you can quickly see the contours of Amsterdam&#8217;s city-plan appear. Also interestingly is to note that people have their own specific areas where they spend most of their time.</p>
<p><a href="http://blog.minst.net/2009/12/21/visualizing-gps-tracks-with-processing"><em>Click here to view the embedded video.</em></a></p>
<p><span id="more-198"></span></p>
<p>To visualize these tracks I used <a href="http://processing.org/">Processing</a>, &#8216;an open source programming language and environment for people who want to program images, animation, and interactions.&#8217;  There are lots of plugins to read different data formats, an interesting one for this project is the <a href="http://processing.org/hacks/hacks:gpx">gpx library</a>. The plan was to render the tracks of each person in a different color, tracks which happened at the same time should be drawn at the same time. This way you can see which people are at the same time at the same location. Each track would fade out in time, leaving a thin line for past tracks.</p>
<p>To do this on a track-basis however turned out to be quite difficult for my limited knowledge of Processing and the time I had available. So instead of using the gpx module I created a flat table with all locations sorted by time. Each row of the table contains lon,lat,color-id,time. The program iterates through all 42000+ rows and draws the locations as a dot. The size of the dot depends on how &#8216;old&#8217; the point is. The last 200 points are drawn with a diminishing size, creating the worm-like effect in the animation. Note that it doesn&#8217;t take into account the actual time between points, just if it is next in line.</p>
<p>A few tweaks were added: Holland in unprojected lat-lon looks odd to dutch people, so I implemented a simple projection library to reproject the points to a semi-RD (dutch projection). Also I wanted to dynamically zoom to the action (not everything was happening in Amsterdam). I did this by calculating the minimum and maximum X and Y for the last 200 points. I wanted the location of our office building to be in view all the time, to provide a point of reference.</p>
<p>The source code can be found <a href="http://blog.minst.net/wp-content/uploads/2009/12/drawing.zip">here </a>if you are really interested. There are three files: Table.pde as written by Ben Fry for his book Visualizing Data, Soprojection.pde, written by <a href="http://blog.geodeo.nl/">Steven Fruijtier</a> at my request and Drawing.pde is hacked together by me. This is a very crude and brute-force approach to render a series of tracks, so please use it with care. Since it needs to recalculate each point for each frame it tends to become slower as it advances through the table.</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.minst.net/2009/12/21/visualizing-gps-tracks-with-processing/feed</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Perceived WCS inaccuracy</title>
		<link>http://blog.minst.net/2009/12/09/perceived-wcs-inaccuracy</link>
		<comments>http://blog.minst.net/2009/12/09/perceived-wcs-inaccuracy#comments</comments>
		<pubDate>Wed, 09 Dec 2009 12:03:56 +0000</pubDate>
		<dc:creator>stvn</dc:creator>
				<category><![CDATA[Open Source]]></category>
		<category><![CDATA[web]]></category>
		<category><![CDATA[Deegree]]></category>
		<category><![CDATA[Geoserver]]></category>
		<category><![CDATA[Mapserver]]></category>
		<category><![CDATA[WCS]]></category>

		<guid isPermaLink="false">http://blog.minst.net/?p=178</guid>
		<description><![CDATA[Working with WCS I discovered a small but noticable shift of data in all three major OSS WCS applications: Geoserver 2.0 (SNAPSHOT downloaded 8 december 10.19UTC) Mapserver 5.6.0 (MS4W Base installer v3.0 Beta 7 + MapServer 5.6.0 release Upgrade) Deegree 2.3rc1 (Apache Tomcat 5.5.28) To find out what the problem exactly was I&#8217;ve done some [...]]]></description>
			<content:encoded><![CDATA[<p>Working with WCS I discovered a small but noticable shift of data in all three major OSS WCS applications:</p>
<ul>
<li> Geoserver 2.0 (SNAPSHOT downloaded 8 december 10.19UTC)</li>
<li> Mapserver 5.6.0 (MS4W Base installer v3.0 Beta 7 + MapServer 5.6.0 release Upgrade)</li>
<li> Deegree 2.3rc1 (Apache Tomcat 5.5.28)</li>
</ul>
<p>To find out what the problem exactly was I&#8217;ve done some testing. I&#8217;ve taken a GeoTiff and configured all three the WCS applications to serve it. Gdalinfo gives us the following <a title="gdalinfo" href="http://blog.minst.net/wp-content/uploads/2009/12/gdalinfo.txt" target="_blank">information</a>, basically it is a GeoTIFF in epsg:3035 with a native resolution of 100m/pixel.</p>
<p><span id="more-178"></span></p>
<p>My test sequence was:</p>
<ol>
<li>request the full extent in native resolution</li>
<li>request the full extent in a 10th of the resolution</li>
<li>request the full extent with the same size as the original data (256&#215;256)</li>
<li>request part of the data in native resolution</li>
<li>request part of the data in non-native, non-multiple resolution</li>
</ol>
<p>I&#8217;m not going to show all the results here, because that would result in an unhealthy long document <img src='http://blog.minst.net/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
<p>To verify the results I loaded the original GeoTiff in Quantum GIS and highlighted a specific feature to show the possible offset of the different results.</p>
<blockquote>
<pre><!--
		@page { size: 8.5in 11in; margin: 0.79in }
		P { margin-bottom: 0.08in }
--></pre>
</blockquote>
<div id="attachment_179" class="wp-caption alignnone" style="width: 600px"><a href="http://blog.minst.net/wp-content/uploads/2009/12/basicdata.png" rel="lightbox[178]"><img class="size-full wp-image-179" title="basicdata" src="http://blog.minst.net/wp-content/uploads/2009/12/basicdata.png" alt="Corine GeoTiff" width="590" height="548" /></a><p class="wp-caption-text">Corine GeoTiff</p></div>
<h3>1  request the full extent in native resolution:</h3>
<p>deegree: http://localhost:8080/deegree-wcs1/services?service=WCS&amp;version=1.0.0&amp;request=GetCoverage&amp;coverage=Corine&amp;crs=EPSG:3035&amp;BBOX=3539200,3402400,3564800,3428000&amp;resx=100&amp;resy=100&amp;format=GeoTIFF gives a three band(!) GeoTiff of 262,674 bytes with a shift of around 40m:</p>
<div id="attachment_181" class="wp-caption alignnone" style="width: 600px"><a href="http://blog.minst.net/wp-content/uploads/2009/12/deegreefull.png" rel="lightbox[178]"><img class="alignnone size-full wp-image-180" title="deegreefull" src="http://blog.minst.net/wp-content/uploads/2009/12/deegreefull.png" alt="deegreefull" width="590" height="548" /></a><p class="wp-caption-text">Deegree result</p></div>
<p>MapServer: http://localhost/cgi-bin/mapserver56/mapserv.exe?map=maps/corine.map&amp;service=WCS&amp;version=1.0.0&amp;request=GetCoverage&amp;coverage=Corine&amp;crs=EPSG:3035&amp;BBOX=3539200,3402400,3564800,3428000&amp;resx=100&amp;resy=100&amp;format=GTiff gives a three band(!) GeoTiff of 197,477 bytes without a shift:</p>
<div id="attachment_182" class="wp-caption alignnone" style="width: 600px"><a href="http://blog.minst.net/wp-content/uploads/2009/12/mapserverfull.png" rel="lightbox[178]"><img class="size-full wp-image-182" title="mapserverfull" src="http://blog.minst.net/wp-content/uploads/2009/12/mapserverfull.png" alt="Mapserver result" width="590" height="548" /></a><p class="wp-caption-text">Mapserver result</p></div>
<p>GeoServer: http://localhsot:8081/geoserver/ows?service=WCS&amp;version=1.0.0&amp;request=GetCoverage&amp;coverage=corine_merge_gtiff_proj_121_108&amp;crs=EPSG:3035&amp;BBOX=3539200,3402400,3564800,3428000&amp;resx=100&amp;resy=100&amp;format=GeoTiff gives a single band GeoTiff of 8,848 bytes with a shift of  around 50m:</p>
<p style="margin-bottom: 0in;">
<div id="attachment_183" class="wp-caption alignnone" style="width: 600px"><a href="http://blog.minst.net/wp-content/uploads/2009/12/geoserverfull.png" rel="lightbox[178]"><img class="size-full wp-image-183" title="geoserverfull" src="http://blog.minst.net/wp-content/uploads/2009/12/geoserverfull.png" alt="Geoserver result" width="590" height="548" /></a><p class="wp-caption-text">Geoserver result</p></div>
<h3>Note:</h3>
<p>Deegree both shifts the data and returns a multi-band image; Mapserver doesn&#8217;t shift the data, but returns a multi-band image; Geoserver shifts the data 1/2 a pixel (50m), but does give a single band image.</p>
<h3>2. request the full extent in a 10th of the resolution</h3>
<p>deegree: http://localhost:8080/deegree-wcs1/services?service=WCS&amp;version=1.0.0&amp;request=GetCoverage&amp;coverage=Corine&amp;crs=EPSG:3035&amp;BBOX=3539200,3402400,3564800,3428000&amp;resx=10&amp;resy=10&amp;format=GeoTIFF produces a 26,237,726 multi band GeoTiff which shifts the data the other way than the first request:</p>
<div id="attachment_184" class="wp-caption alignnone" style="width: 600px"><a href="http://blog.minst.net/wp-content/uploads/2009/12/deegreetenth.png" rel="lightbox[178]"><img class="size-full wp-image-184" title="deegreetenth" src="http://blog.minst.net/wp-content/uploads/2009/12/deegreetenth.png" alt="Deegree result on a tenth of the resolution" width="590" height="548" /></a><p class="wp-caption-text">Deegree result on a tenth of the resolution</p></div>
<p>Mapserver: <!-- 		@page { size: 8.5in 11in; margin: 0.79in } 		P { margin-bottom: 0.08in } -->http://localhost/cgi-bin/mapserver56/mapserv.exe?map=maps/corine.map&amp;service=WCS&amp;version=1.0.0&amp;request=GetCoverage&amp;coverage=Corine&amp;crs=EPSG:3035&amp;BBOX=3539200,3402400,3564800,3428000&amp;resx=10&amp;resy=10&amp;format=GTiff produces a multi-band GeoTiff of 19,681,941 bytes with no shift.</p>
<p>Geoserver: http://localhost:8081/geoserver/ows?service=WCS&amp;version=1.0.0&amp;request=GetCoverage&amp;coverage=corine_merge_gtiff_proj_121_108&amp;crs=EPSG:3035&amp;BBOX=3539200,3402400,3564800,3428000&amp;resx=10&amp;resy=10&amp;format=GeoTiff gives a single band GeoTiff of 158,802 bytes with a shift of around 50m, though there is a small difference with the previous result.</p>
<h3>Note:</h3>
<p>Mapserver and Geoserver both produce a bigger result  (as expected) with the same location as the previous request. Deegree shifts the data differently than previously and also produces a bigger result.</p>
<p style="margin-bottom: 0in;">
<h3>3. request the full extent with the same size as the original data (256&#215;256)</h3>
<p><!-- 		@page { size: 8.5in 11in; margin: 0.79in } 		P { margin-bottom: 0.08in } --></p>
<p style="margin-bottom: 0in;">geoserver: http://localhost:8081/geoserver/ows?service=WCS&amp;version=1.0.0&amp;request=GetCoverage&amp;coverage=corine_merge_gtiff_proj_121_108&amp;crs=EPSG:3035&amp;BBOX=3539200,3402400,3564800,3428000&amp;width=256&amp;height=256&amp;format=GeoTiff produces exactly the same image as in the first request.</p>
<p style="margin-bottom: 0in;">mapserver: http://localhost/cgi-bin/mapserver56/mapserv.exe?map=maps/corine.map&amp;service=WCS&amp;version=1.0.0&amp;request=GetCoverage&amp;coverage=Corine&amp;crs=EPSG:3035&amp;BBOX=3539200,3402400,3564800,3428000&amp;width=256&amp;height=256&amp;format=GTiff produces exactly the same image as in the first request.</p>
<p style="margin-bottom: 0in;">deegree: http://localhost:8080/deegree-wcs1/services?service=WCS&amp;version=1.0.0&amp;request=GetCoverage&amp;coverage=Corine&amp;crs=EPSG:3035&amp;BBOX=3539200,3402400,3564800,3428000&amp;width=256&amp;height=256&amp;format=GeoTIFF produces a slightly smaller image than the first request (262,674 bytes) with no shift!.</p>
<p style="margin-bottom: 0in;">
<div id="attachment_189" class="wp-caption alignnone" style="width: 600px"><a href="http://blog.minst.net/wp-content/uploads/2009/12/deegreefixedsize.png" rel="lightbox[178]"><img class="size-full wp-image-189" title="deegreefixedsize" src="http://blog.minst.net/wp-content/uploads/2009/12/deegreefixedsize.png" alt="Deegree result with width en height" width="590" height="548" /></a><p class="wp-caption-text">Deegree result with width en height</p></div>
<h3>Note:</h3>
<p>Since the request is a different way of describing the same data one would expect that you get the same results. Mapserver and Geoserver do so, Deegree does not, somehow using resx and resy in the request results in shifted data.</p>
<h3>4. request part of the data in native resolution</h3>
<p>deegree: http://localhost:8080/deegree-wcs1/services?service=WCS&amp;version=1.0.0&amp;request=GetCoverage&amp;coverage=Corine&amp;resx=100&amp;resy=100&amp;crs=EPSG:3035&amp;BBOX=3550000,3413200,3554000,3417200&amp;format=GeoTIFF has the correct left-top location but the size of the pixels is wrong, producing a shift of the data which increases as you go right/down:</p>
<div id="attachment_185" class="wp-caption alignnone" style="width: 600px"><a href="http://blog.minst.net/wp-content/uploads/2009/12/deegreepart.png" rel="lightbox[178]"><img class="size-full wp-image-185" title="deegreepart" src="http://blog.minst.net/wp-content/uploads/2009/12/deegreepart.png" alt="Deegree result for a part request" width="590" height="548" /></a><p class="wp-caption-text">Deegree result for a part request</p></div>
<p>geoserver: http://localhost:8081/geoserver/ows?service=WCS&amp;request=GetCoverage&amp;format=GeoTiff&amp;version=1.0.0&amp;coverage=geodan:Corine&amp;resx=100&amp;resy=100&amp;crs=EPSG:3035&amp;BBOX=3550000,3413200,3554000,3417200 produces an image with almost exactly the same shift as the first request.<br />
mapserver: http://localhost/cgi-bin/mapserver56/mapserv.exe?map=maps/corine.map&amp;service=WCS&amp;version=1.0.0&amp;request=GetCoverage&amp;coverage=Corine&amp;resx=100&amp;resy=100&amp;crs=EPSG:3035&amp;BBOX=3550000,3413200,3554000,3417200&amp;format=GTiff produces an image with almost exactly the same location as the first request.</p>
<h3>Note:</h3>
<p>Mapserver and Geoserver shift (or not) the data similar to the first request, Deegree has once again a different shift than any of the previous ones.</p>
<h3>5. request part of the data in non-native, non-multiple resolution</h3>
<p>deegree: http://localhost:8080/deegree-wcs1/services?service=WCS&amp;version=1.0.0&amp;request=GetCoverage&amp;coverage=Corine&amp;resx=30.0&amp;resy=30.0&amp;crs=EPSG:3035&amp;BBOX=3550000,3413200,3554000,3417200&amp;format=GeoTIFF shifts data:</p>
<p><a href="http://blog.minst.net/wp-content/uploads/2009/12/deegreepartnonnative.png" rel="lightbox[178]"><img class="size-full wp-image-186" title="deegreepartnonnative" src="http://blog.minst.net/wp-content/uploads/2009/12/deegreepartnonnative.png" alt="Deegree result for non native, non multiple=" height="548" /></a></p>
<p>geoserver: http://localhost:8081/geoserver/ows?service=WCS&amp;request=GetCoverage&amp;format=GeoTiff&amp;version=1.0.0&amp;coverage=geodan:Corine&amp;resx=30.0&amp;resy=30.0&amp;crs=EPSG:3035&amp;BBOX=3550000,3413200,3554000,3417200 shifts data and adds a black border to the left and top of the result:</p>
<div id="attachment_187" class="wp-caption alignnone" style="width: 600px"><a href="http://blog.minst.net/wp-content/uploads/2009/12/geoserverpartnonnative.png" rel="lightbox[178]"><img class="size-full wp-image-187" title="geoserverpartnonnative" src="http://blog.minst.net/wp-content/uploads/2009/12/geoserverpartnonnative.png" alt="Geoserver result for non-native, non-multiple resolution" width="590" height="548" /></a><p class="wp-caption-text">Geoserver result for non-native, non-multiple resolution</p></div>
<p>mapserver: http://localhost/cgi-bin/mapserver56/mapserv.exe?map=maps/corine.map&amp;service=WCS&amp;version=1.0.0&amp;request=GetCoverage&amp;coverage=Corine&amp;resx=30.0&amp;resy=30.0&amp;crs=EPSG:3035&amp;BBOX=3550000,3413200,3554000,3417200&amp;format=GTiff shifts data:</p>
<div id="attachment_188" class="wp-caption alignnone" style="width: 600px"><a href="http://blog.minst.net/wp-content/uploads/2009/12/mapserverpartnonnative.png" rel="lightbox[178]"><img class="size-full wp-image-188" title="mapserverpartnonnative" src="http://blog.minst.net/wp-content/uploads/2009/12/mapserverpartnonnative.png" alt="Mapserver result for non-native, non-multiple resolution" width="590" height="548" /></a><p class="wp-caption-text">Mapserver result for non-native, non-multiple resolution</p></div>
<h3>Note:</h3>
<p>This request was my initial prompt to find out why all WCS applications shift the data in the results. However this is a false conclusion. What&#8217;s happening here is that the service has to extract 30m wide pixels from 100m wide source data, since 100 divided by 30 isn&#8217;t a whole number it will add the remaining 10m in an adjacent pixel. If you overlay the result and the source data you get a pixel problem, data of source pixel 2 will most likely end up in result pixel b, which is partly over source pixel 1, resulting in a data shift:</p>
<div id="attachment_190" class="wp-caption alignnone" style="width: 311px"><a href="http://blog.minst.net/wp-content/uploads/2009/12/pixelproblem.png" rel="lightbox[178]"><img class="size-full wp-image-190" title="pixelproblem" src="http://blog.minst.net/wp-content/uploads/2009/12/pixelproblem.png" alt="Overlapping 100m with 30m" width="301" height="229" /></a><p class="wp-caption-text">Overlapping 100m with 30m</p></div>
<h2>Conclusion:</h2>
<p>Geoserver has a <span style="text-decoration: line-through;">bug </span>feature which offsets all the results by half a pixel,<span style="text-decoration: line-through;"> this is a known issue with the definition of the location of a pixel</span>. Added to this there&#8217;s the no-data border which appears with non-native, non-multiple requests.<span style="text-decoration: line-through;"> I presume that will be gone once the pixel issue is resolved.</span> (update: apparently I&#8217;ve misunderstood the Geoserver developers; there&#8217;s an issue between pixel placement according to standards and real world implementations, where Geoserver adheres to the standard).</p>
<p>Mapserver doesn&#8217;t offset the data unless it is physically impossible (non-native, non-multiple resolutions, extents which don&#8217;t snap to source data) but produces<span style="text-decoration: line-through;"> a multi-band</span> (this was a configuration issue, thanks to FrankW for spotting this &#8211; proper config is IMAGEMODE BYTE) geotiff where the source data is single band.</p>
<p>Deegree has a bug which offsets some of the results, but I don&#8217;t know what causes it and although it is resolution-related I don&#8217;t see a pattern. It also produces a multi-band geotiff instead of a single band.</p>
<p style="margin-bottom: 0in;">Configuration files and source data can be found <a href="http://dl.dropbox.com/u/175548/data.zip">here</a>.</p>
<div id="_mcePaste" style="overflow: hidden; position: absolute; left: -10000px; top: 0px; width: 1px; height: 1px;"><!-- 		@page { size: 8.5in 11in; margin: 0.79in } 		P { margin-bottom: 0.08in } --></p>
<p style="margin-top: 0.17in; page-break-before: always; page-break-after: avoid;"><span style="font-family: Arial,sans-serif;"><span style="font-size: medium;">Geoserver 2.0 SNAPSHOT downloaded 8 december 10.19 UTC </span></span></p>
</div>
]]></content:encoded>
			<wfw:commentRss>http://blog.minst.net/2009/12/09/perceived-wcs-inaccuracy/feed</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Surface glitches</title>
		<link>http://blog.minst.net/2009/02/18/surface-glitches</link>
		<comments>http://blog.minst.net/2009/02/18/surface-glitches#comments</comments>
		<pubDate>Wed, 18 Feb 2009 11:26:43 +0000</pubDate>
		<dc:creator>stvn</dc:creator>
				<category><![CDATA[TableTop]]></category>
		<category><![CDATA[bastet]]></category>
		<category><![CDATA[work]]></category>
		<category><![CDATA[design]]></category>
		<category><![CDATA[error]]></category>
		<category><![CDATA[Microsoft]]></category>
		<category><![CDATA[Surface]]></category>
		<category><![CDATA[wpf]]></category>

		<guid isPermaLink="false">http://blog.minst.net/?p=169</guid>
		<description><![CDATA[We&#8217;ve got the surface for a while now and have written our first real application. It is based on BruTile and allows you to show various maps, zoom and pan. We created a short movie to show it: Once we got the basics running I tried to edit the XAML to make it look better. [...]]]></description>
			<content:encoded><![CDATA[<p>We&#8217;ve got the surface for a while now and have written our first real application. It is based on <a href="http://www.codeplex.com/brutile">BruTile </a>and allows you to show various maps, zoom and pan. We created a short movie to show it:</p>
<p><a href="http://blog.minst.net/2009/02/18/surface-glitches"><em>Click here to view the embedded video.</em></a></p>
<p><span id="more-169"></span>Once we got the basics running I tried to edit the XAML to make it look better. This turned out to be harder than expected. The surface has once again its own default designs, which in my opinion are worse than the WPF standard designs. The default look is grey and square. So I wanted to change it to something more akin to our other touchtable applications: white and round. However <a href="http://pauldendulk.com/">Paul </a>used a ScatterView component to display the layerlist and the geodan logo. He had read that one can just drop components in a ScatterView, without the need to embed them in ScatterViewItems. This is true, but it is a nightmare for the (non-initiated) designer. What happens is that the grey-square design of the ScatterViewItem is drawn beneath any layout you come up with for your own item. This is a very puzzling behaviour, although not entirely unexpected once you know that the ScatterViewItem exists.</p>
<p>Once I solved this issue I could seriously try to change the layout of the ScatterViewItems. Here however real glitches appeared. We use rounded borders and dropshadows for our items. As you can see below there are (at least) two issues:</p>
<div id="attachment_171" class="wp-caption alignnone" style="width: 603px"><a href="http://blog.minst.net/wp-content/uploads/2009/02/surface-artefact1.png" rel="lightbox[169]"><img class="size-full wp-image-171" title="surface-artefact1" src="http://blog.minst.net/wp-content/uploads/2009/02/surface-artefact1.png" alt="Rounded border on the Surface don't work" width="593" height="491" /></a><p class="wp-caption-text">Rounded border on the Surface don&#39;t work</p></div>
<p>The dark rectangle in the top of the image is actually a shadow of  a ScatterViewItem which for some reason doesn&#8217;t start below it. However this makes it easy to see the first glitch in the rendering. As you can see there is a thin dark line near the edge, which makes a weird square corner at the corner. This shouldn&#8217;t be there and when you resize the ScatterViewItem down, the shadow becomes darker (as it should have been in the first place) and the line is not visible anymore. If you don&#8217;t use rounded corners on the shadow the line is still there, but harder to notice because it is exactly following the edge of the shadow.</p>
<p>The second annoying glitch I&#8217;ve found is the gap between the border and the content. If we zoom in a bit on the layercontrol you can see there is a pixel space between the border and the content:</p>
<div id="attachment_170" class="wp-caption alignnone" style="width: 603px"><a href="http://blog.minst.net/wp-content/uploads/2009/02/surface-artefact2.png" rel="lightbox[169]"><img class="size-full wp-image-170" title="surface-artefact2" src="http://blog.minst.net/wp-content/uploads/2009/02/surface-artefact2.png" alt="A gap between border and content" width="593" height="225" /></a><p class="wp-caption-text">A gap between border and content</p></div>
<p>So far I haven&#8217;t been able to eliminate the pixel wide gap. It doesn&#8217;t look bad in our application right now, but in general it is bad that there is such an uncontrollable gap. So I have the feeling that the Surface people are not a big fan of borders in general and rounded border specifically. <img src='http://blog.minst.net/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
]]></content:encoded>
			<wfw:commentRss>http://blog.minst.net/2009/02/18/surface-glitches/feed</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>WFS 1.1.0, GML 3.1.1 and OpenLayers</title>
		<link>http://blog.minst.net/2009/01/22/wfs-110-gml-311-and-openlayers</link>
		<comments>http://blog.minst.net/2009/01/22/wfs-110-gml-311-and-openlayers#comments</comments>
		<pubDate>Thu, 22 Jan 2009 17:55:51 +0000</pubDate>
		<dc:creator>stvn</dc:creator>
				<category><![CDATA[GIS]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Uncategorized]]></category>
		<category><![CDATA[web]]></category>
		<category><![CDATA[work]]></category>
		<category><![CDATA[OpenLayers]]></category>
		<category><![CDATA[Standards]]></category>

		<guid isPermaLink="false">http://blog.minst.net/?p=162</guid>
		<description><![CDATA[In the INSPIRE framework we are working on the ESDIN project and are using the EuroGeoNames (EGN) project as an implementation of ESDIN. INSPIRE is a big thing within the GIS world in Europe and loads of documents have been written so far. We&#8217;re involved in both ESDIN and EGN and we decided to use [...]]]></description>
			<content:encoded><![CDATA[<p>In the <a href="http://www.inspire-geoportal.eu/">INSPIRE </a>framework we are working on the <a href="http://www.esdin.eu/">ESDIN </a>project and are using the <a href="http://www.inspire-geoportal.eu/">EuroGeoNames </a>(EGN) project as an implementation of ESDIN. INSPIRE is a big thing within the GIS world in Europe and loads of documents have been written so far.</p>
<p>We&#8217;re involved in both ESDIN and EGN and we decided to use the latter as a trial for the first. Together with our partners we&#8217;ve setup a series of servers to fulfill the needs of the projects. The main standard used is the latest WFS and GML versions, which have the annoying disadvantage that there are few clients available.</p>
<p><span id="more-162"></span></p>
<p>To be able to show nicely (as in not an XML file) that everything worked I was asked to build a webclient which would show a map and the data from the EGN service for that area. I figured that this was once again a good reason to look into the latest developments for OpenLayers. I quickly discovered that the released version (2.7) doesn&#8217;t support WFS 1.1.0 so I asked on the mailinglist if people already tried to implement it (and if not, pointers how to do so). Luckily people already did the work and created various patches for the support. (thanks tschaub, bartvde and others)</p>
<p>The most important patch is the one which implements protocols for WFS: ticket <a href="http://trac.openlayers.org/ticket/1648">1648 </a>and its <a href="http://trac.openlayers.org/attachment/ticket/1648/wfs.patch">wfs.patch</a> The main disadvantage of this patch was in my case that it tried to minimise the number of requests to the WFS server (which in general is a good thing). It requests all the features which are within twice the size of the viewport and it doesn&#8217;t request new features when you zoom in. However our server is limited to 10 features per request this results in very interesting behavior. For a starter all the 10 feature could be outside your viewport and also very funny is that shown feature might dissappear when you move the page too much (it requests new features in that case and the first 10 might be outside the viewport). A second <a href="http://trac.openlayers.org/attachment/ticket/1830/resFactor.patch">patch</a>, on ticket <a href="http://trac.openlayers.org/ticket/1830">1830</a>, provided a more aggressive feature update: each zoom action triggers a new request and I set the request-boundingbox-ratio to 1, meaning only those feature within the viewport are requested. This means that every action triggers a new request, which is heavy on the server.</p>
<p>However this is just a reference implementation and hopefully for actual implementations they remove the 10 feature limit. For those interested the reference implementation can be found at <a href="http://research.geodan.nl/egn">http://research.geodan.nl/egn</a></p>
]]></content:encoded>
			<wfw:commentRss>http://blog.minst.net/2009/01/22/wfs-110-gml-311-and-openlayers/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
