3D激光SLAM:LIO-SAM整体介绍与安装编译

LIO-SAM的全称是:Tightly-coupled Lidar Inertial Odometry via Smoothing and Mapping

从全称上可以看出,该算法是一个紧耦合的雷达惯导里程计(Tightly-coupled Lidar Inertial Odometry),借助的手段就是利用GT-SAM库中的方法。

LIO-SAM 提出了一个利用GT-SAM的紧耦合激光雷达惯导里程计的框架。
实现了高精度、实时的移动机器人的轨迹估计和建图。

框架的构成
通过相对观测(两帧间的估计)及绝对观测(GPS),还包括回环检测,构成因子图。

这个框架必须要有激光雷达IMU。可以没有回环和GPS。

IMU的作用:
用IMU的数据对激光雷达点云作畸变矫正
为激光雷达里程计的优化提供一个初值

系统对IMU的作用:
获得的雷达里程计会用来估计IMU的零偏(bias)

点云匹配建图方式
为了保障性能和实时,并不是将激光雷达一帧数据和全局地图进行匹配,而是和经过边缘化的历史地图进行匹配
这种当前帧和局部地图配置而不是全局地图的做法,可以显著提高系统的实时性。

局部地图构成
通过选取关键帧的方式,利用滑窗的方法,将当前的关键帧和历史尺度和大小一致的子关键帧集合配准。

测试情况
提出的方法在三个平台进行了测试,手持设备、UGV、船,在不同场景下表现都很不错。

LIO-SAM整体框架

在这里插入图片描述

输入层中的三个矩形框是是三个传感器

  • IMU
  • 点云
  • GPS(可选)

输出以IMU的频率发布里程计的结果

LIO-SAM中的四个矩形图,对应ROS中的四个节点。每个节点都有其单独的功能。

图像映射节点

可以先看图像映射的节点
该节点订阅3个消息

  • 原始imu数据
  • 原始点云数据
  • imu里程计数据 来自IMU预积分节点

其中imu里程计数据在系统初始化阶段没有该消息,图像映射节点仅有两个数据

主要功能有四个:

  • 获得变换初始估计,该估计是从imu里程计数据获得
  • 组织点云,与lego-loam类似,将点云转为深度图像
  • 点云畸变矫正 只对旋转部分补偿,平移部分在代码中注释掉了。利用的IMU原始数据

该节点发布的消息:
处理后的点云

特征提取节点

订阅信息1个:
来自图像映射节点的处理后的点云

功能:
提取角点和面点

该节点发布的消息:
处理后的点云

建图优化节点

订阅信息两个

  • 特征提取处理后的点云
  • 原始GPS数据(可选)

主要功能

  • 点云匹配
  • 计算雷达里程计的位姿
  • 因子图优化(雷达里程计因子、GPS因子、回环因子),注意这里没有IMU因子

发布消息

  • 激光雷达里程计,发送给IMU预积分节点

IMU预积分节点

该节点最后一个工作,需要前面3个工作完,得到激光雷达里程计后,再进行IMU预积分

订阅数据:

  • imu原始数据
  • 激光雷达里程计(来自建图优化节点)

功能:

  • 因子图优化(IMU预积分因子、雷达里程计因子)
  • 估计IMU零偏

发布消息:

  • IMU里程计信息

LIO-SAM编译与安装

可以参考官网
官网地址

该功能包的依赖有

  • ROS
    验证的版本有Kinetic 和 Melodic
    同时需要安装ROS的几个功能包,如下:
sudo apt-get install -y ros-kinetic-navigation
sudo apt-get install -y ros-kinetic-robot-localization
sudo apt-get install -y ros-kinetic-robot-state-publisher
wget -O ~/Downloads/gtsam.zip https://github.com/borglab/gtsam/archive/4.0.0-alpha2.zip
cd ~/Downloads/ && unzip gtsam.zip -d ~/Downloads/
cd ~/Downloads/gtsam-4.0.0-alpha2/
mkdir build && cd build
cmake ..
sudo make install

cmake 可以改成如下指令

cmake -DGTSAM_BUILD_EITH_MARCH_NATIVE=OFF -DGTSAM_USE_SYSTEM_EIGEN=ON ..

目的是设置一些宏
DGTSAM_BUILD_EITH_MARCH_NATIVE 是开启css加速的宏,要关闭。避免其它库(比如PCL或者自己代码)没有开启的话,会造成运行时出现异常的情况
DGTSAM_USE_SYSTEM_EIGEN 这个是用系统装的eigen编译的宏,要开启。OFF的话会用gtsam自带的eigen,代码运行存在两个版本eigen会容易出问题

