FAST-LIO论文解析

news2025/1/23 15:06:06

题目:FAST-LIO:一种快速鲁棒的基于紧耦合迭代卡尔曼滤波的雷达-惯导里程计

摘要

本文提出了一种计算效率高、鲁棒性好的激光-惯性里程计框架。我们使用紧耦合的迭代扩展卡尔曼滤波器将LiDAR特征点与IMU数据融合在一起,从而在快速运动、嘈杂或混乱的环境中实现鲁棒导航。为了在大量测量数据的情况下降低计算负荷,我们提出了一个新的计算卡尔曼增益的公式。新公式的计算量依赖于状态维数而不是测量维数。在各种室内和室外环境中对所提出的方法及其实现进行了测试。在所有测试中,我们的方法实时产生可靠的导航结果:在四旋翼机载计算机上运行,它在扫描中融合了1200多个有效特征点,并在25毫秒内完成了iEKF步骤的所有迭代。我们的代码在Github2开源。

一、简介

主要贡献:


  1. 紧耦合卡尔曼滤波器,使用IMU运动模型的积分结果和点云匹配残差共同构建残差函数
  2. 里程计频率,以固定采样时间间隔作为一个SCAN进行处理,而不是将整个激光帧作为一个处理单位
    如一帧点云采样时间为100ms,将20ms作为一个SCAN,即将一帧激光点云变成5个SCAN
  3. 点云运动补偿,基于IMU积分结果反推每个激光点采样时间对应的位姿,将所有的激光点变换到SCAN结束时间对应的坐标系
  4. 卡尔曼增益计算,优化计算公式,将针对激光点的矩阵求逆转换为对状态的矩阵求逆,维度几大降低

二、相关工作

A.纯LIDAR方法

基于ICP、G-ICP进行匹配,以及结合点到平面和点到直线的距离进行迭代匹配计算(LOAM、Lego-Loam)。

B.松耦合LIO

将IMU的积分结果作为点云匹配的初值,或者对IMU积分以及点云匹配分别处理,然后再基于EKF进行滤波融合。

C.紧耦合LIO

将原始云点数据和IMU原始数据一起放在图优化或者滤波器中构建残差函数,并进行优化。

三、算法概述

A. 算法框架

本文将使用表1中所示的符号。我们的工作流程概述如图2所示。将激光雷达输入输入特征提取模块,获得平面特征和边缘特征。然后将提取的特征和IMU测量值输入我们的状态估计模块,在10Hz−50Hz下进行状态估计。然后,估计的姿态将特征点变换到世界坐标系并添加到全局地图。
在这里插入图片描述


  • t k t_k tk : 某组scan数据的终止时间
  • τ i \tau _i τi : 在两帧LIDAR时间戳区间内,第i个IMU数据对应时间
  • ρ j \rho _j ρj : lidar帧中第j个云点对应时间
  • I i I_i Ii I j I_j Ij I k I_k Ik : 在 t k t_k tk τ i \tau _i τi ρ j \rho _j ρj时对应的IMU坐标系
  • L i L_i Li L k L_k Lk : ρ j \rho _j ρj t k t_k tk时对应的LIDAR坐标系
  • x , x ^ , x ˉ x, \hat{x}, \bar{x} x,x^,xˉ : 状态估计时的真值、预测值和估计值
  • x ~ \tilde{x} x~ : 真值和估计值之间的差值
  • x ^ k \hat{x}^k x^k : 第k次迭代时的预测值
  • x i x_i xi x j x_j xj x k x_k xk : i,j,k时刻的状态向量
  • x ˘ j \breve{x}_j x˘j :在j时刻的后向传播位姿

B. 系统描述

1.运算符介绍

略。

2.LIDAR数据预处理

