Skip to content

A real-time, semantic dense RGB-D SLAM system that can output semantic map

Notifications You must be signed in to change notification settings

HenryFOCUS/maskfusion_cpp

 
 

Repository files navigation

MaskFusion_cpp

A real-time dense RGB-D SLAM system that can recognizes, segments and assigns semantic class labels (80 different classes) on 3D surfel map.

Real-time Pipeline

Classes Colors

Click here to see the demo video!

Click here to see the project report!

Reference

Hardware

In order to run MaskFusion_cpp pipeline smoothly, you need 2 GPU with enough memory to store multiple models simultaneously. I used two Nvidia GTX 1080i for experiments.

How to build it?

I recommend to build MaskFusion_cpp environment by nvidia-docker. You can build the MaskFusion_cpp docker image by the Dockerfile I provided:

cd MaskFusion_cpp/docker
docker build -t maskfusion_cpp .

I also provided script build.sh shows step-by-step how MaskFusion_cpp is built based on Ubuntu 16.04 environment (within CUDA 9.0, cuDNN 7.1.4 and OpenGL 4.6.0) and which dependencies are required.

Download MaskRCNN Models

You can download the pre-trained MaskRCNN model from here. Then put the downloaded model mask_rcnn_coco.dat in MaskFusion_cpp/model directory.

Run MaskFusion_cpp

Offline Pipeline

If you have a ASUS Xtion Pro Live depth camera working, then you can run MaskFusion_cpp after build it.

cd MaskFusion_cpp && mkdir build && cd build && cmake .. && make -j`nproc`
./MaskFusion_cpp

If you want to run MaskFusion_cpp offline, firstly you need use Logger2 to record a RGB-D stream and save it as klg file, then run

./MaskFusion_cpp -l path_to_your_klg_file

If you build MaskFusion_cpp in docker environment as I suggest, before you run it, you should make sure the docker container can run GUI applications. In your host's terminal, run

xhost +

This will adjust the permissions of the X server host, make docker container can display something on your screen.

Then start your docker container by run

docker run --privileged --runtime=nvidia -it /tmp/.X11-unix:/tmp/.X11-unix -e DISPLAY=unix$DISPLAY -e GDK_SCALE -e GDK_DPI_SCALE your_maskfusion_cpp_docker_image_name /bin/bash

You can save the semantic surfel map in MaskFusion_cpp pipeline, the map will be saved as ply files in /home/src/MaskFusion_cpp/map/ directory.

Tools

About

A real-time, semantic dense RGB-D SLAM system that can output semantic map

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 47.0%
  • Jupyter Notebook 41.6%
  • Python 3.7%
  • Cuda 3.5%
  • CMake 2.0%
  • GLSL 0.9%
  • Other 1.3%