IMU校正以及姿态融合[通俗易懂]

版权声明:本文为博主原创文章,未经博主允许不得转载。博主:shenshikexmu联系方式:shenshikexmu@163.com缘起有缘在简极科技兼职两年。接触了IMU,我去的时候那家公司还是一个要把IMU放进足球的公司,祝愿简极越来越好。IMU校正算法大概是接触传感器三个月做出来的,博客IMU加速度、磁力计校正--椭球拟合的内容,那时只是把校准问题当作椭球拟合问题。融合算法大…

大家好,又见面了,我是你们的朋友全栈君。

本文为博主“声时刻”原创文章,未经博主允许不得转载。
联系方式:shenshikexmu@163.com

缘起
有缘在简极科技兼职两年。接触了IMU,我去的时候那家公司还是一个要把IMU放进足球的公司,祝愿简极越来越好。IMU校正算法大概是接触传感器三个月做出来的,博客IMU加速度、磁力计校正--椭球拟合的内容,那时只是把校准问题当作椭球拟合问题。融合算法大概是接触IMU一年做出来的,中途学习了kalman滤波。在安卓上的实时算法一年半完成,视频
IMUCalibration-Gesture换了一个更好的校正算法,滤波算法不变。愿和大家一起学习并讨论。有些朋友邮件上问我问题,真的给我很大的鼓励。
2021年4月,我自己的论文TII《Low-cost IMU Calibration with Nonlinear Scale Factors》

校正
这边有一篇讲IMU误差的很好的博客,直接引用了,IMU误差模型和校准。也是在《A Robust and Easy to implement method for imu calibration without External Equipments》框架下解释误差的。
这里写图片描述
图源于IMU误差模型和校准
加速度
参照ICRA2014论文:《A Robust and Easy to implement method for imu calibration without External Equipments》
说明
摘数据的部分我没有按照ICRA2014的算法写,而是自己写了FindFixData这样一个函数。ICRA2014的摘数据的算法我也拿matlab写了一遍,算方差实在是太花时间了(可能我的那个算法需要优化),FindFixData算法轻便一些,就是要人为的设置参数,ICRA2014不需要人为设置参数。摘出的稳定数据校正角速度参数和磁力计参数,摘出的运动的数据用来校正角速度传感器。
角速度
参照ICRA2014论文:《A Robust and Easy to implement method for im calibration without External Equipments》
磁力计
算法1:mag2acc_matrix,假设重力与磁向量的夹角不变。

算法2:Cal_mag4acc_frame,利用不同姿态下传感器感受的磁通向量的变化与姿态变化的相关性,计算参数。

说明
算法中的校正传感器为MPU9250,这个传感器的加速度坐标系与磁力计坐标系的z轴反向。在校正时,把变换矩阵的 T 33 T_{33} T33位置设为-1,如果其他传感器z轴相同, T 33 T_{33} T33设为1.

这里写图片描述
MPU9250
T m 2 a = [ T 11 T 12 T 13 T 21 T 22 T 23 T 31 T 32 − 1 ] Tm2a=\begin{bmatrix} T_{11} & T_{12} &T_{13} \\T_{21} & T_{22}&T_{23} \\T_{31} &T_{32}&-1\end{bmatrix} Tm2a=T11T21T31T12T22T32T13T231

其他,是1还是-1,这个要看传感器资料了 。
T m 2 a = [ T 11 T 12 T 13 T 21 T 22 T 23 T 31 T 32 1 ] Tm2a=\begin{bmatrix}T_{11} & T_{12} &T_{13} \\T_{21} & T_{22}&T_{23} \\T_{31} &T_{32}&1\end{bmatrix} Tm2a=T11T21T31T12T22T32T13T231
参数
c a l a c c = T a ∗ K a ∗ ( r a w a c c + B a ) cal_{acc}=Ta*Ka*(raw_{acc}+Ba) calacc=TaKa(rawacc+Ba)
c a l g y r o = T g ∗ K g ∗ ( r a w g y r o + B g ) cal_{gyro}=Tg*Kg*(raw_{gyro}+Bg) calgyro=TgKg(rawgyro+Bg)
c a l m a g = T m 2 a ∗ ( r a w m a g + B m ) cal_{mag}=Tm2a*(raw_{mag}+Bm) calmag=Tm2a(rawmag+Bm)