每帧激光雷达点的坐标系都是当前时刻对应的运动坐标系,由于原始激光雷达点的采样频率非常高(如200HZ,这里指的是激光雷达在扫描时采样频率,不是单帧激光雷达数据的频率),因此不可能在接受到每个新点后进行处理,更实际的方法是在一定时间内积累这些点,并一次处理他们(参考IMU预积分)。在Fast-Lio中,最小累计间隔为20ms,实现50HZ的位姿输出和地图更新,如图2(a)所示。这样的累计点集成为scan,一次处理时间为 t k t_k tk(见图2 b)。从原始点中提取局部平滑度较高的平面点和局部平滑度低的边缘点。

平面点和边缘点的提取使用LOAM中的方法,此外在边缘特征提取时加入了对强度信息的考虑,即强度平滑度大的点同样被提取为线特征。

假设特征点的数量为m,采样时间间隔为 ( t k − 1 , t k ] \left ( t_{k-1},t_{k} \right ] (tk1,tk],且 ρ m = t k \rho _m = t_{k} ρm=tk
定义特征点为:
在这里插入图片描述

其中 L j L_j Lj ρ j \rho _j ρj时刻的LIDAR坐标系。对于一次激光数据的扫描,同样存在一组IMU测量数据,采样时间间隔为 [ t k − 1 , t k ] \left [ t_{k-1},t_{k} \right ] [tk1,tk],IMU数据的起止时间不一定与scan起止时间相同。

C.状态估计

为了估计状态公式(2)中的状态,我们使用迭代扩展卡尔曼滤波器。此外,我们在状态估计的切空间中描述估计协方差。

假设 t k − 1 t_{k−1} tk1时刻最后一次LiDAR扫描的最优状态估计为 x ˉ k − 1 \bar{x}_{k-1} xˉk1,协方差矩阵为 P ˉ k − 1 \bar{P}_{k-1} Pˉk1。则 P ˉ k − 1 \bar{P}_{k-1} Pˉk1表示随机误差状态向量的协方差定义如下:
在这里插入图片描述

该公式表示状态估计误差 = 真实值 - 估计值

其中旋转误差为旋转矩阵乘的性质,其余为向量减的性质。

另外,FAST-LIO是基于IEKF实现的状态估计,所以需要了解一些EKF中的概念:


  • 预测值:指通过过程模型(如积分为代表的运动模型),基于上一时刻的最优值和运动模型预测的理想结果,预测值需要加上噪声影响才更接近真值
  • 观测值:指直接通过传感器获得测量数据,如IMU的线加速度和角速度
  • 估计值:指在EKF的更新步骤中,结合预测值和估计值得到的最接近真值的最优解

1.前向传播

即基于IMU数据,通过运动模型对角速度和线加速度进行积分,根据上一时刻的估计值和当前时刻的运动求解得到的理想预测值,同时计算误差的协方差矩阵

(1)状态预测
公式4是指过程模型,即对于第k组数据的不断积分的过程第i+1次迭代的预测值 = 第i次迭代的预测值 + 一次积分结果i=1第0次迭代的预测值即k-1时刻的估计值
在这里插入图片描述

公式5是指误差模型,即对于第k组数据的每一次迭代,第i+1时刻的状态误差 = 第i+1时刻的考虑噪声影响的估计值 - 第i+1时刻的不考虑噪声影响理想预测值

第i+1时刻的考虑噪声影响的估计值即公式2,由第i时刻的真值加上i到i+1时刻考虑噪声影响的积分结果得到

第i+1时刻的不考虑噪声影响理想预测值即公式4,由i时刻的理想预测值加上不含噪声的积分结果得到
在这里插入图片描述

(2)计算误差的协方差矩阵
在这里插入图片描述

2.反向传播和运动补偿

即通过运动补偿进行激光点云去畸变。

当点云累计时间间隔达到 t k t_k tk时,就会进入下一个scan,该scan的位姿估计需要在上一个scan的位姿x和误差协方差矩阵基础上进行更新。虽然在时间上是连续的,但是新的scan坐标系已经改变了。

为了补偿新scan中某个点 ρ j \rho _j ρj到上一scan坐标系之间的运动畸变,对公式(2)进行反向传播得到以下公式:
在这里插入图片描述

