[GRASS-SVN] r53213 - grass-addons/grass6/raster/r.connectivity.corridors

svn_grass at osgeo.org svn_grass at osgeo.org
Tue Sep 18 11:57:06 PDT 2012


Author: sbl
Date: 2012-09-18 11:57:05 -0700 (Tue, 18 Sep 2012)
New Revision: 53213

Modified:
   grass-addons/grass6/raster/r.connectivity.corridors/description.html
Log:
Example added to manual of r.connectivity.corridors

Modified: grass-addons/grass6/raster/r.connectivity.corridors/description.html
===================================================================
--- grass-addons/grass6/raster/r.connectivity.corridors/description.html	2012-09-18 18:45:22 UTC (rev 53212)
+++ grass-addons/grass6/raster/r.connectivity.corridors/description.html	2012-09-18 18:57:05 UTC (rev 53213)
@@ -14,6 +14,125 @@
 
 </dl>
 
+<h2>EXAMPLE</h2>
+
+<em>The following example is based on the North Carolina dataset!</em><br>
+<br>
+<em>Please be aware that all input parameter of the following example are purely hypothetical (though they intend to imitate a real life situation) and chosen only for the matter of the exercise. Parameters have to be adjusted in other cases according to ecological knowledge in order to give meaningful results!</em><br>
+<br>
+Let us assume we want to analyse the habitat connectivity for a hypothetical species of the Hardwood Swamps in North Carolina. This species lives only in the larger core area of the swamps (> 1ha) while the borders are no suitable habitats.<br>
+It is not the most mobile of species and can cover (under optimal conditions) maximal 1.5 km.
+
+<h3>Prepare input data</h3>
+Befor we can run the connectivity analysis with the r.connectivity.*-tools we need to prepare the the example input data. Because we want to use cost distance as a distance measure we have to provide a cost raster map in addition to the required vector map of (habitat) patches:<br>
+<br>
+<b>Create input patch vector map</b><br>
+
+<div class="code"><pre>
+###Set region
+g.region -p rast=landuse96_28m at PERMANENT align=landuse96_28m at PERMANENT
+
+###Patch input vector map
+##Extract habitat patches
+#Condition 1: Category 11 = Bottomland Hardwoods/Hardwood Swamps
+#Condition 2: no border-cells are suitable  
+r.mapcalc "patches=if(\
+landuse96_28m[0,1]==11&&\
+landuse96_28m[0,-1]==11&&\
+landuse96_28m[1,1]==11&&\
+landuse96_28m[1,0]==11&&\
+landuse96_28m[1,-1]==11&&\
+landuse96_28m[-1,1]==11&&\
+landuse96_28m[-1,0]==11&&\
+landuse96_28m[-1,-1]==11&&\
+landuse96_28m==11,1,null())"
+
+#Vectorize patches
+r.to.vect input=patches output=patches feature=area --overwrite
+
+#Add a column for the population proxy (in this case area in hectares)
+v.db.addcol map=patches layer=1 'columns=area_ha double precision' 
+
+#Upload area to attribute table (later used as population proxy)
+v.to.db map=patches type=point,line,boundary,centroid layer=1 qlayer=1 option=area units=hectares columns=area_ha
+
+#Extract core habitat areas with more than 1 ha
+v.extract input=patches at user1 output=patches_1ha type=point,line,boundary,centroid,area,face layer=1 where=area_ha>1 new=-1 --overwrite
+</pre></div>
+
+<b>Create a cost raster (se also: <em>r.cost</em>)</b><br>
+
+For the cost raster, we assume that areas which are developed with high intensity are absolute barriers for our species (not crossable at all).
+Other developed and managed areas can be crossed, but only at high costs (they are avoided where possible). Other Hardwood landcover types offer best opportnity for the dispersal of our species (they are prefered), while the costs for crossing the other landcover types is somewhere inbetween.<br>
+Hint: One might also add infrastructure like e.g. roads<br>
+
+<div class="code"><pre>
+#Reclassify land use map
+echo '0 = 56 #not classified (2*resolution (28m))
+1 = NULL #High Intensity Developed (absolut barrier)
+2 = 140 #Low Intensity Developed (5*resolution (28m))
+3 = 112 #Cultivated (4*resolution (28m))
+4 = 70 #Managed Herbaceous Cover (2,5*resolution (28m))
+6 = 28 #Riverine/Estuarine Herbaceous (1*resolution (28m))
+7 = 42 #Evergreen Shrubland (1,5*resolution (28m))
+8 = 42 #Deciduous Shrubland (1,5*resolution (28m))
+9 = 42 #Mixed Shrubland (1,5*resolution (28m))
+10 = 28 #Mixed Hardwoods (1*resolution (28m))
+11 = 28 #Bottomland Hardwoods/Hardwood Swamps (1*resolution (28m))
+15 = 56 #Southern Yellow Pine (2*resolution (28m))
+18 = 28 #Mixed Hardwoods/Conifers (1*resolution (28m))
+20 = 42 #Water Bodies (1,5*resolution (28m))
+21 = 84 #Unconsolidated Sediment (3*resolution (28m))' | r.reclass input=landuse96_28m at PERMANENT output=costs --overwrite 
+</pre></div>
+
+<h3>Create the network (r.connectivity.distance)</h3>
+In the first step the network dataset is created, and the cost distance between all possible pairs of vertices (patches) is calculated.<br>
+Our species is known to be uable to cover more than 1.5 km distance. In order to identify potential for improving the connectectivity of the landscape for our speies we set the cutoff distance (maximum search distance for connections) to three times dispersal potential of our species (4500). In lack of real population data we use the area (ha) as a proxy. The distance between two patches is measured as the maximum distance along the closest 500m of boundary of a patch (ca. 18 border cells with 28m resolution). All non map output is stored in a folder named hws_connectivity in the current working directory.<br>
+
+<div class="code"><pre>
+r.connectivity.distance --verbose patches=patches_1ha costs=costs pop_proxy=area_ha prefix=hws_connectivity folder=./hws_connectivity cutoff=4500 border_dist=18
+</pre></div>
+
+<h3>Analyse the network (r.connectivity.network)</h3>
+
+In the next step network analysis is performed. We define the connectivity cutoff (maximum cost distance where connectivity is assumed) to be 1500.0 cost distance units, which represents the maximum known dispersal ability of our species. The dispersal kernel is adjusted to characteristics of this species by setting the exponent to -3, which gives a steeper decrease in successful dispersal with increasing cost distance. Only very few dispersal units of our species are expected to cross more than ca. 900 cost distance units successfully (se: ./hws_connectivity/kernel.eps after running the command or run it with the x-flag (-x) for only displaying the kernel). Connectivity metrics reslults are stored in te attribute table of the vector maps on vertex (patches, map name: "prefix" _ vertex_measures) and edge level (connections, map name: "prefix" _ edge_measures). An overview over connectivity metrics on the graph level (the entire network) is stored in "folder" (./hws_connectiv
 ity). We requested also an R-plot of the dispersal kernel and an R-plot givig an overview over network characteristics to be stored in the same folder.<br>
