SVIN is a tightly coupled Sonar-Visual-Inertial-Depth formulation of Simultaneous Localization and Mapping (SLAM) algorithm for real-time underwater navigation. The package contains two modules:
The main branch now uses ROS 2. Please use the ros1 branch if you need to work with ROS1. We are in process of figuring out how to use old sonar and data in ROS2 as they are custom topic types. Sonar and depth modes will not work and are disabled by default.
The setup instructions are tested on Ubuntu 24.04 with ROS Jazzy.
Prerequisites
Please follow installation page for detailed instructions on building SVIN.
Running it on our publicly available datasets: https://www.afrl.ai/resources. If you follow "Datasets for Visual-Inertial-Based State Estimation Algorithms" link you will be directed to a google drive directory, under the ' Bus' and 'Cave' you will find ROS bagfile with Sonar topic named as '/imagenex831l/range' and ' /imagenex831l/range_raw'.
To build again use
colcon build --event-handlers console_direct+
The easiest way to convert between ROS1 and ROS2 bag is using rosbags-convert rosbags.
To install
sudo apt install pipx
pipx install rosbags
To convert ROS1 bag to ROS2 use
rosbags-convert --src <ros1 bag> --dst <ros2_bag_folder>
Run the launch file for Cave:
source install/setup.bash
ros2 launch okvis_ros svin_gopro_uw.xml
Run the launch file for Cave:
source install/setup.bash
ros2 launch okvis_ros svin_stereorig_v2.xml
Or, run the launch file for Bus:
source install/setup.bash
roslaunch okvis_ros svin_stereorig_v1.xml
In different terminal, run the bag file
ros2 bag play bagfile_name --clock
The pseudo ground truth trajectories obtained using COLMAP are in colmap_groundtruth folder. These trajectories are only accurate up to scale and evaluation should be done after scaling only.
Note: We plan to release the scale accurate trajectory using rig constraints soon.