Area Calculations
- Select the shape layer with polygons you want to compute the area of and then click the Open Field Calculator icon in the Attributes toolbar.
- In the popup window, enter a new output filed name, change the type to “Decimal number (real).” Adjust the precision (number of trailing decimal points) and field length (total number of digits maximum) as needed.
- Then in the Expression tab input
$area
or in the middle column open the Geometry tab and click$area
. - Click OK. If you are not already in Edit mode, you will be prompted to enable it. Do so.
- Once the calculation is complete, right-click on the layer and select “Open Attribute Table”.
- You should see an additional field containing the area of each shape.
- If you make a change to the shapes and wish to recalculate the areas, reopen the field calculator window” and check “Update existing field”. Then, in the dropdown box select the area field. Input
$area
under Expression, and click OK.
Topographic Lines ↔ DEM
Topographic Lines to DEM
- Import your contour lines into QGIS. Then, open the Processing Toolbox and search for and double-click on the TIN Interpolation Tool.
- In the window, select the contour layer as the “vector layer”, and either enter the field corresponding to elevation as the “interpolation attribute”, or check the box to use the Z-coordinates for that layer. Then, click the green plus and leave Points beneath Type. If you have additional contours or shapes that represent structure or break lines (e.g. cliff or lake boundaries), change the “vector layer” and “interpolation attribute” as required, click the green plus to add it in, and select either “Structure line” or “Break line” under Type.
- Scrolling down, expand the options beneath Extent, and select the option appropriate for where you want to create the DEM. We will use Calculate from Layer to get the DEM to range over the whole layer.
- Under Output raster size, adjust the pixel size so that the number of displayed rows and columns is not exceedingly large. This will ensure that QGIS will not take too long to produce the output, and that the output DEM file will not be too large. However, note that increasing the size too high will mean the resulting raster will have less precision and follow the contours less. You may want to repeatedly adjust the setting and rerun the algorithm until you are happy with the end result.
- Make sure to save the resulting layer by clicking on the three dots underneath Interpolated, then click Run. When the process is finished, a new layer containing the DEM should appear:
DEM to Topographic Lines
- In the menus, click through Raster > Extraction > Contour….
- In the window, select your DEM layer under “Input layer”, and adjust the value under “Interval between contour lines” as needed.
- Click Run. When the process is done, a new layer will be created containing the contours. [Note: This process may take a lot of time, especially if the DEM covers a large area. You can try increasing the interval between contour lines to shorten the time needed.]
- To find the elevation of a specific contour line, select the contour layer in the Layers List, and click on the line with the Identify Features tool selected.
Least Cost Path
- Create a shapefile layer to add the paths you want to calculate the least cost path over. (If you need a refresher, see Tracing in QGIS). Make sure you add a field for the direction of each path if your network has one-way paths, and a field for speed if you would like to calculate the fastest route.
- Set the new layer to edit mode, and then trace the paths needed. Enter new id values for each. In the direction field, label the path “two-way” if it is two-way, “forward” if it is one-way in the direction you drew the path, or “backward” if it is one-way opposite the direction you drew the path. If you have a speed field, enter the speed of traveling over that path in km/h.
- When you are done, save your edits and turn off edit mode.
- Right-click on the shapes layer and click Properties.
- Open the Symbology Tab, click the top dropdown box and select “Rule-based”
- Click on the green plus “Add rule” button .
- In the edit rule window, click the “Expression Editor” icon besides “Filter,” and directly enter the formula
“direction” in (‘forward’, ‘backward’)
- This will filter what we do to affect only the one-way roads.
- Scroll down to under “Symbol.” Click to select the row “Simple Line,” and then click on the dropdown box beside “Symbol layer type” to choose “Marker Line.”
- Scroll down further, uncheck “With Interval” and check “On central point of segments” under “Marker Placement”
- Click and select the bottom-most row labeled “Simple Marker”
- Scroll down to the box of symbols and click on the triangle pointing right.
- Click on the data-defined override icon in the row for Rotation, and then click Edit.
- In the Expression Builder, enter
if(‘backward’, 180, 0)
. This will rotate the arrow direction to be in the correct orientation. Then click OK. - Finally, click OK to close the “Edit Rule” window, and then click Apply in the Layer Properties Window. You should see arrows along one-way paths traveling in the correct directions.
- Open the Processing Toolbox with the Processing Toolbox icon on the toolbar, or through Processing > Toolbox.
- In the Processing Toolbox, navigate under “Vector Overlay” to the Split with Lines tool, or search using the search bar. Double left-click to open the dialog.
- In the window that pops up, press Run. A new layer called “Split” should appear that merges all of your paths together. If you have special symbology for your paths, you can turn that layer invisible by checking the box next to it.
- Then, open the Network Analysis tab in the Processing Toolbox or search to find the “Shortest path (point to point)” tool. Double left-click to open the dialog.
- Enter the “Split” layer as the “Vector layer representing network”, and select “Shortest” or “Fastest” under “Path type to calculate” based on what you want to compute. Then, click on the three dots besides “Start point” and “End point” to select the points on the network you want to compute an optimal path between.
- Open the Advanced parameters, and input the direction field and the values used to indicate forward direction, backward direction, and both directions. (See screenshot above). If you are computing the “Fastest” path, you will need to input the speed field also. Click Run.
- A new layer named “Shortest path” will appear. Open its Attribute table to see the “cost” of the path: distance if you computed the “Shortest” path, or time if your computed the “Fastest” path.
Viewsheds
- Install the Visibility Analysis Plugin (if you need a refresher on installing plugins, see the instructions here).
- Import DEM data for the area you want to perform your analysis around. If you don’t already have that data, you can download it from NASA, from the Consortium for Spatial Information, or other sources. If you have topographic contours, you can try converting it to DEM.
- If you need multiple DEM granules, merge them together through Raster > Miscellaneous > Merge and selecting the layers with the three dots besides “Input layers.” Click Run. Use the outputted layer for the following steps.
- Your CRS will also need to have units of meters. If you are unsure if this is the case, click on the globe at the bottom right, and in the window check that your CRS has “meters” as units.
- If not, you will need to reproject your DEM and data to a CRS that does have meters as units. When you have chosen a CRS, reproject your DEM data by navigating to Raster > Projections > Warp (Reproject). In the window, select the DEM layer, put in the source CRS and target CRS, and then click Run. Use the outputted “Reprojected” layer for the remaining steps.
- Open the Processing Toolbox and select the Create Viewpoints tool from the Visibility Analysis plugin. Under “Observer Location(s)” select a shapefile corresponding to points you want to calculate the viewshed from. Put in the reprojected DEM layer under “Digital Elevation Model.” Fill out the remaining parameters as needed. Click Run.
- In the Processing Toolbox, now select the Viewshed tool. Leave “Analysis type” and “Combining multiple outputs” as is, select the output of the Create Viewpoints tool for “Observer location(s)” and select the reprojected DEM layer for the “Digital elevation model.” Check the box to take into account Earth curvature if you are working over large distances. Then hit Run. You should have an output raster file that gives pixels an integer value corresponding to the number of viewpoints that can “see” that point.
Cluster Analyses
There are two major algorithms in QGIS used for clustering: DBSCAN clustering and K-means clustering.
DBSCAN (Density-based spatial clustering of applications with noise) clusters based on the density of points. Points which are too far away from others are deemed noise and are not clustered.
K-means tries to create a specified number of equal-sized clusters by computing “mean” points and clustering points which are closest to a specific “mean.”
DBSCAN
Make sure that the CRS of your points has units of meters. If not, you may have to reproject (see here).
- In the Processing Toolbox , open the DBSCAN Clustering process.
- Select your point layer as the Input layer. Then, you will need to adjust the minimum cluster size and maximum distance between clustered points, which determine how “dense” points need to be to form a cluster.
- A new layer should appear. Open the Symbology tab of the Properties window and set the coloring to be done based on
CLUSTER_ID
(see here for more detailed instructions) to see the clusters (and noise). You may want to adjust the parameters and rerun the DBSCAN algorithm to get better results.
If you are having trouble finding a good distance value for the algorithm, you may want to use the Measure Line tool in the Attributes Toolbar to get a sense for the distances between your points. The parameter “maximum distance between points” determines a radius around every point that the algorithm checks for other points in to determine density, i.e. you may want to measure distances between individual points.
K-means
- In the Processing Toolbox , open the K-means clustering process.
- In the K-means algorithm window, select your point layer as the input layer, and then input the number of clusters the algorithm should produce. You will probably need to guess and rerun the algorithm multiple times until you are satisfied with the results.
- In the new layer, open the Properties tab and in the Symbology tab, set the coloring to be done based on
CLUSTER_ID
(see here for more detailed instructions).This will show all of the generated clusters: