Skip to content

Files

Latest commit

75e44a8 · Jan 11, 2025

History

History
106 lines (70 loc) · 5.48 KB

README.md

File metadata and controls

106 lines (70 loc) · 5.48 KB

ROMAN

Opposite view loop closure

Welcome to ROMAN(Robust Object Map Alignment Anywhere). ROMAN is a view-invariant global localization method that maps open-set objects and uses the geometry, shape, and semantics of objects to find the transformation between a current pose and previously created object map. This enables loop closure between robots even when a scene is observed from opposite views.

Included in this repository is code for open-set object mapping and object map registration using our robust data association algorithm. For ROS1/2 integration, please see the roman_ros repo. Further information, including demo videos can be found here.

Citation

If you find ROMAN useful in your work, please cite our paper:

M.B. Peterson, Y.X. Jia, Y. Tian and J.P. How, "ROMAN: Open-Set Object Map Alignment for Robust View-Invariant Global Localization," arXiv preprint arXiv:2410.08262, 2024.

@article{peterson2024roman,
  title={ROMAN: Open-Set Object Map Alignment for Robust View-Invariant Global Localization},
  author={Peterson, Mason B and Jia, Yi Xuan and Tian, Yulun and Thomas, Annika and How, Jonathan P},
  journal={arXiv preprint arXiv:2410.08262},
  year={2024}
}

System Overview

System diagram

ROMAN has three modules: mapping, data association, and pose graph optimization. The front-end mapping pipeline tracks segments across RGB-D images to generate segment maps. The data association module incorporates semantics and shape geometry attributes from submaps along with gravity as a prior into the ROMAN alignment module to align maps and detect loop closures. These loop closures and VIO are then used for pose graph optimization.

The roman package has a Python submodule corresponding to each pipeline module. Code for creating open-set object maps can be found in roman.map. Code for finding loop closures via data association of object maps can be found in roman.align. Finally, code for interfacing ROMAN with Kimera-RPGO for pose graph optimization can be found in roman.offline_rpgo.

Dependencies

Direct dependencies, CLIPPER and Kimera-RPGO are installed with the install script. If you would like to use Kimera-RPGO with ROMAN (required for full demo), please also follow the Kimera-RPGO dependency instructions.

Install

First, activate any virtual environment you would like to use with ROMAN.

Then, clone and install with:

git clone git@github.com:mit-acl/roman.git
./roman/install.sh

Demo

A short demo is available to run ROMAN on small subset of the Kimera Multi Data. The subset includes two robots (sparkal1 and sparkal2) traveling along a path in opposite directions. We demonstrate ROMAN's open-set object mapping and object-based loop closure to estimate the two robots' cumulative 200 m long trajectories with 1.2 m RMSE absolute trajectory error using our vision-only pipeline.

Instructions for running the demo:

  1. Download a small portion of the Kimera Multi Data that is used for the ROMAN SLAM demo. The data subset is available for download here.

  2. Download FastSAM model weights here.

  3. In your .bashrc or in the terminal where you will run the ROMAN demo export the following environment variables:

export ROMAN_DEMO_DATA=<path to the demo data>
export FASTSAM_WEIGHTS_PATH=<path to weights downloaded in step 2>
  1. cd into this repo and run the following to start the demo
mkdir demo_output
python3 demo/demo.py \
    -p demo/params/demo \
    -o demo_output

Here, the -p argument specifies the parameter directory and the -o argument specifies the output directory.

Optionally, the mapping process can be visualized with the -m argument to show the map projected on the camera image as it is created or -3 command to show a 3D visualization of the map. However, these will cause the demo to run slower.

The output includes map visualization, loop closure accuracy results, and pose graph optimization results including root mean squared absolute trajectory error.

Running on Custom Data

ROMAN requires RGB-D images and odometry information. ROMAN should be runnable on any data with this information, using robotdatapy to interface pose data and image data. Currently supported data types include ROS1/2 bags, zip files of images, and csv files for poses, with additional data sources in development. Click here for more information on running on custom data.

Acknowledgements

This research is supported by Ford Motor Company, DSTA, ONR, and ARL DCIST under Cooperative Agreement Number W911NF-17-2-0181.

Additional thanks to Yun Chang for his help in interfacing with Kimera-RPGO.