+<br>
+Users with a multi-processor computer (e.g. dual-core) may speed up processing by setting cores > 1 in r.connectivity.network.<br>
+
+<div class="code"><pre>
+r.connectivity.network -y -i folder=./hws_connectivity connectivity_cutoff=1500.0 lnbh_cutoff=2.0 cl_thres=10 exponent=-3 kernel_plot=./hws_connectivity/kernel.eps overview_plot=./hws_connectivity/overview.eps cores=1
+</pre></div>
+
+<h3>Calculate corridors (r.connectivity.corridors)</h3>
+
+In this example two alternative (or to some extent complementary) sets of corridors are calculated:<br>
+<br>
+Corridor set 1:<br>
+For the first set, corridors are only computed for the minimum spanning tree (in literture sometimes called the backbone of an ecological network). This is specified in the "where"-parameter. Edge betweenness values are used as weights, which represent the centrality of a connection (edge) in a network (and is therewith a measure of importance). The output is a set of corridor raster maps (named: "prefix" _corridor_ "edge_id" _ "weight") and a summary over all computed corridors (named: "prefix" _corridor_ "edge_id" _ "weight" _sum_ "suffix").<br>
+
+<div class="code"><pre>
+r.connectivity.corridors --verbose folder=./hws_connectivity suffix=mst weights=cf_eb_ud where="cf_mst_ud > 1" cores=1
+</pre></div>
+
+Corridor set 2:<br>
+For the second set, corridors are computed for all edges in the graph (network). This takes a little more time. Corridors are then weighted by the modeled, undirected (= in oth directions) flow of propagules ("cf_u").<br>
+
+<div class="code"><pre>
+r.connectivity.corridors --verbose folder=./hws_connectivity suffix=alle weights=cf_u cores=1
+</pre></div>
+
+Users with a multi-processor computer (e.g. dual-core) may speed up corridor processing by setting cores > 1 r.connectivity.corridors.<br>
+An other means for speeding up processing would be to use integer weights (e.g. by converting edge betweenness to integer afte multiplying with 10 to the power of the relevant number of digits). Then <em>r.reclass</em> is used in the script instead of <em>r.recode</em>.<br>
+<br>
+When all analysis is finnished some cleanup may be appropriate, in order to save disk space:<br>
+
+<div class="code"><pre>
+#Add the f-lag (-f) to the following two commands if you are sure you want to delete all intermediate maps from r.connectivity.*.
+g.mremove rast=hws_connectivity_corridor_*
+g.mremove rast=hws_connectivity_patch_*
+</pre></div>
+
+
 <h2>SEE ALSO</h2>
 <em>
 <a href="r.connectivity.distance.html">r.connectivity.distance</a>, 



More information about the grass-commit mailing list