之后就可以下载LIO-SAM的代码进行安装了

cd ~/catkin_ws/src
git clone https://github.com/TixiaoShan/LIO-SAM.git
cd ..
catkin_make

安装编译成功后,会提示如下:
在这里插入图片描述

运行

roslaunch lio_sam run.launch

通过上面的指令就能运行了。

但是在运行前,要根据自己的情况进行一些参数配置

在params.yaml文件中可以看到一些配置

  pointCloudTopic: "points_raw"               # Point cloud data
  imuTopic: "/imu_correct"                         # IMU data
  odomTopic: "odometry/imu"                   # IMU pre-preintegration odometry, same frequency as IMU
  gpsTopic: "odometry/gpsz"                   # GPS odometry topic from navsat, see module_navsat.launch file

其中

  • 点云的Topic名称为points_raw
  • IMU的Topic名称为/imu_correct

这两个如果自身的数据发布名称不一致,需要改成一致的

  • GPS的Topic名称为odometry/gpsz
    如果没有GPS可以不用管
  sensor: velodyne                            # lidar sensor type, either 'velodyne' or 'ouster'
  N_SCAN: 16                                  # number of lidar channel (i.e., 16, 32, 64, 128) 雷达的通道数量
  Horizon_SCAN: 1800                          # lidar horizontal resolution (Velodyne:1800, Ouster:512,1024,2048)激光雷达水平分辨率   也就是水平角度分辨率  360/1800=0.2
  downsampleRate: 1                           # default: 1. Downsample your data if too many points. i.e., 16 = 64 / 4, 16 = 16 / 1
  lidarMinRange: 1.0                          # default: 1.0, minimum lidar range to be used  雷达最小距离长度
  lidarMaxRange: 1000.0                       # default: 1000.0, maximum lidar range to be used  雷达最大距离长度

这边雷达参数也要对应的设置

  extrinsicTrans: [0.0, 0.0, 0.0]
  extrinsicRot: [1, 0, 0,
                  0, 1, 0,
                  0, 0,  1]
  extrinsicRPY: [ 1, 0, 0,
                0, 1 , 0,
                  0, 0, 1]

IMU和类的外参配置一下
别的就没啥了

配置完即可运行launch文件,然后在rviz中就可以看到地图了

在这里插入图片描述
在这里插入图片描述
粉色的是面点,绿色的是角点

  • 10
    点赞
  • 82
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
好的,关于在激光SLAM框架LIO-SAM中加入地平面约束,构造地平面因子,用C++代码实现的问题,我可以为您提供一些思路。 首先,需要明确的是,在LIO-SAM中加入地平面约束的主要目的是为了提高定位和建图的精度。地平面信息可以帮助我们更好地估计机器人的高度,并且可以过滤掉一些误差比较大的点云数据,从而提高建图的质量。 其次,在LIO-SAM中构造地平面因子的过程可以分为以下几个步骤: 1. 首先需要对点云数据进行初步的处理,将点云数据转换到机器人坐标系下,并对点云进行滤波和分割,得到地面和非地面点云数据。 2. 接着,需要对地面点云数据进行平面拟合,得到地面的法向量和距离参数。 3. 然后,可以根据地面的法向量和距离参数,构造地平面因子。具体而言,可以采用高斯-牛顿法或者LM算法等优化方法,将地面因子加入到目标函数中,从而实现地平面约束。 最后,关于用C++代码实现地平面因子的构造,可以参考以下的代码: ``` // 定义地平面因子 class GroundFactor: public ceres::SizedCostFunction<1, 6> { public: GroundFactor(const Eigen::Vector3d& n, const double d) : n_(n), d_(d) {} virtual ~GroundFactor() {} virtual bool Evaluate(double const* const* parameters, double* residuals, double** jacobians) const { const double* p = parameters[0]; Eigen::Map<const Eigen::Vector3d> T(p); residuals[0] = n_.dot(T) + d_; if (jacobians != NULL && jacobians[0] != NULL) { Eigen::Map<Eigen::Matrix<double, 1, 6, Eigen::RowMajor>> jacobian(jacobians[0]); jacobian.setZero(); jacobian.block<1, 3>(0, 0) = n_.transpose(); } return true; } static ceres::CostFunction* Create(const Eigen::Vector3d& n, const double d) { return (new ceres::AutoDiffCostFunction<GroundFactor, 1, 6>(new GroundFactor(n, d))); } private: Eigen::Vector3d n_; double d_; }; ``` 以上就是关于在激光SLAM框架LIO-SAM中加入地平面约束,构造地平面因子,用C++代码实现的一些思路和代码实现。希望对您有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

月照银海似蛟龙

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值