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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 【Verilog】移位寄存器总结:移位寄存器、算数移位寄存器、线性反馈移位寄存器(LFSR)

    【Verilog】移位寄存器总结:移位寄存器、算数移位寄存器、线性反馈移位寄存器(LFSR)在练习HDLbits的时候,最常见的几种移位寄存器进行了总结,供大家参考,希望可以帮助到大家。

    2022年7月16日
    51
  • CSRF攻击与防御(写得非常好)「建议收藏」

    转载地址:http://www.phpddt.com/reprint/csrf.htmlCSRF概念:CSRF跨站点请求伪造(Cross—SiteRequestForgery),跟XSS攻击一样,存在巨大的危害性,你可以这样来理解:攻击者盗用了你的身份,以你的名义发送恶意请求,对服务器来说这个请求是完全合法的,但是却完成了攻击者所期望的一个操作,

    2022年4月14日
    37
  • mysql密码更改_mysql初始密码在哪个文件

    mysql密码更改_mysql初始密码在哪个文件若使用mysqld–initialize初始化mysql数据库,会产生一个默认的随机密码。密码位置:mysql安装目录下的data目录下的xxx.err文件,此文件如下所示:用记事本打开err文件可以看到临时密码:<a5F34))PqMb使用cmd命令行工具,用临时密码登录,进行修改密码命令:mysql-uroot-p修改密码sqlsetpasswordfo…

    2022年8月12日
    5
  • jre环境变量配置_Windows系统配置Java环境变量

    jre环境变量配置_Windows系统配置Java环境变量一、到达环境变量配置页面从路径:桌面->控制面板->系统和安全->系统,到达系统,点击左侧“高级系统设置”,再点击“环境变量”。方法1:在桌面上右键“此电脑”,选择属性,直接到达系统(桌面无“此电脑”或“控制面板”的同学可选择方法2),然后点击“高级系统设置”,再点击“环境变量”,到达配置页面。123方法2:1点击窗口,选择设置2搜索并…

    2022年7月8日
    178
  • pycharm 2021.4.14激活码_通用破解码[通俗易懂]

    pycharm 2021.4.14激活码_通用破解码,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月17日
    60
  • 【计算机网络(微课版)】第3章 数据链路层 课后习题及答案

    【计算机网络(微课版)】第3章 数据链路层 课后习题及答案3-1数据链路(即逻辑链路)与链路(即物理链路)有何区别?“电路接通了”与“数据链路接通了”的区别何在?(1)数据链路与链路的区别在于——数据链路除链路外,还必须有一些必要的规程来控制数据的传输。因此,数据链路比链路多了实现通信规程所需要的硬件和软件。(2)“电路接通了”表示链路两端的结点交换机已经开机,物理连接已经能够传送比特流了。但是,数据传输并不可靠。在物理连接…

    2022年7月21日
    13

发表回复

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

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