No version for distro humble. Known supported distros are highlighted in the buttons above.
No version for distro jazzy. Known supported distros are highlighted in the buttons above.
No version for distro rolling. Known supported distros are highlighted in the buttons above.

Package Summary

Tags No category tags.
Version 0.0.0
License BSD
Build type CATKIN
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/irobot-algorithm/sentry_navigation.git
VCS Type git
VCS Version main
Last Updated 2025-03-19
Dev Status UNMAINTAINED
CI status No Continuous Integration
Released UNRELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

This is a modified version of LOAM which is original algorithm is described in the following paper: J. Zhang and S. Singh. LOAM: Lidar Odometry and Mapping in Real-time. Robotics: Science and Systems Conference (RSS). Berkeley, CA, July 2014.

Additional Links

No additional links.

Maintainers

  • claydergc

Authors

  • Dongjiao He

Point-LIO

1. Introduction

<img src="https://github.com/hku-mars/Point-LIO/raw/master/image/toc4.png" width = 75% >
<font color=#a0a0a0 size=2>The framework and key points of the Point-LIO.</font>

New features:

  1. would not fly under degeneration.
  2. high odometry output frequency, 4k-8kHz.
  3. robust to IMU saturation and severe vibration, and other aggressive motions (75 rad/s in our test).
  4. no motion distortion.
  5. computationally efficient, robust, versatile on public datasets with general motions.
  6. As an odometry, Point-LIO could be used in various autonomous tasks, such as trajectory planning, control, and perception, especially in cases involving very fast ego-motions (e.g., in the presence of severe vibration and high angular or linear velocity) or requiring high-rate odometry output and mapping (e.g., for high-rate feedback control and perception).

Important notes:

A. Please make sure the IMU and LiDAR are Synchronized, that’s important.

B. Please obtain the saturation values of your used IMU (i.e., accelerator and gyroscope), and the units of the accelerator of your used IMU, then modify the .yaml file according to those settings, including values of ‘satu_acc’, ‘satu_gyro’, ‘acc_norm’. That’s improtant.

C. The warning message “Failed to find match for field ‘time’.” means the timestamps of each LiDAR points are missed in the rosbag file. That is important because Point-LIO processes at the sampling time of each LiDAR point.

D. We recommend to set the extrinsic_est_en to false if the extrinsic is given. As for the extrinsic initiallization, please refer to our recent work: Robust and Online LiDAR-inertial Initialization.

E. If a high odometry output frequency without downsample is required, set

``` as true. Then the warning message of tf "TF_REPEATED_DATA" will pop up in the terminal window, because the time interval between two publish odometery is too small. The following command could be used to suppress this warning to a smaller frequency:

in your catkin_ws/src,

git clone --branch throttle-tf-repeated-data-error git@github.com:BadgerTechnologies/geometry2.git

Then rebuild, source setup.bash, run and then it should be reduced down to once every 10 seconds. If 10 seconds is still too much log output then change the ros::Duration(10.0) to 10000 seconds or whatever you like.

F. If you want to use Point-LIO without imu, set the "imu_en" as false, and provide a predefined value of gavity in "gravity_init" as true as possible in the yaml file, and keep the "use_imu_as_input" as 0.

## **1.1. Developers:**
The codes of this repo are contributed by:
[Dongjiao He (贺东娇)](https://github.com/Joanna-HE) and [Wei Xu (徐威)](https://github.com/XW-HKU)


## **1.2. Related paper**
Our paper is published on Advanced Intelligent Systems(AIS). [Point-LIO](https://onlinelibrary.wiley.com/doi/epdf/10.1002/aisy.202200459), DOI: 10.1002/aisy.202200459


## **1.3. Related video**
Our accompany video is available on **YouTube**.
<div align="center">
    <a href="https://youtu.be/oS83xUs42Uw" target="_blank"><img src="https://github.com/hku-mars/Point-LIO/raw/master/image/final.png" width=60% /></a>
</div>

## 2. What can Point-LIO do?
### 2.1 Simultaneous LiDAR localization and mapping (SLAM) without motion distortion

### 2.2 Produce high odometry output frequence and high bandwidth

### 2.3 SLAM with aggressive motions even the IMU is saturated

# **3. Prerequisites**

## **3.1 Ubuntu and [ROS](https://www.ros.org/)**
We tested our code on Ubuntu20.04 with noetic. Ubuntu18.04 and lower versions have problems of environments to support the Point-LIO, try to avoid using Point-LIO in those systems. Additional ROS package is required:

sudo apt-get install ros-xxx-pcl-conversions


## **3.2 Eigen**
Following the official [Eigen installation](eigen.tuxfamily.org/index.php?title=Main_Page), or directly install Eigen by:

sudo apt-get install libeigen3-dev


## **3.3 livox_ros_driver2**
Follow [livox_ros_driver2 Installation](https://github.com/Livox-SDK/livox_ros_driver2).

*Remarks:*
- Since the Point-LIO supports Livox serials LiDAR, so the **livox_ros_driver2** must be installed and **sourced** before run any Point-LIO luanch file.
- How to source? The easiest way is 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).

## 4. Build
Clone the repository and catkin_make:


cd ~/$A_ROS_DIR$/src
git clone https://github.com/hku-mars/Point-LIO.git
cd Point-LIO
git submodule update --init
cd ../..
catkin_make
source devel/setup.bash
- Remember to source the livox_ros_driver2 before build (follow 3.3 **livox_ros_driver2**)
- If you want to use a custom build of PCL, add the following line to ~/.bashrc

```export PCL_ROOT={CUSTOM_PCL_PATH}

