class: title-slide, center, middle # GIS in Archaeology ## 07 - Interpolation ### Martin Hinz #### Institut für Archäologische Wissenschaften, Universität Bern 13/11/24 .footnote[ .right[ .tiny[ You can download a [pdf of this presentation](gis_in_archaeology07.pdf). ] ] ] --- <!-- opening shapefile --> ## Let's Get Started 1. [Click this link](https://github.com/BernCoDALab/gia/raw/main/lectures/07/data/neolithic_expansion.zip) and download 14C dates for the expansion of the Neolithic 2. Open QGIS 3. Start a new project and Add the layer 4. Add a Background Layer to know where we are... --- ## Interpolation > is a type of estimation, a method of constructing new data points within the range of a discrete set of known data points. - *wikipedia* > Spatial interpolation is the process of using points with known values to estimate values at other unknown points. - *QGIS Manual* Example: Temperature of an area, based on the measurements of certain weather stations .center[ data:image/s3,"s3://crabby-images/22b04/22b048f1686d2c69172f8e306fb9ee5c0b3c0ef6" alt=":width 45%" .caption[Source: https://docs.qgis.org]] --- ## Interpolation > For many characteristics (e.g. temperature, precipitation, population density), the area-wide collection of measured values is not feasible due to financial, personnel, time, etc. constraints. It is therefore necessary to estimate values for unsampled locations from samples. The so-called interpolation is a mathematical solution to the problem of bringing values from point to area. It is based on the assumption that the values at two points are the more similar the closer these points are together. - *https://gis.uster.ch, translation MH* In Archaeology: We often only have this point information. If we assume that the situation at other points in the vicinity is similar to the one for which we have point data (underlying continuous process), interpolations can help to understand these processes. .center[ data:image/s3,"s3://crabby-images/36025/36025cb585845ca75363e0cf5ad8f67ce2163ac7" alt=":width 45%" .caption[Source: Fort 2015]] --- ## How to bring points into area? .pull-left[ 1. Every space around a point gets its value - either as **raster** or **vector** - Gridding, Thiessen-Polygons, Nearest Neighbor 2. Every space between points gets a value that is dependent on both points and its distance to them - Triangulation, in GIS most often a **raster** - Delauny Triangulation rsp. TIN (Triangulated Irregular Network) 3. The value of every space (pixel) is influenced by all surrounding actual points - linearly weighted combination of values from nearby points - Inverse Distance Weighted (IDW) 4. more complicated or informed methods... ] .pull-right[ data:image/s3,"s3://crabby-images/7fc44/7fc44d3f40d9239a112ba4365b655f5529f05714" alt="" .caption[Source: https://www.battelleecology.org] ] --- ## Gridding - Most simple approach - produces raster grids with 'gaps' 1. create a regular grid over the mapping area 2. for every cell where there is one value, this cell gets the value 3. for every cell where there are multiple values, this cell gets the mean value 4. every other cell remains empty data:image/s3,"s3://crabby-images/046bf/046bf9867b0362e4196f8404ca55499c928b331a" alt=":width 48%" data:image/s3,"s3://crabby-images/02001/02001ba6fe4189b7570835dea4da7b255f19c25f" alt=":width 48%" .caption[Source: https://desktop.arcgis.com/] Not very convenient for areal analysis... --- ## Gridding in QGIS 1. Click on 'Raster > Conversion > Rasterize (Vector to Raster)' 2. Select the Input Layer 3. Select 'CALBP' as the field that should be rastered 4. Select 'georeferenced units' as raster units 5. Select 100000 m as pixel size for width and height 6. Select the Extend of the point layer as extend for the resulting raster 7. Click on 'Run' data:image/s3,"s3://crabby-images/e09fa/e09fa010853dbd4c5836a12b04e7978987e96c77" alt=":width 48%" data:image/s3,"s3://crabby-images/6b8e0/6b8e09de8fe698f0dd5c2781301e19bec677574e" alt=":width 48%" --- ## Gridding in QGIS result - you should see a raster covering the points - pixel size defines the resolution - if you change symbology to pseudocolor, it already looks reasonable data:image/s3,"s3://crabby-images/e5ab6/e5ab67b29bce7b55fd047c8cab5641012c1d3bed" alt=":width 48%" data:image/s3,"s3://crabby-images/16a4f/16a4fb0b35c48973973f8e93c49b9f761e9ce2fe" alt=":width 48%" --- ## Thiessen Polygons .pull-left[ > A Voronoi diagram, also called Thiessen polygons or Dirichlet decomposition, is a decomposition of space into regions determined by a given set of points in space, here called centres. - german wikipedia, translated Technique to estimate the area affected mainly by a point within a set of points 1. connect all neighbouring points 2. draw a orthogonal line at the middle of the connections 3. stop, when you meet other lines ] .pull-right[ data:image/s3,"s3://crabby-images/5b57e/5b57edd79ed3950cbd67efd3dd59497797a40315" alt=":width 60%" data:image/s3,"s3://crabby-images/b8d4b/b8d4b34166ed3fe2fc8752ec160841b8784d88cd" alt=":width 60%" ] --- ## Thiessen Polygons in QGIS 1. Click on 'Vector > Geometry tools > Voronoi polygons' 2. (You could define an additional buffer around your working area...) 3. Just click on 'Run' data:image/s3,"s3://crabby-images/d07fe/d07fe5ca5b08b368b73c7ccf9f8019832025861d" alt=":width 48%" data:image/s3,"s3://crabby-images/1e56c/1e56c35dfd9445a65b32fdad8aa2c976c83d0707" alt=":width 48%" --- ## Thiessen Polygons in QGIS result .pull-left[ The result is are polygons around your points that contain all the values from the attribute table of the points. You can check by looking in the attribute table You can use symbology > graduated to use the CALBP field for colorising The result is this piece of art to the right, blue means early, red means late neolithisation Of course, transparency is a nice option here, too. ] .pull-right[ data:image/s3,"s3://crabby-images/2cd75/2cd7557d4398c2c154bdf9ae0e24f248ce367685" alt=":width 48%" data:image/s3,"s3://crabby-images/d7692/d76925d248d268cd64f5a6cb6890358596152424" alt=":width 48%" data:image/s3,"s3://crabby-images/f895e/f895e257654139d021386ceed1691e0c42c6502a" alt=":width 48%" ] --- ## Thiessen Polygons as Raster > Nearest Neighbor Interpolation You can also create a raster version quite easily. Either you raster the Thiessen Polygons... data:image/s3,"s3://crabby-images/64920/64920b079b7f5e8277df10e5b9d81d9f41ec8fff" alt="" Or you use the Nearest Neighbor Interpolation (not to mix up with the analysis) --- ## Nearest Neighbor Interpolation in QGIS 1. Select 'Raster > Analysis > Grid (Nearest Neighbor)' 2. Select the input layer and specify the field CALBP as 'z value from field' 3. click on 'Run' data:image/s3,"s3://crabby-images/2bb30/2bb303243760ce6901d65e7d98fe7a165b4bf963" alt=":width 48%" data:image/s3,"s3://crabby-images/126b6/126b60baa302a4b776f789c79fa52f61d103ced8" alt=":width 48%" --- ## Nearest Neighbor Interpolation in QGIS Result The resulting raster is equivalent to the Thiessen Polygon Solution... only as raster data:image/s3,"s3://crabby-images/1acd8/1acd8d72904be9cb594116dbbfa2b61187205462" alt=":width 48%" data:image/s3,"s3://crabby-images/beced/beced82a4508f8f2209ce8a31f3f7c2ae21b3b2c" alt=":width 48%" --- ## TIN (Triangulated Irregular Network) - Another interpolation technique placing more focus on dynamics between the actual points - the surface is divided in triangles, where the data points are the corners - these triangles are placed in 3d (x,y and the interpolated value as z) and rastered data:image/s3,"s3://crabby-images/3c864/3c8641d7dbf37119f4172ed6706657ca08f03362" alt=":width 38%" data:image/s3,"s3://crabby-images/382f6/382f6bda9ff7e55e1c327fd0fb585e784f5460cf" alt=":width 58%" .caption[Source: https://courseware.e-education.psu.edu; http://sar.kangwon.ac.kr/] --- ## TIN Benefits / Disadvantages - more dynamic interpolation than simple gridding or Nearest Neighbor - interactions/differences between data points are better interpolated - very good for interpolating rather regular elevation measurements ### but - highly irregulare point patterns can result in 'strange' networks data:image/s3,"s3://crabby-images/cb731/cb731a5686291fb7febf1aee21b37de5cb7df650" alt=":width 48%" data:image/s3,"s3://crabby-images/73b21/73b21a1a3777a7a95764c0b96486da1353dc48a6" alt=":width 48%" .caption[Source: http://www.geocomputation.org; Bhargava et al. 2013] --- ## TIN in QGIS .pull-left[ 1. In the toolbox data:image/s3,"s3://crabby-images/2e188/2e1880a1d82a5e8c4ff9379dfb0759466d1cd0ef" alt="", search for 'tin' 2. Select 'TIN Interpolation' 3. Select the input layer 4. Select CALBP as interpolation attribute 5. Click on the '+' icon 6. Select the extend to be calculated from the layer extend 7. Specify the resolution either in width or in height 8. (if you want to see the network itself, select eg. Temporary Layer from the Triangulation) 9. Click on 'Run' ] .pull-right[ data:image/s3,"s3://crabby-images/1801b/1801b75b1f9c82f682944a00b5f30ff09544a6a2" alt=":width 90%" data:image/s3,"s3://crabby-images/a198b/a198b513541d5aa6c891687cf6c09b3dcd7d0c93" alt=":width 90%" ] --- ## TIN result - As a result, you should see grayish triangles - After selecting pseudocolor, the expansion of the neolithic is again nicely visible - if you selected the output of the Triangulation, you can overlay this (right picture) data:image/s3,"s3://crabby-images/cbf04/cbf04cb093c712889d86feba9d4ca2b3fe25a1ac" alt=":width 48%" data:image/s3,"s3://crabby-images/621e3/621e359e1760cf3391bc1effde6ab055629d03e9" alt=":width 48%" --- ## Inverse Distance Weighted (IDW) - archaeological data most of the time represent a biased random selection - the individual date is 'untrustworthy' - probably you are more interested in the underlying pattern than the value of the individual date - Inverse Distance Weighted (IDW) consider all points around a certain cell (pixel) to be interpolated - the further away a point is, the less impact it should have > Tobler's first law of geography: everything is related to everything else, but near things are more related than distant things .center[ data:image/s3,"s3://crabby-images/6e7d2/6e7d2c3ef365fadeb6f61cf382350779838ee037" alt=":width 55%" ] .caption[Source: https://docs.qgis.org] --- ## Inverse Distance Weighted (IDW) .pull-left[ for a pixel to interpolated: - take all the points and their values - 'calculate a mean' in so far, as values close to the pixel have a higher impact than values further away - how much distance is 'penalizing' depends on the 'power' value: - higher power result in points further away have lesser impact ] .pull-right[ data:image/s3,"s3://crabby-images/97227/97227d83653796715aaef6d5ec24c4fbdad6f892" alt="" ] .center[ data:image/s3,"s3://crabby-images/92c87/92c87f07ff006b90de9c20362abbb22c24bb69f9" alt=":width 30%" data:image/s3,"s3://crabby-images/79683/79683de06ae6f3813d1ece4d7d8e9c8ea4f03080" alt=":width 48%" ] .caption[Source: http://www.geography.hunter.cuny.edu. Left image: green line: smaller power value, dashed line: higher power value] --- ## IDW in QGIS .pull-left[ 1. In the toolbox data:image/s3,"s3://crabby-images/2e188/2e1880a1d82a5e8c4ff9379dfb0759466d1cd0ef" alt="", search for 'idw' 2. Select 'IDW Interpolation' 3. Select the input layer 4. Select CALBP as interpolation attribute 5. Click on the '+' icon 6. Select the extend to be calculated from the layer extend 7. Specify the resolution either in width or in height 8. Specify the power P. You can leave it for now at the default value 2. 9. Click on 'Run' ] .pull-right[ data:image/s3,"s3://crabby-images/fd107/fd107861269ad147afbf63bf5a4ca4fc0ac6f946" alt=":width 90%" data:image/s3,"s3://crabby-images/14ab9/14ab9ffc3c1d0c0219a01047626c92557986619b" alt=":width 90%" ] --- ## IDW in QGIS result .pull-left[ - after changing to pseudocolor, the result is much more regionalised - the higher the power, the more the individual points will be relevant (more 'measles') - the lesser the power, the more the general pattern will be visible (smoother) ] .pull-right[ data:image/s3,"s3://crabby-images/92c87/92c87f07ff006b90de9c20362abbb22c24bb69f9" alt="" ] .center[ data:image/s3,"s3://crabby-images/a6e62/a6e627a41928ed46b566bfa02a23044680c598da" alt=":width 48%" data:image/s3,"s3://crabby-images/4b2f8/4b2f8bd5e1e3b12e95d9b3b87dccae21bdec4d25" alt=":width 48%" .caption[Left: Power 2. Right: Power 0.5.] ] --- ## Contours .pull-left[ - Colors give already a good impression about the general pattern - Contours are lines connecting positions of the same value in a raster dataset representing continuous phenomena - Contour lines are useful in surface mapping, as they make it possible to visualise both flat and steep surfaces (distance between contour lines) and ridges and valleys (approaching and diverging lines) - they also can be used to enhance the visualisation of interpolation ] .pull-right[ data:image/s3,"s3://crabby-images/cb60c/cb60c7a530153ede85365433bf422202dc0f3490" alt="" .caption[Source: https://www.giscourse.com.] ] --- ## Contours in QGIS .pull-left[ 1. Select 'Raster > Extraction > Contour' from the menue 2. Select the input layer 3. (In multichannel raster you might need to select the correct channel) 4. Specify the distance between the contour lines 5. (If your range should not start from 0, you could define an offset) 6. Click on 'Run' ] .pull-right[ data:image/s3,"s3://crabby-images/9c7cb/9c7cb1843c735be64960207dc7e37bebc056adc2" alt=":width 90%" data:image/s3,"s3://crabby-images/bad3a/bad3ace6a6a593f5503e7e8bb19068b68b90ea65" alt=":width 90%" ] --- ## Contours in QGIS Result Now you should see the interpolation enhanced with contour lines, that make it easier to spot patterns... .center[ data:image/s3,"s3://crabby-images/06403/0640350f5f5ac189e7e468b6e0c3ed497c2f884d" alt=":width 50%" ] --- ## What We've Covered -- .pull-left[ + What is interpolation, and what is it good for + Gridding + Thiessen Polygons and Nearest Neighbor + TIN (Triangulated Irregular Network) + Inverse Distance Weighted (IDW) + Contour lines ] -- .pull-right[ ### What to choose for what? - Gridding: rarely the best option - Thiessen Polygons: if you assume homogenous, delimited areas - TIN: if the actual values are more relevant - IDW: if the underlying process is more relevant ] .center[ data:image/s3,"s3://crabby-images/0c069/0c0696977f4cf1aa901265851538ebe7c94b533d" alt=":width 60%" .caption[Source: https://www.battelleecology.org] ] --- ## Homework + Get the [archaeological sites of the Kanton bern](https://github.com/BernCoDALab/gia/raw/main/lectures/07/data/fundstellen_mit_hoehen.zip) with elevation (field: altitude1) + try out different interpolation algorithms + Which algorithm gives the best result for interpolation of elevation? + Send me your assessement and the best result via email (martin.hinz@iaw.unibe.ch) as screenshot or exported map --- class: inverse, middle, center # Any questions? data:image/s3,"s3://crabby-images/c7800/c7800261408d2590eb639bb29da387948affba46" alt=":width 20%" .caption[Source: https://www.instagram.com/sadtopographies] .footnote[ .right[ .tiny[ You might find the course material (including the presentations) at https://github.com/BernCoDALab/gia You can see the rendered presentations at https://berncodalab.github.io/gia You can contact me at <a href="mailto:martin.hinz@unibe.ch">martin.hinz@unibe.ch</a> ] ] ]