Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Graph generation #401

Open
wants to merge 13 commits into
base: master
Choose a base branch
from
189 changes: 189 additions & 0 deletions tutorials/docs/graph_generation.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,189 @@
.. _graph_generation:
SteveMacenski marked this conversation as resolved.
Show resolved Hide resolved

Graph Generation
****************

- `Overview`_
- `Requirements`_
- `Tutorial Steps`_

Overview
========
This tutorial walks a user through generating a graph for the nav2 router.
SteveMacenski marked this conversation as resolved.
Show resolved Hide resolved

Requirements
============
Follow https://www.qgis.org/en/site/forusers/download.html to install QGIS.

Tutorial Steps
==============

1- Open QGIS and create a new project. Set the project coordinate reference system to `WGS 84/ Pseudo-Mercator`.
SteveMacenski marked this conversation as resolved.
Show resolved Hide resolved

|

.. image:: images/graph_generation/coordinate_reference_system.png
:height: 400px
SteveMacenski marked this conversation as resolved.
Show resolved Hide resolved
:width: 600px
:align: center

|

2- If you don't need to adjust your raster image to the map frame, click
`Layer -> Add Layer -> Add Raster Layer`. Select your raster image and click `Add`.

3- If you need to adjust your raster image to the map frame, open the georeferencer tool
SteveMacenski marked this conversation as resolved.
Show resolved Hide resolved
by clicking `Raster -> Georefencer`. Set the trasformation settings to `Linear` for `Transformation
type`, `WGS 84/ Pseudo-Mercator` for `Traget SRS` and set your desired path for the `Output Raster`.
SteveMacenski marked this conversation as resolved.
Show resolved Hide resolved

|

.. image:: images/graph_generation/transformation_settings.png
:height: 500px
:width: 300px
:align: center

|

Select the raster image you wish to georeference and place at least three georeferencer control points. Apply the
transformation.

|

.. image:: images/graph_generation/georeferencer.png
:height: 400px
:width: 600px
:align: center

|

Drag and drop the raster file output into the layers window.

|

.. image:: images/graph_generation/raster_layer.png
:height: 400px
:width: 600px
:align: center

|

4- Now that we have the raster layer in the correct coordinate system we can start placing nodes.


Select `Layer -> Create Layer -> New ShapeFile Layer`. Set the shapefile layer setting to be
`nodes` for the `File name`, `points` for the `Geometry type` and `WGS 84/ Pseudo-Mercator` for the coordinate system. Press `OK`.

|

.. image:: images/graph_generation/node_layer.png
SteveMacenski marked this conversation as resolved.
Show resolved Hide resolved
:height: 600px
:width: 400px
:align: center

|

Click on the node layer and use the tool bar to start adding nodes. The IDs field can be left null.
SteveMacenski marked this conversation as resolved.
Show resolved Hide resolved

|

.. image:: images/graph_generation/nodes.png
:height: 600px
:width: 400px
:align: center

|


5- Now an edge layer can be created. Select `Layer -> Create Layer -> New ShapeFile Layer`. Set the shapefile layer setting to be
`edges` for the `File name`, `LineString` for the `Geometry type` and `WGS 84/ Pseudo-Mercator` for the coordinate system. Press `OK`.

|

.. image:: images/graph_generation/edge_layer.png
:height: 400px
:width: 600px
:align: center

|

Click on the edge layer and use the tool bar to start adding edges. Use the magnet tool to snap
SteveMacenski marked this conversation as resolved.
Show resolved Hide resolved
the start and end points of the edge to nodes.

|

.. image:: images/graph_generation/edges.png
:height: 600px
:width: 400px
:align: center

|

6- Now we will add ids for all nodes and edges.
Select the node layer and then click on the `Field calculator` tool. Check the `Update existing
SteveMacenski marked this conversation as resolved.
Show resolved Hide resolved
field` box and select `id` in the dropdown menu. Add `@row_number` to the `expression field`` and click `Ok`.

|

.. image:: images/graph_generation/field_calculator.png
:height: 400px
:width: 600px
:align: center

|

This will generate ids for each node. To verify that the ids have been generated, right click on
SteveMacenski marked this conversation as resolved.
Show resolved Hide resolved
the node layer and select `Open attribute table`. This will display the current attributes associated with the node layer.
SteveMacenski marked this conversation as resolved.
Show resolved Hide resolved

Follow the same process for the edges but swap the `@row_number` for `@row_number + <number_of_nodes>`.
SteveMacenski marked this conversation as resolved.
Show resolved Hide resolved


7- Now that we have our node and edge layers with IDs, we can associate node IDs with edge IDs.

Select `Database -> DB manager`. Expand `Virtual layers` and expand `Project layers`. Open up
SteveMacenski marked this conversation as resolved.
Show resolved Hide resolved
the SQL window. In the SQL window load in the association script by selecting `Load File`.
Execute the script. Load the new layer by checking the `Load as new layer` box and clicking `Load`.
This layer will be refered to as connected edges.

|

.. image:: images/graph_generation/sql_script.png
:height: 400px
:width: 600px
:align: center

|

8- We are now ready to export the node and edge layer as geojson files. Right click on the nodes layer and select
`Export -> Save Feature As`. Set the format to geojson and verify the coordinate reference system is set to `WGS 84/ Pseudo-Mercator`.

|

.. image:: images/graph_generation/export_to_geojson.png
:height: 300px
:width: 400px
:align: center

|

Follow the same process for the connected edges layer.

9- Create a new geojson file called graph. Copy the nodes geojson file into the graph file. Insert the features
from the connected edges geojson file into the features tag in the graph file.
SteveMacenski marked this conversation as resolved.
Show resolved Hide resolved

|

.. image:: images/graph_generation/geojson_graph.png
:height: 600px
:width: 400px
:align: center

|

10- Congratulations! Your graph is ready to be consumed by the nav2 route! If you wish to add nodes or edges to your graph,
edit the layers and repeat the proccess from step 6. If you wish to adjust the graph, make sure `Editing` is toggled on for the
node and edge layer. Then select `Vertex Tool(all Layers)` and toggle on `Topological Editing`. Repeat the proccess from step 7.


Happy Routing!

Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added tutorials/docs/images/graph_generation/edges.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added tutorials/docs/images/graph_generation/nodes.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions tutorials/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -22,3 +22,4 @@ Navigation2 Tutorials
docs/adding_smoother.rst
docs/using_collision_monitor.rst
docs/adding_a_nav2_task_server.rst
docs/graph_generation.rst