Skip to content

uzh-rpg/rpg_svo_pro_with_digital_twins

Repository files navigation

Drift-free Visual SLAM using Digital Twins

Tightly-coupled Fusion of Global Position Measurements in SVO Pro

This repo contains a sliding-window optimization-based odometry system fusing visual, inertial and global pose measurements obtained by registering to a Digital Twin. It builds on top of the visual-inertial odometry algorithm SVO Pro.

Publication

If you use this code in an academic context, please cite the following RAL 2025 paper.

R. Merat (equal contribution), G. Cioffi (equal contribution), L. Bauersfeld, and D. Scaramuzza, "Drift-free Visual SLAM using Digital Twins," Robotics and Automation Letters (RA-L). 2025.

@article{merat2025drift,
  title={Drift-free Visual SLAM using Digital Twins},
  author={Merat, Roxane and Cioffi, Giovanni and Bauersfeld, Leonard and Scaramuzza, Davide},
  journal={IEEE Robotics and Automation Letters},
  year={2025},
  publisher={IEEE}
}

Install

The code has been tested on

  • Ubuntu 18.04 with ROS Melodic
  • Ubuntu 20.04 with ROS Noetic

Install dependences

Install catkin tools and vcstools if you haven't done so before. Depending on your operating system, run

# For Ubuntu 18.04 + Melodic
sudo apt-get install python-catkin-tools python-vcstool

or

# For Ubuntu 20.04 + Noetic
sudo apt-get install python3-catkin-tools python3-vcstool python3-osrf-pycommon

Install system dependencies and dependencies for Ceres Solver

# system dep.
sudo apt-get install libglew-dev libopencv-dev libyaml-cpp-dev 
# Ceres dep.
sudo apt-get install libblas-dev liblapack-dev libsuitesparse-dev

Clone and compile

Create a workspace and clone the code (ROS-DISTRO=melodic/noetic):

mkdir catkin_ws && cd catkin_ws
catkin config --init --mkdirs --extend /opt/ros/<ROS-DISTRO> --cmake-args -DCMAKE_BUILD_TYPE=Release
cd src
git clone [email protected]:uzh-rpg/rpg_svo_pro_with_digital_twins.git
vcs-import < ./rpg_svo_pro_with_digital_twins/dependencies.yaml
touch minkindr/minkindr_python/CATKIN_IGNORE
catkin build

Trobleshooting

Refer to SVO Pro.

Instructions

To launch the programm on our custom dataset download the rosbag and the city twin files from here.

Place them correctly as specified in the configuration file, and run :

roslaunch svo_ros Oerlikon.launch

Make sure you have all the config files as requested in the launch file, and play your rosbag in another terminal. When using your own data, adjust the topic names in the launchfile.

That's it already you are set!

This will launch :

  • svo_ros with the global pose accepted as input to the optimizaqtion problem
  • svo_registration, which will register the local point cloud to the global city twin.
  • rviz

Credits

The VIO system used in this repo is based on SVO Pro. Check SVO Pro for the full list of aknowledgments.

License

The code is licensed under GPLv3. For commercial use, please contact the authors at [email protected] and [email protected].

Check SVO Pro for licenses of the external dependencies.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published