0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

如何整定卡尔曼滤波的Q、R这两个参数

GReq_mcu168 来源:TsinghuaJoking 作者:卓晴老师 2022-06-30 14:25 次阅读

一个关于卡尔曼滤波的问题,之前用的互补滤波效果也还好,但在用卡尔曼滤波的时候出现了一些问题:就是如何整定卡尔曼滤波的Q、R这两个参数,这两个参数分别是角度数据置信度与角速度数据置信度。我看别人用的这两个参数都非常小,比如别人Q都是零点零零几,而用的时候发现Q零点几跟随效果很差,我把Q调到1跟随效果才差不多。但是Q和R不都是协方差吗,它们可以取到1及以上的值吗?即Q和R有没有取值范围,以及这两个参数整定方法是什么?

回复:Kalman滤波算法常常被用来计算直立车模倾角和转动角速度。算法利用陀螺仪给出的转速度量和加速度传感器给出的倾角观测量完成计算。除了Kalman滤波器算法之外,还可以使用互补滤波器进行帮助计算。

如果不考虑系统状态的时变性和系统噪声的时变性,上述两种方法本质上是相同的。

下图显示了对于被测物体位置使用Kalman滤波算法来估计物体实际位置的示意图。

1c7fedbe-f83a-11ec-ba43-dac502259ad0.jpg

通常情况下所使用的Kalman滤波器是离散时间系统形式的。我们真正想得到的物理量表示成系统状态中的某些分量。对于系统状态的估计(滤波结果)所使用的信息来源于两个方面,一个是对系统状态演变模型的了解,包括系统转移矩阵和输入控制矩阵,输入孔质量等,另一方面来自于对系统状态的观测量。

1ca8e106-f83a-11ec-ba43-dac502259ad0.png

但这两方面的信息都会有某种不确定性。通常使用系统噪声向量(W)和观测噪声向量(V)来表示。两个噪声大小分别使用它们各自的协方差矩阵来表示。系统噪声协方差矩阵使用Q,观测噪声的协方差矩阵使用R。

下面是系统方程和观测方程表达式。虽然在表达式中包括了系统噪声w和转测噪声v,但在计算系统状态转移和系统观测量的时候并不考虑这两个噪声的影响。

1cca03c2-f83a-11ec-ba43-dac502259ad0.png

两个噪声的影响只是在卡尔曼滤波器离散迭代算法过程中使用到了两个噪声的协方差矩阵Q和R。分别用于计算系统状态估计误差的协方差矩阵P和卡尔曼滤波器增益K的大小。

下面是传统线性卡尔曼滤波器的五个基本迭代公式。

1cdec046-f83a-11ec-ba43-dac502259ad0.png

从上面公式来看,真正所要滤波得到的结果来自于公式(4)中的系统状态估计值x的某些分量,公式(4)的结果是由公式(1)所得到的状态预测值和来自观测量y计算得到的。其中卡尔曼滤波器增益K是在状态预测值和观测误差值之间做了一个折中。

如果K很小,比如等于0,则滤波结果更加接近由系统状态估计值给出的递归结果;如果K很大,比如等于1,则滤波结果更加接近于观测值所反算出来的状态变量。

1d06947c-f83a-11ec-ba43-dac502259ad0.png

K值是由公式(3)计算获得,其中的P值是通过公式(2)(5)进行计算,反映了Q的大小,因此K值的大小可以由如下形式示意:

1d25c220-f83a-11ec-ba43-dac502259ad0.png

因此,K值至于Q,R的比值有关系,而与Q,R的绝对值没有关系。所以,在不同算法中,R, Q的取值根据反应的不同量纲,可以有很大的变化,但它们的比值会决定了滤波值应该更多来自于系统模型演化的信息,还是来自于观察信号信息。

智能车竞赛中,使用Kalman滤波器将惯性传感器所得到的车体陀螺仪所反映的角速度和和加速度传感器所获得的倾斜角信息进行融合,获得直立车模倾角和转动角速度。

此时,往往将系统状态x设定为车模需要观察的角度。系统输入量u为测量所得到的角速度;系统观察值设定为有加速度传感器给出的倾角。

系统模型噪声w应该反映出陀螺仪测定角速度的随机误差和随着时间漂移的系统误差两部分。系统观测噪声v应该反映了加速度计输出量中在计算角度的近似误差和由于车模运动所产生的干扰噪声。