这里需要参考图2-b进行理解,在前向传播过程中基于IMU数据我们得到了 t k − 1 t_{k-1} tk1 t k t_{k} tk的运动,以及 t k t_{k} tk时刻的估计值,现在为了对雷达点进行运动补偿,根据反向传播公式由 t k t_{k} tk时刻位姿得到 ρ j \rho _j ρj时刻的位姿,然后得到 ρ j − 1 \rho _{j-1} ρj1时刻位姿,以此类推,通过j=ij=t_k每个时刻的位姿,可以将对应的云点坐标系全部转换到 t k t_{k} tk时刻坐标系。
在这里插入图片描述

反向传播会根据特征点的频率执行,特征点的频率通常比IMU频率高的多(注意,这里描述的不是点云频率,而是点的频率,常见的机械式激光雷达、固态激光雷达点云频率通常为5、10、15、20HZ,而点的频率是非常高的,例如16线的velodyne,点云频率为10HZ,每条激光线束通常有2000个点,16x2000/0.1即为点的频率)。

对于两帧IMU测量之间采样的所有特征点,我们使用左IMU测量作为反向传播的输入。此外,注意到f(xj, uj, 0)的最后三个元素(对应于陀螺仪bias, 加速度计bias,与外参)为零(见公式3),反向传播可简化为以下公式,即只针对位移、速度和旋转进行反向传播。
在这里插入图片描述

通过后向传播可以得到 ρ j \rho _j ρj到scan结束时间 t k t_k tk之间的相对运动,即旋转和平移变换。这一相对变换将每个点的坐标系都转换到scan结束时间 t k t_k tk下的坐标系。
在这里插入图片描述

3.残差计算

经过运动补偿,可以将每个scan中的特征点都视为 t k t_k tk时刻采集的点,并使用这组点构造残差。假定当前为 [ t k − 1 , t k ] [t_{k-1}, t_{k}] [tk1,tk]下卡尔曼滤波器的第k次迭代,记此刻的状态估计为 X ^ k k \hat{X}_{k}^{k} X^kk。对于第0次迭代, X ^ k k = X ^ k \hat{X}_{k}^{k} = \hat{X}_{k} X^kk=X^k,即通过前向传播得到的初始状态估计。然后,该scan中的特征点可以通过公式11被转换到全局坐标系下:
在这里插入图片描述

对于公式11,是先将k时刻的第j个特征点变换到k时刻的IMU坐标系下,然后再变换到全局坐标系下。对于每个LiDAR特征点,假设其附近特征点在地图中定义的最近的平面或边缘是该点真正所属的位置。也就是说,激光部分的残差被定义为坐标变换后的激光点到全局地图中对应边缘或平面的距离。定义 u j u_j uj为特征点对应平面的法向量或者线段方向,则激光匹配的在第k次迭代的残差可以被定义为公式12:
在这里插入图片描述

上述公式的物理含义为:残差 = 特征点的估计全局坐标 与 地图上最近的平面或边缘点 的距离。其中,特征点的估计全局坐标需要单独计算,而地图上最近的平面或边缘点则由kd-Tree中搜索得到。此外,我们只会考虑其标准值低于一定阈值(如 0.5m)的残差。而残差高于阈值的点会被定义为离群值或 新观测到的点。

4.迭代状态更新

为了融合激光点云匹配残差和上述IMU前向传播得到的当前状态估计 x ˉ k \bar{x}_{k} xˉk和误差协方差矩阵 P ˉ k \bar{P}_{k} Pˉk,我们需要将残差 z j k z^{k}_j zjk和真实状态 x k x_k xk以及LIDAR的测量噪声相关联。LIDAR的测量噪声由测距噪声和激光束定向误差,通过公式13去除。
在这里插入图片描述

结合公式10、11、12、13可以得到以下残差方程
在这里插入图片描述

