Below, you find detailed instructions on how to use the Cycle Node Network Planner.
Contents of this file (click to jump to corresponding step):
- Step 1: Set up QGIS
- Step 2: Download the contents of this repository (
knudepunkter
folder) - Step 3: Fill out the configuration file
- Step 4: Open the empty QGIS project
Fyn.qgz
in theknudepunkter-main
folder - Step 5: Open the Python console in QGIS, and run the scripts from the
scripts
folder in indicated order - Step 6: Explore the QGIS visualization: use the evaluation layers (polygons, points, elevation) to assess in which places the network should be improved
- Step 7: Explore the summary statistics: get an overview of overall network quality and general characteristics of the network
- The Cycle Node Network Planner was developed to run with QGIS-LTR 3.28 Firenze, but might also work with later versions. If you already have QGIS installed, you can check your version by clicking on
About QGIS-LTR
, as shown below. To download the latest stable release of QGIS or to upgrade it to the 3.28 version, click here.
- Find out the path to the Python installation for the QGIS app on your local machine. That is, find the full path to the
python3.9
application file located in your QGIS installation folder. Typically, this will be similar to
/Applications/QGIS-LTR.app/Contents/MacOS/bin/python3.9
-
Open your command line interface (Terminal on macOS)
-
Use the path from step 2 (abbreviated as
<qgispythonpath>
below) to run the commands below in your commmand line interface. (Copy each line below separately, paste it in your command line interface, replace<qgispythonpath>
by the path from step 2, and hit enter.) Note that you have to be connected to the internet for the installs to work.
<qgispythonpath> -m pip install --upgrade shapely
<qgispythonpath> -m pip install --upgrade geopandas --force-reinstall -v geopandas==0.14.0
<qgispythonpath> -m pip install momepy
<qgispythonpath> -m pip install osmnx==1.6.0
<qgispythonpath> -m pip install numpy --force-reinstall -v numpy==1.22.4
<qgispythonpath> -m pip install contextily
Alternatively, if you know how to run a bash script, navigate to the knudepunkter-main
folder in your command line interface and run ./setuppython.sh <qgispythonpath>
.
- If you had QGIS open, restart QGIS now for the changes to take effect.
On the landing page of this repository, click on the Code
button (in the upper right), then Download ZIP
to download the entire repository to your local machine. Unzip the downloaded folder knudepunkter-main
. This will be the main folder for the entire workflow.
Note: If you already work with the Git command line extension and prefer to clone the repository instead of downloading it, you need to have git-lfs
installed on your machine before cloning.
Open the file config.yml
, located in the main folder knudepunkter-main
, in any text editor (e.g. Notepad on Windows, or TextEdit on MacOS). Provide the study area name of your choice, in quotation marks (the default is "Fyn"). Then, in the list of municipalities, remove the hashtags for all municipalities that you want to include in the analysis. This is set to the following 10 municipalities by default: 0410 Middelfart, 0420 Assens, 0430 Faaborg-Midtfyn, 0440 Kerteminde, 0450 Nyborg, 0461 Odense, 0479 Svendborg, 0480 Nordfyns, 0482 Langeland and 0492 Ærø.
Open the empty QGIS project Fyn.qgz
, located in the knudepunkter-main
folder.
In QGIS,
- Open the Python Console
- Click on
Show Editor
- Click on
Open Script
- Navigate to the
scripts
folder (within theknudepunkter-main
folder) - Select the next script (by number: 01, then 02, ...)
- Click on
Open
- Optionally, at the top of each script, you can adjust display settings (type
True
orFalse
for displaying vs. not displaying the layers generated by this script). - Each script contains a line beneath which no changes should be introduced.
- Click on
Run
. - While the script is running, you will see status messages in the console window.
- Once you see the message
Script XXX ended succcessfully
, save the project (cmd+s), and run the next script.
Repeat steps 3-11 for all scripts (from 01_define_study_area.py
to 07_plot_summary_statistics.py
) consecutively.
Troubleshooting
- Note that QGIS might become unresponsive for several minutes while a script is running.
- At any stop in the workflow, you can save the QGIS project, close it, and then come back to it later.
- Note that for some of the scripts, a stable internet connection is required.
- If the script
05_compute_slope.py
script fails to run - please try again! (it sometimes requires several attempts) - if a script fails to complete and throws an error message:
- remove layers added by the script, and delete the files created by the script (including temporary/partial files)
- save, close, and reopen the QGIS project
- try to run the script again
- if the problem persists: create a new QGIS project in the
knudepunkter-main
folder and restart the workflow there from script 01
Explore the results of the workflow by (de)selecting layers in the QGIS project.
For example, select "Culture/Network in culture areas" within the "Evaluate network" layer to explore which parts of the network lead through culturally particularly interesting parts of the study area.
Or, select "POIS" within the "Evaluate network" layer to explore which points of interest are within vs. outside reach (dark vs. light color) of the network. Use the "Identify features" tool to get more information on a particular feature on the map.
After running all scripts, you will find a plot of summary statistics in the subfolder results/plots/
(in your knudepunkter-main
folder):