LM算法

增加了我自己写的Levenberg-Marquardt算法,matlab自带的lsqnonlin函数被注释,可以选择注释我手写的LM算法,选择取消注释lsqnonlin函数。

姿态
Mahony filter
参考 《Nonlinear Complementery Filters on the Special Orthogonal Group》
受启发于 http://blog.csdn.net/luoshi006/article/details/51513580
EKF
参考 《A Double-Stage Kalman Filter for Orientation Tracking with an Integrated Processor in 9-D IMU》

High Low pass
Gyro进行高通滤波器,Accelerate & Magnetic进行低通滤波。

滤波结果
滤波结果
校正与融合

imuCalibration-Gesture

开源代码
具体请参考github开源代码:IMUCalibration-Gesture.

如果您觉得此文对您所要做的工作有帮助,欢迎在github上标星星。

欢迎在“知识星球”更深入地探讨问题。

知识星球


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/125502.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • OGEngine教程:声音载入

    OGEngine教程:声音载入

    2021年12月9日
    40
  • 小白能读懂的 《手把手教你学DSP(TMS320X281X)》第三章 2020-12-25

    小白能读懂的 《手把手教你学DSP(TMS320X281X)》第三章 2020-12-251最小系统1.1任何保证正常工作一定要检查电源和地是否短接。电源芯片一定要产生稳定电压,3.3V和1.8V。板子要断电插拔,不要热插拔JTAG。1.2最小系统1.2.1电源电路电源芯片常用TPS767D301,产生稳定的3.3V与1.8V。电源和地之间要通过电容连接,电容值查询数据手册,有推荐使用的电路。数字电源和模拟电源通过电感或磁珠连接,数字地和模拟地也通过这些隔断。1.2.2芯片引脚主要是各部分的引脚,内核数字地和模拟地,内核电压和模拟电压。

    2022年5月4日
    51
  • 服务器加网站防盗链,网站防盗链的设置方法介绍(适用于IIS和Apache)[通俗易懂]

    服务器加网站防盗链,网站防盗链的设置方法介绍(适用于IIS和Apache)[通俗易懂]这篇文章主要为大家详细介绍了网站防盗链的设置方法介绍(适用于IIS和Apache),具有一定的参考价值,感兴趣的小伙伴们可以参考一下,有需要的朋友可以收藏方便以后借鉴。做网站的朋友一般都会遇到这样的一种情况,就是别人的网站经常会调用我们自己网站的图片或者文件,这无形之中会增加我们的服务器的压力,尤其是对于一些服务器带宽并不是十分富裕的网站来说就更是雪上加霜。因此我们需要学会设置防盗链来应对或者说来…

    2022年7月23日
    22
  • ibatis isNotEmpty

    ibatis isNotEmpty1、ibatis中isNotEmpty的作用        selectxiddictCode,xnamedictNamefromcity  ]]>                  xflag=$xflag$   ]]>                              xprovince_id=#xpro

    2022年10月7日
    0
  • 单纯形法和单纯形表_什么是初始单纯形表

    单纯形法和单纯形表_什么是初始单纯形表线性规划常用的方法是单纯形表法,下面用一个简单的例子告诉大家如何用最简单的方法求取目标函数Z值。用单纯形方法求解线性规划问题:首先引入松弛变量,把原问题化为标准形式:具体步骤如下:第1步,确定初始单纯形表第2步:判别检验所有的检验系数(1)如果所有的检验系数,则由最优性判定定理知,已获最优解,即此时的基本可行解就是最优解。(2)若检验系数…

    2025年7月2日
    0
  • [Python3]Numpy数组转置的三种方法T、transpose、swapaxes「建议收藏」

    [Python3]Numpy数组转置的三种方法T、transpose、swapaxes「建议收藏」天下难事,必作于易;天下大事,必作于细——老子Numpy是高性能科学计算和数据分析的基础包,里面包含了许多对数组进行快速运算的标准数学函数,掌握这些方法,能摆脱数据处理时的循环。1.首先数组转置(T)创建二维数组data如下:进行矩阵运算时,经常要用数组转置,比如计算矩阵内积X^TX.这时就需要利用数组转置,如下:2.轴对换之transpose对于高维数组,可以使用轴对换来对多…

    2022年6月2日
    34

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号