基于ES-EKF的LiDAR/GNSS/IMU传感器融合轨迹估计(附项目源码)

2024-04-10 09:36

本文主要是介绍基于ES-EKF的LiDAR/GNSS/IMU传感器融合轨迹估计(附项目源码),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

基于改进EKF的LiDAR/GNSS/IMU传感器融合轨迹估计(附项目源码)

  • 算法概述
    • Prediction
    • Correction
    • ES-EKF算法
    • 融合算法实现轨迹估计
    • 实验结果

最近在研究传感器融合,看到一个很好的开源项目,适合小白学习,为以后做传感器融合、SLAM、自动驾驶和室内定位等方向打下基础。

算法概述

题目:基于改进扩展卡尔曼滤波(Error State-EKF)的LiDAR/GNSS/IMU的传感器融合轨迹估计
关键词:改进扩展卡尔曼滤波(Error State Extended Kalman Filter,ES-EFK)、传感器融合、轨迹估计、激光雷达(LiDAR)、卫星导航(GNSS)、惯性测量元件(IMU)

算法的overview如下图所示:
在这里插入图片描述
整体而言,就是使用LiDAR、GNSS和IMU的数据根据ES-EKF进行融合迭代估计轨迹。在本项目中,IMU的采样频率较高,而GNSS和LiDAR的采样频率较低。该算法可以分为两个部分:预测(Prediction)和改正(Correction)。下面让我们一起看看这个算法。

Prediction

Prediction阶段是基于小车IMU测量的运动模型进行预测轨迹,然后再结合GNSS或LiDAR的数据用EKF融合改正预测的轨迹。

下面的小车的参数,包括位置pk、速度vk和姿态qk。
在这里插入图片描述
运动方程以IMU的数据作为输入,包括四元数转旋转矩阵Cns,比力加速度fk(由加速度计测量),角速度Wk(由陀螺仪测量)。这里需要注意的是,处理IMU数据的时候一般都用四元数,避免用欧拉角带来的死锁问题。
在这里插入图片描述

Correction

Correction阶段就是用GNSS或者LiDAR观测到的数据对估计的位置进行改正。

GNSS的观测方程:
在这里插入图片描述
LiDAR的观测方程:
在这里插入图片描述

ES-EKF算法

Error-state Extended Kalman Filter(ES-EKF)是一种改进的扩展卡尔曼滤波算法,基本思想就是将State分为两部分Nominal State和Error State。它用于状态估计问题,特别是对于非线性系统的状态估计问题,例如在机器人定位、导航和控制方面的应用。
x代表真值, x_hat代表Nominal State,占比较大, delta_x代表Error State,占比较小。

线性化如下:
在这里插入图片描述

ES-EKF试图通过引入误差状态来改进EKF的性能。它的核心思想是,通过对状态误差进行线性化而不是对状态本身进行线性化,可以更好地处理非线性性质,并提高滤波器的稳健性和准确性。相比起一般的EKF算法,优势在于:(1)Error State的线性化比Nominal State更好;(2)对于三维空间的数据处理较好,使用旋转的情况,因此很适合本项目的3D LiDAR数据。

详细推导过程可以参考该文章:ES-EKF算法推导

融合算法实现轨迹估计

1.使用IMU数据更新运动模型
在这里插入图片描述
2.不确定度计算和传播
在这里插入图片描述
3. 使用GNSS或LiDAR改正
3.1 计算卡尔曼增益
在这里插入图片描述
3.2 更新Error State
在这里插入图片描述
3.3 改正状态预测
在这里插入图片描述
3.4 计算改正方差
在这里插入图片描述

实验结果

该项目中,已经提供了预处理好的IMU、GNSS和LiDAR数据,参考轨迹和预测轨迹的对比实验结果如下:

在这里插入图片描述
位置和姿态矩阵误差:(蓝色实线是误差,红色虚线是不确定度)
在这里插入图片描述

以上就是这个小项目的主要算法介绍和实验结果,非常适合小白学习。最后,附上原作者的项目链接

我个人改进后的项目链接

这篇关于基于ES-EKF的LiDAR/GNSS/IMU传感器融合轨迹估计(附项目源码)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/890696

相关文章

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

idea+spring boot创建项目的搭建全过程

《idea+springboot创建项目的搭建全过程》SpringBoot是Spring社区发布的一个开源项目,旨在帮助开发者快速并且更简单的构建项目,:本文主要介绍idea+springb... 目录一.idea四种搭建方式1.Javaidea命名规范2JavaWebTomcat的安装一.明确tomcat

pycharm跑python项目易出错的问题总结

《pycharm跑python项目易出错的问题总结》:本文主要介绍pycharm跑python项目易出错问题的相关资料,当你在PyCharm中运行Python程序时遇到报错,可以按照以下步骤进行排... 1. 一定不要在pycharm终端里面创建环境安装别人的项目子模块等,有可能出现的问题就是你不报错都安装

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

MyCat分库分表的项目实践

《MyCat分库分表的项目实践》分库分表解决大数据量和高并发性能瓶颈,MyCat作为中间件支持分片、读写分离与事务处理,本文就来介绍一下MyCat分库分表的实践,感兴趣的可以了解一下... 目录一、为什么要分库分表?二、分库分表的常见方案三、MyCat简介四、MyCat分库分表深度解析1. 架构原理2. 分

linux查找java项目日志查找报错信息方式

《linux查找java项目日志查找报错信息方式》日志查找定位步骤:进入项目,用tail-f实时跟踪日志,tail-n1000查看末尾1000行,grep搜索关键词或时间,vim内精准查找并高亮定位,... 目录日志查找定位在当前文件里找到报错消息总结日志查找定位1.cd 进入项目2.正常日志 和错误日

java 恺撒加密/解密实现原理(附带源码)

《java恺撒加密/解密实现原理(附带源码)》本文介绍Java实现恺撒加密与解密,通过固定位移量对字母进行循环替换,保留大小写及非字母字符,由于其实现简单、易于理解,恺撒加密常被用作学习加密算法的入... 目录Java 恺撒加密/解密实现1. 项目背景与介绍2. 相关知识2.1 恺撒加密算法原理2.2 Ja

在.NET项目中嵌入Python代码的实践指南

《在.NET项目中嵌入Python代码的实践指南》在现代开发中,.NET与Python的协作需求日益增长,从机器学习模型集成到科学计算,从脚本自动化到数据分析,然而,传统的解决方案(如HTTPAPI或... 目录一、CSnakes vs python.NET:为何选择 CSnakes?二、环境准备:从 Py

Nginx屏蔽服务器名称与版本信息方式(源码级修改)

《Nginx屏蔽服务器名称与版本信息方式(源码级修改)》本文详解如何通过源码修改Nginx1.25.4,移除Server响应头中的服务类型和版本信息,以增强安全性,需重新配置、编译、安装,升级时需重复... 目录一、背景与目的二、适用版本三、操作步骤修改源码文件四、后续操作提示五、注意事项六、总结一、背景与

Android实现图片浏览功能的示例详解(附带源码)

《Android实现图片浏览功能的示例详解(附带源码)》在许多应用中,都需要展示图片并支持用户进行浏览,本文主要为大家介绍了如何通过Android实现图片浏览功能,感兴趣的小伙伴可以跟随小编一起学习一... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码