The Mesh Navigation bundle provides software to perform efficient robot navigation on 2D-manifolds in 3D represented as triangular meshes. It allows to safely navigate in various complex outdoor environments by using a modular extendable layerd mesh map. Layers can be loaded as plugins and represent certain geometric or semantic metrics of the terrain. The layered mesh map is integrated with Move Base Flex (MBF) which provides a universal ROS action interface for path planning and motion control, as well as for recovery behaviours. Thus, additional planner and controller plugins running on the layered mesh map are provided.
Maintainer: Sebastian Pütz
Author: Sebastian Pütz
Please use the official released ros package or install more recent versions from source.
sudo apt install ros-melodic-mesh-navigation
Installation from source
All dependencies can be installed using rosdep
rosdep install mesh_navigation
As explicit dependencies we refer to the following ROS packages, which are also developed by us:
Use the pluto_robot package for example HDF5 map datasets, Gazebo simulations, and example configurations.
This mesh_navigation stack provides a navigation server for Move Base Flex (MBF). It provides a couple of configuration files and launch files to start the navigation server with the configured layer plugins for the layered mesh map, and the configured planners and controller to perform path planning and motion control in 3D (or more specifically on 2D-manifold).
The package structure is as follows:
-
mesh_navigation
The corresponding ROS meta package. -
mbf_mesh_core
contains the plugin interfaces derived from the abstract MBF plugin interfaces to initialize planner and controller plugins with onemesh_map
instance. It provides the following three interfaces:- MeshPlanner -
mbf_mesh_core/mesh_planner.h
- MeshController -
mbf_mesh_core/mesh_controller.h
- MeshRecovery -
mbf_mesh_core/mesh_recovery.h
- MeshPlanner -
-
mbf_mesh_nav
contains the mesh navigation server which build on top of the abstract MBF navigation server. It uses the plugin interfaces inmbf_mesh_core
to load and initialize plugins of the types described above. -
mesh_map
contains an implementation of a mesh map representation building on top of the mesh data structures in lvr2. This package provides a layered mesh map implementation. Layers can be loaded as plugins to allow a highly configurable 3D navigation stack for robots traversing on the ground in outdoor and rough terrain. -
mesh_layers
The package provides a couple of mesh layers to compute the trafficability of the terrain. Furthermore, these plugins have access to the HDF5 map file and can load and store layer information. The mesh layers can be configured for the robots abilities and needs. Currently we provide the following layer plugins:- HeightDiffLayer -
mesh_layers/HeightDiffLayer
- RoughnessLayer -
mesh_layers/RoughnessLayer
- SteepnessLayer -
mesh_layers/SteepnessLayer
- RidgeLayer -
mesh_layer/RidgeLayer
- InflationLayer -
mesh_layers/InflationLayer
- HeightDiffLayer -
-
dijkstra_mesh_planner
contains a mesh planner plugin providing a path planning method based on Dijkstra's algorithm. It plans by using the edges of the mesh map. The propagation start a the goal pose, thus a path from every accessed vertex to the goal pose can be computed. This leads in a sub-optimal potential field, which highly depends on the mesh structure. -
wave_front_planner
contains a Fast Marching Method (FMM) wave front path planner to take the 2D-manifold into account. This planner is able to plan over the surface, due to that it results in shorter paths than thedijkstra_mesh_planner
, since it is not restricted to the edges or topology of the mesh. A comparison is shown below. -
mesh_client
Is an experimental package to load navigation meshes only from a mesh server.
Use the MeshGoal
tool to select a goal pose on the shown mesh in RViz.
The following table gives an overview of all currently implemented layer plugins available in the stack and the corresponding types tp specify for usage in the mesh map configuration. An example mesh map configuration is shown below.
Currently the following planners are available:
- name: 'dijkstra_mesh_planner'
type: 'dijkstra_mesh_planner/DijkstraMeshPlanner'
- name: 'wave_front_planner'
type: 'wave_front_planner/WaveFrontPlanner'
- name: 'mmp_planner'
type: 'mmp_planner/MMPPlanner'
The planners are compared to each other.
Vector Field Planner | Dijkstra Mesh Planner | ROS Global Planner on 2.5D DEM |
---|---|---|
If you want to test the mesh navigation stack with Pluto please use the simulation setup and the corresponding launch files below for the respective outdoor or rough terrain environment. The mesh tools have to be installed. We developed the Mesh Tools as a package consisting of message definitions, RViz plugins and tools, as well as a persistence layer to store such maps. These tools make the benefits of annotated triangle maps available in ROS and allow to publish, edit and inspect such maps within the existing ROS software stack.
In the following demo videos we used the developed VFP, i.e., the wavefront_propagatn_planner. It will be renamed soon to vector_field_planner.
Dataset and Description | Demo Video |
---|---|
Botanical Garden of Osnabrück University | |
Stone Quarry in the Forest Brockum |
Colored Point Cloud | Height Diff Layer | RGB Vertex Colors |
---|---|---|
ROS Distro | GitHub CI | Develop | Documentation | Source Deb | Binary Deb |
---|---|---|---|---|---|
Melodic | |||||
Noetic |