Skip to content

Mesh Mapping

There are many different strategies to mesh your environment. Some of them consist of multiple steps, which gives a greater control about intermediate results. Others generate meshes directly, which makes it faster, but also harder to figure out potential flaws.

Most of those strategies consist of a simultaneous localization and mapping (SLAM) software somewhere in the chain. For simplicity, we distinguish SLAM software by the data structure they operate on and generate as output.

For example, point cloud (PCD) SLAM is a SLAM software that operates on point clouds and generates a large PCD of the environment. There are exceptions, for example voxel-based SLAM often operate on voxel-representations, also producing large voxel-maps as end result, but also producing a mesh as side-product, such as Warpsense. Then we still consider it as voxel-based SLAM and handle the mesh output as if it was before converted from a voxel-based representation to a mesh. So Warpsense, for example, is a voxel-based SLAM and also a mesh conversion tool.

Then, the following procedures are possible to obtain a mesh from your environment, using different SLAM approaches:

Meshing

List of Helpful Open-Source Software

PCD SLAM

This list will grow.

Name Link MeshNav-proved?
Point-LIO https://github.com/hku-mars/Point-LIO unknown
MOLA https://github.com/MOLAorg/mola unknown
Slam6D https://slam6d.sourceforge.io/ Tested with high resulution Riegl scans
GLIM https://github.com/koide3/glim unknown
Open3D https://www.open3d.org/ yes, scripts

The resulting PCD can be used to generate a mesh. See conversion tools.

Voxel-based SLAM

Name Link MeshNav-proved?
voxblox https://github.com/ethz-asl/voxblox unknown
nvblox https://github.com/nvidia-isaac/nvblox unknown
Uni-Fusion https://github.com/Jarrome/Uni-Fusion unknown

Mesh SLAM

Name Link MeshNav-proved?
Kinect Fusion https://www.microsoft.com/en-us/research/wp-content/uploads/2016/02/ismar2011.pdf unknown
PUMA https://github.com/PRBonn/puma unknown. unconnected mesh?
SLAMesh https://github.com/lab-sun/SLAMesh unknown
Warpsense https://github.com/juliangaal/warpsense unknown
Kimera https://github.com/MIT-SPARK/Kimera-VIO unknown

Other SLAM

Name Link MeshNav-proved?
PIN SLAM https://github.com/PRBonn/PIN_SLAM unknown. In first test, mesh was corrupted so I couldn't traverse with the lvr2 half-edge mesh.
Loopy-SLAM https://github.com/eriksandstroem/Loopy-SLAM unknown

Conversion Tools

It is also possible to convert certain data structures to others. Here a list:

Name Link Comments MeshNav-proved?
lvr2 https://github.com/uos/lvr2 lvr2_reconstruct executable yes
Open3D https://www.open3d.org/ Example Open3D scripts: Link yes
meshlab https://www.meshlab.net/ yes

LVR2

The lvr2 project has a tool to reconstruct meshes from unordered point clouds:

./bin/lvr2_reconstruct input_pcd.ply

It uses the Marching Cubes algorithm to reconstruct a mesh from the input_pcd.ply and writes the resulting mesh to triangle_mesh.ply.

The results look like this:

Point Cloud Triangle Mesh
PCD Mesh

The lvr2_reconstruct executable has many useful parameters that can be adjusted for different point cloud sizes, resultions, or environments. The parameters can be printed as follows:

./bin/lvr2_reconstruct --help

Some important parameters are:

Parameter Description
-v 0.2 Voxelsize for the Marching Cubes algorithm. Has to be set to the smallest possible triangle resolution you want to have.
--kn 5 Number of nearest neighbors used for PCD normal computation. This depends on the PCD density and other environmental factors.
--ki 10 Number of nearest neighbors used to interpolate the normals
--kd 10 Number of nearest neighbors of each voxel corner to compute the signed distance values.

There are more parameters that influence the way lvr2 is reconstructing surfaces from point clouds. My advise is to just test them and see what changes.

Optimization

After we generated a mesh using SLAM approaches, it often has a high resolution; normally, exactly as high as the internal voxel representation. However, we can reduce the number of faces at planar regions, while still describing the environment accurately. This can be done using tools from various mesh editing software, such as Blender or meshlab.

Or you can use the lvr2_mesh_reduce tool from the lvr2 project as follows:

./bin/lvr2_mesh_reduce input_mesh.ply -r 0.6

It reduces the number of faces by a ratio of 0.6 and writes the results to reduced_mesh.ply, which would look as follows:

Triangle Mesh Optimized Mesh
Mesh MeshOpti

Warning: For malformed meshes, this tool will result in an PanicException. It's on our list of things that needed to be fixed. If you find a solution to that problem, please contact us.