对于第k次迭代,将上述残差方程在 x ˉ k \bar{x}_{k} xˉk进行一阶泰勒展开,得到公式14:
在这里插入图片描述

其中, z j k z^{k}_j zjk为点云匹配误差,H为残差函数的一阶雅格比, X ~ k k \tilde{X}_{k}^{k} X~kk为状态估计的真实值与估计值之差,v表示LIDAR点的测量噪声。

x k x_k xk的先验分布是从第III-C.1节中的前向传播中获得,用于以下公式的计算:
在这里插入图片描述

其中 J k J^k Jk为公式15在0处一阶泰勒展开的雅格比矩阵。

结合公式15的先验和公式14的后验分布,可以得到最大后验估计。公式15表示前向传播过程中IMU积分的先验误差,公式14表示点云匹配对应的残差。

将公式15带入到个公式17,并且将二次项进行整理,可以得到公式18,卡尔曼滤波中更新过程中的卡尔曼增益和第k+1次迭代的估计值,如果第k+1次迭代时对应的残差小于一定阈值,则本次迭代结果为最优状态估计和协方差,即公式19。
在这里插入图片描述

在这里插入图片描述

但由于激光雷达中的点数量庞大,在公式18求解卡尔曼增益时会对一个维度很大的矩阵求逆,在本文中将对激光数据的求解转移到对状态的求解,使维度极大得降低,得到新的卡尔曼增益形式。简单的来说就是将公式18中对 ( H P H T + R ) (HPH^T + R) (HPHT+R)求逆,转变为对 ( H T R ) (H^TR) (HTR)求逆
在这里插入图片描述

我们在附录B中基于矩阵逆引理证明了这两种形式的卡尔曼增益确实是等价的。由于激光雷达测量值是独立的,协方差矩阵R为对角矩阵,因此新公式只需要在状态维度上反转两个矩阵,而不需要在测量值上反转。新公式大大节省了计算量,因为状态维数通常比LIO中的测量值要低得多(例如,在10hz扫描速率下,扫描中有1000多个有效特征点,而状态维数只有18)。

5.算法伪代码


输入:上一个SCAN的最优状态估计 x ˉ k − 1 \bar{x}_{k-1} xˉk1 p ˉ k − 1 \bar{p}_{k-1} pˉk1
当前SCAN对应的IMU数据 ( a m , w m ) (a_m, w_m) (am,wm)
当前SCAN的激光特征点

  1. 基于前向传播得到状态预测值和先验误差的协方差矩阵
  2. 基于后向传播得到运动补偿后的3D激光点
  3. 迭代前:迭代次数k=-1, X ^ k k = 0 = X ^ k \hat{X}^{k=0}_{k} = \hat{X}_{k} X^kk=0=X^k
  4. 迭代
    | 1. 迭代次数k=k+1
    | 2. 计算IMU前向传播先验一阶雅格比 J k J^k Jk和先验误差的协方差矩阵
    | 3. 计算点云匹配残差 z j k z^k_j zjk和残差的一阶泰勒展开雅矩阵 H j k H^k_j Hjk
    | 4. 更新状态估计和卡尔曼增益
    结束:当本次误差和上次误差之间的差值小于某个阈值
  5. 更新状态估计值 x ˉ k \bar{x}_k xˉk和后验估计协方差矩阵 P ˉ k \bar{P}_k Pˉk

输出: x ˉ k \bar{x}_k xˉk P ˉ k \bar{P}_k Pˉk


D.地图更新

通过将求解得到的状态转化为旋转矩阵和平移向量,然后将雷达坐标系下的点转换到全局坐标系下,最后添加到全局地图中。

E.初始化

为了获得系统状态的良好初始估计(例如,重力矢量Gg、偏置和噪声协方差),以便加速状态估计器,需要初始化。在FAST-LIO中,初始化很简单:将LiDAR保持静止几秒钟(本文中所有实验均为2秒),然后使用收集到的数据初始化IMU偏差和重力矢量。如果激光雷达支持非重复扫描(例如Livox AVIA),保持静态也允许激光雷达捕获初始高分辨率地图,这对后续导航有益。

