当前位置: 首页 > article >正文

自己造轮子-基于Ceres的GNSS-INS松耦合组合导航算法

之前硕士期间的研究课题涉及到GNSS-INS组合导航,入门看的武汉大学牛老师团队的KF-GINS,不得不说,大组的东西还是很棒的,很适合组合导航入门,KF-GINS主要是基于ESKF的GNSS/INS松耦合组合导航系统,博主就不在这里对ESKF和松耦合进行过多的阐述了。本篇主要针对基于Ceres的松耦合组合导航系统的设计与实现,那么直接开造~

Ceres

Ceres这个工具对于slamer应该不算陌生,主要用来设计基于优化问题,那么对于松耦合的GNSS/INS组合导航系统,其实也可以参考基于ESKF的思路来设计基于Ceres的融合方案;

使用工具

本篇博客对于gnss和imu的数据主要使用的是开源方针算法“gnss-ins-sim”

1.ubuntu18.04
2.ros-melodic
3.gnss-ins-sim

融合方案设计

松耦合,那么也就是将ins解算得到的PVQ与gnss提供的PVQ进行融合,然后根据建立的运动学模型和观测来反向估计对应传感器的噪声,本篇博客使用的观测有gnss提供的速度以及位置信息,那么涉及到的融合就只有速度和位置的融合;

位置的融合

1.残差函数
e r r o r = P g − P i error = P_g-P_i error=PgPi
下标i表示imu的递推解算得到的P,g表示由gnss提供的P观测;
2.残差的雅可比矩阵
J = [ 1 0 0 0 1 0 0 0 1 ] J=\begin{bmatrix} 1 & 0 & 0 \\ 0 & 1 & 0 \\ 0 & 0 & 1 \end{bmatrix} J= 100010001

速度的融合

1.残差函数
e r r o r = V g − V i error = V_g-V_i error=VgVi
下标i表示imu的递推解算得到的P,g表示由gnss提供的P观测;
2.残差的雅可比矩阵
J = [ 1 0 0 0 1 0 0 0 1 ] J=\begin{bmatrix} 1 & 0 & 0 \\ 0 & 1 & 0 \\ 0 & 0 & 1 \end{bmatrix} J= 100010001

加速度计的零偏估计

这块其实与上面的速度融合相似,只是需要对残差函数做更进一步的细化:
对于ins的速度更新公式:
![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/d7fe0d5fe51a49388afef7b936c3da2f.png
v k = v k − 1 + ( R w b k a k + R w b k − 1 a k − 1 2 − g ) ( t k − t k − 1 ) v_k=v_{k-1}+(\frac{R_{wb_k}a_k+R_{wb_{k-1}}a_{k-1}}{2}-g)(t_k-t_{k-1}) vk=vk1+(2Rwbkak+Rwbk1ak1g)(tktk1)
上述公式基于中值法做的速度递推

残差公式

e r r o r = V g − V k error = V_g - V_k error=VgVk

雅可比矩阵

这里我没有手推过,就直接用的Ceres的自动求导了…

代码实现

我把代码提到我自己的github了,有兴趣的各位可以去看看,其实对于零偏的估计这块,我自己有点拿不准,但是最终估计出来的效果确实也接近我自己手动设置的加速度计的零偏,还望各位大佬能够不吝赐教,有错误的地方能够大方指点一下,我在这里谢过每一位读过我博客的各位了~
github仓库-选择master分支
如果代码能够帮到各位读者,还望能够star一下哟~

开源工具包使用参考

深蓝学院-多传感器融合定位-第六讲


http://www.kler.cn/a/509724.html

相关文章:

  • 前端项目搭建和基础配置
  • Docker部署Redis
  • MySQL面试题2025 每日20道
  • 使用Pydantic驾驭大模型
  • 无降智o1 pro——一次特别的ChatGPT专业模式探索
  • 彻底理解JVM类加载机制
  • 为AI聊天工具添加一个知识系统 之51 从形态学简约到纯粹的思维再映射到AI操作系统 之2
  • liunx进程函数汇总(包含管道、共享内存、消息队列、信号)
  • 浅谈计算机网络03 | 现代网络组成
  • 【tailscale 和 ssh】当服务器建立好节点,但通过客户端无法通过 ssh 连接
  • PostgreSQL-WAL日志介绍(一)
  • 蓝桥杯训练—矩形面积交
  • 服务器怎样防范网络蠕虫病毒?
  • Ubuntu 手动安装 Open WebUI 完整指南
  • 《CPython Internals》阅读笔记:p221-p231
  • 【优化算法】狭义相对论搜索算法:一种基于狭义相对论物理学的元启发式方法
  • 《内网穿透:开启网络世界的任意门》
  • 于灵动的变量变幻间:函数与计算逻辑的浪漫交织(下)
  • 20250118拿掉荣品pro-rk3566开发板上Android13下在uboot和kernel启动阶段的Rockchip这个LOGO标识
  • 深入浅出JSON:数据交换的轻量级解决方案
  • OpenVela——专为AIoT领域打造的开源操作系统
  • SpringBoot3 升级介绍
  • Hexo + NexT + Github搭建个人博客
  • 解决:Loading class `com.mysql.jdbc.Driver‘. This is deprecated
  • 复健第二天之[MoeCTF 2022]baby_file
  • ASP.NET Core中 JWT 实现无感刷新Token