如果Q大R小,造成K增加,则滤波结果中就会存在较大的由于车模运动所产生的噪声,俗称跟踪不好;如果Q小R大,造成K减小,则滤波结果会出现两种问题,第一就是从处置值收敛到正确值的过程较慢,需要等一个比较长的稳定时间。另一方面就是会受到陀螺仪本身零点漂移,产生比较大的输出零点误差。

最终这两个参数的大小可以根据所选择的器件的实际性能(噪声,漂移等)通过实验观察的方式获得一个比较好的相对值。

审核编辑 :李倩

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 滤波器
    +关注

    关注

    158

    文章

    7326

    浏览量

    174759
  • 算法
    +关注

    关注

    23

    文章

    4452

    浏览量

    90746
  • Kalman
    +关注

    关注

    0

    文章

    11

    浏览量

    8162

原文标题:卡尔曼滤波器中的Q,R

文章出处:【微信号:mcu168,微信公众号:硬件攻城狮】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    Fcx3 mipi输入参数设置中,H-Blanking和V-Blanking这两个参数设置是会起作用的吗?

    输入参数设置中,H-Blanking 和V-Blanking 这两个参数设置是会起作用的吗? 这个消影时间是输入mipi信号的消影时间吗?mipi信号是包含了这个信息?现在这个参数
    发表于 02-28 07:51

    小白请问电路里这两个半圆代表什么?

    请问电路里这两个半圆代表什么元件? 没有搜到呀。 另外,请问下图中的3.3v 电源是不是都要接到一起. 谢谢
    发表于 02-16 16:32

    ADIS16448在卡尔滤波里的系统噪声参数是多少?

    大家好,最近我在使用ADIS16448做IMU和GPS的融合。IMU主要是完成卡尔滤波里预测的步骤,所以我需要为我的IMU设置系统噪声参数Q
    发表于 12-28 08:04

    电源这两个参数值,你有误读过吗?

    电源这两个参数值,你有误读过吗?
    的头像 发表于 11-27 16:33 195次阅读

    有没有基于9轴传感器的三阶卡尔滤波器算法?

    有没有基于9轴传感器的三阶卡尔滤波器算法
    发表于 11-06 06:00

    二阶滤波对比卡尔滤波输出哪个效果更好?

    二阶滤波对比卡尔滤波输出哪个效果更好
    发表于 10-13 08:21

    卡尔滤波输出的时候延时很大要怎么解决?

    卡尔滤波输出的时候延时很大要怎么解决
    发表于 10-11 08:10

    卡尔滤波是属于一什么滤波器?

    卡尔滤波器是属于一高通滤波器还是带通滤波
    发表于 10-11 06:58

    卡尔滤波算法对比其他的滤波算法有什么优点?

    卡尔滤波算法对比其他的滤波算法有什么优点
    发表于 10-11 06:42

    卡尔滤波算法是怎么实现对数据的预测处理的?

    卡尔滤波算法是怎么实现对数据的预测处理的
    发表于 10-10 08:28

    卡尔滤波可以用于四轴的姿态数据处理吗?

    卡尔滤波可以用于四轴的姿态数据处理吗
    发表于 10-10 07:29

    什么是卡尔滤波?卡尔滤波的作用是什么

    一、什么是卡尔滤波? 你可以在任何含有不确定信息的动态系统中使用卡尔滤波,对系统下一步的走向做出有根据的预测,即使伴随着各种干扰,卡尔
    的头像 发表于 08-08 09:39 4686次阅读
    什么是<b class='flag-5'>卡尔</b>曼<b class='flag-5'>滤波</b>?<b class='flag-5'>卡尔</b>曼<b class='flag-5'>滤波</b>的作用是什么

    卡尔滤波的总结和思维扩展

    卡尔滤波本质上是寻找两个分布线性组合取得最新小均方差的问题。然后扩展到多维向量空间。
    的头像 发表于 07-13 16:40 541次阅读
    <b class='flag-5'>卡尔</b>曼<b class='flag-5'>滤波</b>的总结和思维扩展

    浅析卡尔滤波

    在 飞行器姿态计算 中,卡尔滤波是最常用的姿态计算方法之一。今天就以目前的理解讲以下卡尔滤波
    的头像 发表于 06-14 10:44 1574次阅读

    卡尔滤波(KF)与扩展卡尔曼(EKF)

    卡尔滤波是一种高效率的递归滤波器(自回归滤波器), 它能够从一系列的不完全包含噪声的测量(英文:measurement)中,估计动态系统的状态,然而简单的
    发表于 05-10 17:51 3次下载