S-FAST_LIO is a simplified implementation of FAST_LIO (Xu, Wei, et al. "Fast-lio2: Fast direct lidar-inertial odometry."), which is modified from FAST_LIO. This code is clean and accessible. It is a reference material for SLAM beginners.The main modifications are as follows:
- The Sophus is used to define the state variables, instead of the complicated IKFOM
- The gravity component is directly defined by a Vector3d, thus the complicated calculation of two-dimensional manifold can be omitted
- The code structure has been optimized, and the unnecessary codes have been deleted
- Detailed Chinese notes are added to the code
- Add relocation function in established maps
- Support for Robosense LiDAR has been added
In addition, the following links are also my previous works. I strongly recommend reading them, since they are the interpretation and detailed equation derivation of the FAST-LIO paper:
Requires Docker and the NVIDIA Container Toolkit installed.
1. Enter the /docker
folder and make a docker image.
git clone https://github.com/Taeyoung96/S-FAST_LIO_docker.git
cd S-FAST_LIO_docker/docker
docker build -t s-fast-lio .
2. Make docker container (same path as above)
In /docker
,
sudo chmod -R 777 container_run.sh
./container_run.sh <container_name> <image_name:tag>
./container_run.sh s-fast-lio-container s-fast-lio:latest
If you have successfully created the docker container, the terminal output will be similar to the below.
================S-FAST-LIO Docker Env Ready================
root@taeyoung-cilab:/root/catkin_ws#
Ubuntu >= 16.04.
PCL >= 1.8, Eigen >= 3.3.4.
Follow livox_ros_driver Installation.
Source:Add the line source $Licox_ros_driver_dir$/devel/setup.bash
to the end of file ~/.bashrc
, where $Licox_ros_driver_dir$
is the directory of the livox ros driver workspace (should be the ws_livox
directory if you completely followed the livox official document).
We use the old version of Sophus
git clone https://github.com/strasdat/Sophus.git
cd Sophus
git checkout a621ff
mkdir build
cd build
cmake ../ -DUSE_BASIC_LOGGING=ON
make
sudo make install
Clone the repository and catkin_make:
cd ~/catkin_ws/src
git clone https://github.com/zlwang7/S-FAST_LIO.git
cd ../
catkin_make
source ~/catkin_ws/devel/setup.bash
Here we provide some additional Avia Rosbags. They are collected by Arafat-ninja.
Files: Can be downloaded from google drive. You can also directly use the Avia Rosbags provided by FAST_LIO (google drive).
Run:
roslaunch sfast_lio mapping_avia.launch
rosbag play YOUR_DOWNLOADED.bag
Datasets are collected by a RS-Helios LiDAR and an Xsens IMU.
Files: Can be downloaded from google drive.
Run:
roslaunch sfast_lio mapping_rs.launch
rosbag play YOUR_DOWNLOADED.bag
It can relocalization in an established map. First, establish the map and note that pcd_save_en is set to true in the yaml file. Then, set the initial position and quaternion in yaml for relocalization, and run:
roslaunch sfast_lio mapping_rs_relocalization.launch
rosbag play YOUR_DOWNLOADED.bag
The same as FAST_LIO.
Here we use the dataset (The Main Building in the University of Hong Kong) in FAST-LIO paper. The sensor suite is handheld during the data collection and returned to the starting position after traveling around 140m. The average number of effective feature points is 2015. All algorithms are tested on an Intel i7 2.3 GHz processor-based computer.
Performance Comparison | Average processing time | Drift |
---|---|---|
FAST-LIO | 7.52ms | 0.035% |
S-FAST_LIO | 7.07ms | 0.037% |
Thanks for the authors of FAST-LIO.