5. Directly run

5.1 For Avia

Connect to your PC to Livox Avia LiDAR by following Livox-ros-driver installation, then

    cd ~/$Point_LIO_ROS_DIR$
    source devel/setup.bash
    roslaunch point_lio mapping_avia.launch
    roslaunch livox_ros_driver2 livox_lidar_msg.launch

  • For livox serials, Point-LIO only support the data collected by the livox_lidar_msg.launch since only its livox_ros_driver2/CustomMsg data structure produces the timestamp of each LiDAR point which is very important for Point-LIO. livox_lidar.launch can not produce it right now.
  • If you want to change the frame rate, please modify the publish_freq parameter in the livox_lidar_msg.launch of Livox-ros-driver before make the livox_ros_driver2 pakage.

5.2 For Livox serials with external IMU

mapping_avia.launch theratically supports mid-70, mid-40 or other livox serial LiDAR, but need to setup some parameters befor run:

Edit

``` to set the below parameters:

1. LiDAR point cloud topic name: 
``` lid_topic 
  1. IMU topic name:
    
    
  2. Translational extrinsic:
    
    
  3. Rotational extrinsic: extrinsic_R (only support rotation matrix)
    • The extrinsic parameters in Point-LIO is defined as the LiDAR’s pose (position and rotation matrix) in IMU body frame (i.e. the IMU is the base frame). They can be found in the official manual.
  4. Saturation value of IMU’s accelerator and gyroscope:
    ```, 
    ```satu_gyro
    
  5. The norm of IMU’s acceleration according to unit of acceleration messages:
    
    

5.3 For Velodyne or Ouster (Velodyne as an example)

Step A: Setup before run

Edit

``` to set the below parameters:

1. LiDAR point cloud topic name: 
``` lid_topic 
  1. IMU topic name: imu_topic (both internal and external, 6-aixes or 9-axies are fine)
  2. Set the parameter timestamp_unit based on the unit of time (Velodyne) or t (Ouster) field in PoindCloud2 rostopic
  3. Line number (we tested 16, 32 and 64 line, but not tested 128 or above):
    
    
  4. Translational extrinsic:
    
    
  5. Rotational extrinsic: extrinsic_R (only support rotation matrix)
    • The extrinsic parameters in Point-LIO is defined as the LiDAR’s pose (position and rotation matrix) in IMU body frame (i.e. the IMU is the base frame).
  6. Saturation value of IMU’s accelerator and gyroscope:
    ```, 
    ```satu_gyro
    
  7. The norm of IMU’s acceleration according to unit of acceleration messages:
    
    

Step B: Run below

    cd ~/$Point_LIO_ROS_DIR$
    source devel/setup.bash
    roslaunch point_lio mapping_velody16.launch

Step C: Run LiDAR’s ros driver or play rosbag.

5.4 PCD file save

Set

``` in launchfile to 
``` 1 
```. All the scans (in global frame) will be accumulated and saved to the file 
``` Point-LIO/PCD/scans.pcd 
``` after the Point-LIO is terminated. 
```pcl_viewer scans.pcd
``` can visualize the point clouds.

*Tips for pcl_viewer:*
- change what to visualize/color by pressing keyboard 1,2,3,4,5 when pcl_viewer is running. 

1 is all random
2 is X values
3 is Y values
4 is Z values
5 is intensity

```

6. Examples

The example datasets could be downloaded through onedrive. Pay attention that if you want to test on racing_drone.bag, [0.0, 9.810, 0.0] should be input in ‘mapping/gravity_init’ in avia.yaml, and set the ‘start_in_aggressive_motion’ as true in the yaml. Because this bag start from a high speed motion. And for PULSAR.bag, we change the measuring range of the gyroscope of the built-in IMU to 17.5 rad/s. Therefore, when you test on this bag, please change ‘satu_gyro’ to 17.5 in avia.yaml.

6.1. Example-1: SLAM on datasets with aggressive motions where IMU is saturated

6.2. Example-2: Application on FPV and PULSAR

PULSAR is a self-rotating UAV actuated by only one motor, PULSAR

7. Contact us

If you have any questions about this work, please feel free to contact me and Dr. Fu Zhang via email.

CHANGELOG
No CHANGELOG found.

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Launch files

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged point_lio at Robotics Stack Exchange

No version for distro noetic. Known supported distros are highlighted in the buttons above.
No version for distro ardent. Known supported distros are highlighted in the buttons above.
No version for distro bouncy. Known supported distros are highlighted in the buttons above.
No version for distro crystal. Known supported distros are highlighted in the buttons above.
No version for distro eloquent. Known supported distros are highlighted in the buttons above.
No version for distro dashing. Known supported distros are highlighted in the buttons above.
No version for distro galactic. Known supported distros are highlighted in the buttons above.
No version for distro foxy. Known supported distros are highlighted in the buttons above.
No version for distro iron. Known supported distros are highlighted in the buttons above.
No version for distro lunar. Known supported distros are highlighted in the buttons above.
No version for distro jade. Known supported distros are highlighted in the buttons above.
No version for distro indigo. Known supported distros are highlighted in the buttons above.
No version for distro hydro. Known supported distros are highlighted in the buttons above.
No version for distro kinetic. Known supported distros are highlighted in the buttons above.
No version for distro melodic. Known supported distros are highlighted in the buttons above.