四、试验结果

A.计算复杂度实验

对卡尔曼增益计算方法用时进行了对比,结果如下
在这里插入图片描述

B.无人机实验

主要对计算回环处的漂移现象,室内环境下32m的轨迹,漂移为8cm

C.室内实验

室内场景、快速选转运动,对FAST-LIO建图效果和LOAM以及LOAM+IMU松耦合进行了定性对比,建图效果略好,和FAST-LIO慢速运动下的建图效果相比则无较大差异。

里程计位姿输出上频率远高于loam,因为在FAST-LIO中是按照激光点的采样频率进行的状态估计,而非激光帧的频率。

D.室外实验

(1)基于手持激光雷达
在室外条件下,手持激光雷达进行快速选转,140的轨迹漂移为7cm。
(2)基于LINS室外数据集
处理时间: FAST-LIO为7.3ms,LINS为34.5ms
特征点数: FAST-LIO为784,LINS为147

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1344036.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

LeetCode刷题--- 单词搜索

个人主页:元清加油_【C】,【C语言】,【数据结构与算法】-CSDN博客 个人专栏 力扣递归算法题 http://t.csdnimg.cn/yUl2I 【C】 ​​​​​​http://t.csdnimg.cn/6AbpV 数据结构与算法 ​​​​http://t.csdnimg.cn/hKh2l 前言:这个专栏主要讲述…

OpenCV 4.9.0 正式发布

​ 开源计算机视觉库 OpenCV 4.9.0 已于2023年12月29日正式发布。 此次发布有DNN模块对ONNX Attention、Einsum等层的支持、新的fastGEMM实现、transformers的实验性支持等诸多亮点。 OpenCV 4.9.0 更新内容: (来自OpenCV中国团队以及中国社区的贡献…

跨域是什么,如何解决跨域

文章目录 前言一、 什么是跨域?二、常见跨域问题三、如何解决跨域如何解决跨域(方式)前端解决跨域问题CORS反向代理JSONP 总结 前言 跨域是在开发中经常遇到的问题,那什么是跨域呢?及常见跨域的处理方案有哪些呢&…

2020年认证杯SPSSPRO杯数学建模A题(第一阶段)听音辨位全过程文档及程序

2020年认证杯SPSSPRO杯数学建模 A题 听音辨位 原题再现: 把若干 (⩾ 1) 支同样型号的麦克风固定安装在一个刚性的枝形架子上 (架子下面带万向轮,在平地上可以被水平推动或旋转,但不会歪斜),这样的设备称为一个麦克风树。不同的麦…

Selenium在vue框架下求生存

vue框架下面,没有id、没有name,vue帮开发做了很多脏活累活,却委屈了写页面自动化测试的人(当然,也给爬信息的也带来了一定的难处)。这里只能靠总结,用一些歪门邪道: 一、跟开发商量…

计算机网络【EPoll原理】

预备知识:内核poll钩子原理 内核函数poll_wait 把当前进程加入到驱动里自定义的等待队列上 ; 当驱动事件就绪后,就可以在驱动里自定义的等待队列上唤醒调用poll的进程; 故poll_wait作用:可以让驱动知道事件就绪的时…

Can‘t locate IPC/Cmd.pm in @INC (@INC contains:解决方案

大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的…

可移动磁盘上的文件删除了怎么恢复?详细教程介绍

在我们的日常生活和工作中,可移动磁盘作为一种便携式的存储设备,经常被用来备份和传输数据。然而,有时候由于误操作或不小心的删除,导致可移动磁盘上的文件丢失。这些文件可能包含重要的工作资料、个人照片、视频等,一…

【Java开发岗面试】八股文—Java虚拟机(JVM)

声明: 背景:本人为24届双非硕校招生,已经完整经历了一次秋招,拿到了三个offer。本专题旨在分享自己的一些Java开发岗面试经验(主要是校招),包括我自己总结的八股文、算法、项目介绍、HR面和面试…

【教学类-43-02】20231226 九宫格数独2.0(n=9)(ChatGPT AI对话大师生成 回溯算法)

作品展示: 背景需求: 大4班20号说:我不会做这种(九宫格),我做的是小格子的, 他把手工纸翻过来,在反面自己画了矩阵格子。向我展示: “我会做这种!” 原来他…

数据采集遇到验证码校验的一般破解方式简述

背景 百度自动采集是一种高效的数据采集方法,但是在采集过程中经常会遇到图片验证码的问题,从而导致采集失败。那么有没有什么方法可以绕过图片验证呢?本文将为您详细介绍。 解决方案 一、使用OCR技术识别验证码 OCR技术可以识别图片中的…

JS 遍历本月所有日期

代码如下: function getMonthAllDays() {// 获取当前日期var currentDate new Date(); // 获取当前月份的第一天var firstDayOfMonth new Date(currentDate.getFullYear(), currentDate.getMonth(), 1); // 获取当前月份的最后一天var lastDayOfM…

Python将普通图像转化为栅格影像

引言 本人研究的方向是遥感,研究了2年也搞没清楚普通图像和遥感影像的区别,只知道到了多了地理坐标信息,但是经纬度信息映射到每个图像像素点的底层逻辑我还不太理解。因为现在需要使用python将图像转化为栅格影像,所以在此仔细研…

超维空间S2无人机使用说明书——51、基础版——使用yolov8进行目标跟踪

引言:为了提高yolo识别的质量,提高了yolo的版本,改用yolov8进行物体识别,同时系统兼容了低版本的yolo,包括基于C的yolov3和yolov4,以及yolov7。 简介,为了提高识别速度,系统采用了G…

解决VNC连接Ubuntu服务器打开终端出现闪退情况

服务器环境 阿里云ECS服务器 操作系统:Ubuntu 20.0.4 如何使用VNC连接阿里云ECS服务器 1.阿里云官方指导:通过VNC搭建Ubuntu 18.04和20.04图形界面 2.新手入门ECS——ubuntu 20.04安装图形化界面和本地VNC连接 问题描述 使用VNC连接上新申请阿里云服…

Python 实现 PDF 到 Word 文档的高效转换(DOC、DOCX)

PDF(Portable Document Format)已成为一种广泛使用的电子文档格式。PDF的主要优势是跨平台,可以在不同设备上呈现一致的外观。然而,当我们需要对文件内容进行编辑或修改,直接编辑PDF文件会非常困难,而且效果…

分布式技术之分布式数据存储系统

文章目录 什么是分布式数据存储系统?分布式数据存储系统三要素顾客:生产和消费数据导购:确定数据位置货架:存储数据 CAP 理论指出,在分布式系统中,不能同时满足一致性、可用性和分区容错性,指导…

408计算机组成原理错题知识点拾遗

个人向错题相关部分整理,涵盖真题、模拟、课后习题等。 408相关: 408数据结构错题知识点拾遗 408数据结构常考算法基础训练等待完善 408计算机组成原理错题知识点拾遗408操作系统错题知识点拾遗等待完善408计算机网络错题知识点拾遗 408计算机网络各层协…

MYSQL的UPDATE时锁表机制

(笔记,只为获取流量券) MySQL中,UPDATE 操作涉及到行级锁和表级锁的概念,具体取决于事务隔离级别和被更新的条件, 无索引的情况下: 当表没有索引的情况下,UPDATE 操作通常会涉及到表级锁。这是…

使用Halcon 采集图像并进行简单处理rgbl_to_gray/threshold/connection/fill_up

使用Halcon 采集图像并进行简单处理 文章目录 使用Halcon 采集图像并进行简单处理 下面介绍一个简单的采集图像的例子。在Halcon中利用图像采集接口,使用USB3.0相机实时拍摄图像。采集到图像后对图像进行简单的阀值分割处理,将有物体的区域标记出来。 &a…