卡尔曼滤波器笔记——最详细

news2025/1/17 0:19:08

 笔记来源—

卡尔曼滤波算法原理及代码实现!icon-default.png?t=N7T8https://www.bilibili.com/video/BV1WZ4y1F7VN/?spm_id_from=333.337.search-card.all.click&vd_source=8d55784dc9c7530bc9e3fa220380be56

 简单介绍一下

现在我们就是不知道是距离多少,就需要用到这个卡尔曼滤波器。

这里的预测方程就是我们的状态方程

这里的H一般就是单位矩阵 ,或者是单位矩阵的一部分

这里的n一般就是状态变量的个数,m就是你选择的观测值

H具体是什么形状要根据选择的状态变量X_{k}以及要观测的目标值的Z_{k}的形状

所以上面我们举的小车的例子的观测值就只有一个,那就是他的距离,所以Z_{k}就是1*1的矩阵,m就是1,如果我们还想知道车速,那么m就是2.Z_{k}就是2*1的矩阵

举个例子

状态变量的个数等于状态方程的个数乘以他的阶数,这里他只有一个方程

首先要看他是一个几自由度的模型,这个RLC模型他是一个1自由度的系统,所以他只涉及一个方程,因为他只有一个回路,一个方程就可以把这个系统表示了。本质上他是一个单自由度系统。一个单自由度系统就写一个方程,这个方程他又是一个二阶的方程,所以选两个状态变量。

这里我们的求导是为了些状态方程。

这里的A是系统矩阵,B是控制矩阵

X_{k-1}代表的就是在k-1时候的状态u_{k-1}就是我们的控制量,一般我们在基尔霍夫数据中里面一般是认为没有控制量,所以这一项基本上为0,再加上我们的噪声w_{k-1}就得到了预测方程

问题来了,那么我们的观测方程又是什么?

H到底是什么?

H其实就是一个单位阵,继续用那个例子

我们的X_{k}=\begin{bmatrix} I\\ \frac{1}{C}\int Idt\end{bmatrix}

Z_{k}=HX_{k}+V_{k}是由我们自己决定的,也就是说你做卡尔曼滤波就是你决定的,①比如是电流I的话我们的Z_{k}=I.②比如还想要\frac{1}{C}dt,那么Z_{k}=\begin{bmatrix} I\\ \frac{1}{C}\int Idt\end{bmatrix}

在第一种情况下我们的H=\begin{bmatrix} 1 & 0 \end{bmatrix}

也就是说Z_{k}=HX_{k}+V_{k},我们只要知道Z_{k}X_{k}就可以知道我们的H

如果我们选第二种,那么我们的H=\begin{bmatrix} 1 &0 \\ 0& 1 \end{bmatrix},但是他应该是H=\begin{bmatrix} 1 &0 \\ 0& 0 \end{bmatrix},因为什么呢,因为

\frac{1}{C}\int Idt无法观测到,写了1就说明观测的到,但是我们观测不到所以这里是0.

我们的目标就是找到最优的估计值,先验就是我们要通过我们的预测方程来达到一个预测估计值 

\hat{x}_{k}就是说我们已经测量z_{k}了,也就是说已经拿到预测值\hat{x}_{k}^{-}还有测量值z_{k}了,我们对他进行矫正,矫正得到了一个最优的估计值,然后就会得到我们的先验估计误差和后验估计误差

下面就是我们的预测方程,上面讲过

 然后我们找到了先验估计误差跟后验估计误差,就有了先验估计误差的协方差还有后验估计误差的协方差

优化思路

卡尔曼滤波详细解释

我们对一个硬币进行测量三次,那我们怎么去估计这个值呢,一般我们的第一思路就是求平均值

经过转换我们可以看到这个等式

随着k的增加我们可以知道,这个\frac{1}{k}趋近于0

这个也很好理解,就是说当我们有了大量的数据,我们对估计的结果就很有信心了

数据比较少的时候,作用就大了

让我们换种表达方式

可以 看到我们的新一次的估计值与上一次的估计值有关,上一次的就跟上上一次的有关,这就是卡尔曼滤波的递归思想。

这个时候我们引入估计误差跟测量误差的概念,我们可以知道当估计误差远大于测量误差的时候,我们的卡尔曼增益是趋近于1的,这个时候我们就带入原来的公式,可以看到我们的估计值是等于测量值的,也就是说我们更加相信这个测量值。

当估计误差远小于测量误差的时候,我们的卡尔曼增益系数就接近于0,我们的估计值就相信上一次的估计值

举个例子

我们先引入三个公式,前面两个就是我们上面推出来的公式,第三个是我们的更新估计误差的公式

再引入我们的数据,还是测长度。

我们的实际长度是50mm,估计长度是40mm,估计误差在5mm,我们第一次的测量值为51mm,测量误差是3mm,也就是说我们测量的值在48-54mm之间,使用的是同一个测量工具,所以它第几次的测量误差都是3mm

然后我们就可以进行计算

然后我们继续进行第二次的计算

我们第二次测量的值为48,测量误差还是3mm

我们继续进行计算,可以看到我们的卡尔曼增益根据上一次的估计误差进行了更新

我们的估计值也由于卡尔曼的增益上一次的估计值进行了更新

我们的估计误差根据我们的卡尔曼增益上一次的估计误差进行了更新

然后剩下的我们使用excel进行计算

我们的测量误差就是3,只要保证在50上下范围3左右浮动就可以了

然后先计算我们的K_{k}

再计算我们的估计值\hat{x}_{k}

再计算我们的估计误差

这里可以看到这里的蓝色是我们的测量结果,红色是我们估计的结果,我们的估计值从一开始的40开始上升,慢慢逐渐到我们的49附近,再慢慢靠近我们的实际值,我们知道这个50是我们的实际尺寸

数学基础——数据融合,协方差矩阵,状态空间方程,观测器

方差

这两个是一样的

数据融合——Data Fusion

假设我们现在有两个称,去称一个东西,得到两个结果,而且我们知道这两个称都不准,得到两个结果一个是Z_{1},另一个是Z_{2}

我们可以知道他的正态分布和概率(积分可以算)

机器视觉中应用正态分布

正态分布概率计算

不知道正态分布的的可以看一下上面这两个链接

这时候我们知道了这两个结果,这个时候我们要去估算这两个真实值,是多少呢?

凭感觉来讲,应该是在这两个分布的中间,而且第一个的误差小,因为他的标准差小

所以真实值更靠近第一个称称出来的结果,大概在绿线的位置

如果要从数学上找到一个最优的估计值应该怎么做?

这个时候就要用到我们之前所说的Kalman Gain的思想了

下面我们就是要去求解K了,就是使得我们的估计值的标准差最小,也就是方差最小

为什么?

因为方差越小越接近真实值

对其求导(令他为0),可以得到我们的极值,然后再带入我们的方差值,就可以知道我们的k

有了k以后我们再把k带入上面的式子

可以得到

也就是说,根据这两个称的特性测量出来的结果我们做出了预测,这个预测就是30.4g,并且通过数学证明了他就是最优解

回到我们之前的这一步,我们,这时候我们就可以去更新我们的估计误差

这个时候去计算他的方差

带入到蓝色的地方

就得到了我们估计值跟估计误差(方差)

这就是他的图,这个过程就叫做数据融合

协方差矩阵

举个例子

 这里我们取三个人最基本的数据,身高,体重,年龄。并求平均值,方差,协方差

从这里的协方差可以反应出如果这里两个相乘项都小于平均值,那么两个数相乘都是正的,如果都大于平均值,两个数相乘也是正的。如果一个大一个小,那么两个值相乘就是负的了。

结果:1、如果求出来的协方差两个值都是正的话,那就说明这两个变量方向就是一样的(正相关)

2、如果是负的话,那就说明这两个变量变化方向是相反的

同样我们可以求出来另外两个的协方差

然后我们的协方差矩阵就是这种形式,带入数据,我们就可以分析各个数据之间的关系了

然后我们再可以扩展一下,在扩展之前,我们分析一下

如何通过矩阵的运算来计算协方差

首先我们去求一个过渡矩阵

我们可以知道a矩阵的后面两个矩阵相乘再乘三分之一就是一个求平均值

计算一下,其实就是对应的,通过这样的方法我们就能算出来协方差矩阵了

这里我们给出了15个队员,然后右边的就是他们的协方差矩阵,我们先看对角线的数据

可以看到他们之间的方差变化是蛮大的

也就是说如果想成为射手的话,并不局限于身高和体重,年龄的跨度也是比较大的,19.4的方差相当于有四岁多的标准差,±4岁也就是8岁,跨度也是不少的,所以说一个射手的年龄关系不是特别大。

首先我们看体重跟身高,首先就是29.75,说明体重跟身高是非常正相关的,随着身高增加体重也增加,然后我们看年龄跟体重,年龄跟身高,他们之间的相关性非常小。说明对于这些运动员来说

 他们的身高体重年龄就没有太多的关系。

状态空间表达

现代控制理论就是以状态空间为基础的,有兴趣可以看这个up主的视频

【Advanced控制理论】1_介绍_哔哩哔哩_bilibili

这里我们给出最基础的概念

例子

一个弹簧阻尼系统,质量为m,向右施加的力为F,向右的方向是x,弹簧的胡克系数是k,B是他的阻尼系数。他的动态方程如下图所示

然后我们可以把F定义为u,也就是系统的输入。

首先我们把他化成状态空间的表达式就是首先要确定两个状态变量

然后做一个等量代换,就用两个一阶微分方程把这个形式表达出来了。

如果我们这里还有测量量,我们可以把它定义为Z1,测的是他的位置,Z2测的就是它的速度

然后我们把上面的4个式子用矩阵的方式紧凑的表达出来

我们就去填一个数

根据上面的式子可以得到

而测量的方程就可以这样表达

完整的表达

这就是状态空间的表达形式

我们可以归纳一下(蓝字)

这就是一种连续的表达形式

我们可以看到状态变量的方程哪里有对Xt的导数,体现了随时间的变化

如果我们将其写成离散的形式,每相隔一个时刻来看一下这个变化的话,就可以写成这样的形式

这里的下标k,k-1,k+1每一个单位1都代表了一个时间单位,叫做sample time(采样时间)也代表了一种变化趋势

从离散型到连续型并不是照抄上面的矩阵结果,需要根据采样时间来进行计算(不是这次重点讨论的结果,只需要记得基本的概念),体现的是一种变化,从上一步到这一步的变化。

然后我们回到之前的讲过的

数据融合的例子

我们知道世界中,充满了不确定性,比如我们的模型不准确,这时候我们就可以加一点不确定性,加一个w_{k-1},在测量当中我们也可以加上v_{k},这是在测量当中产生的不确定性。现在我们就是有了两个不确定性,也就是说模型也不准确,测出来的值也不准确。

在这两个都不准确的情况下,如何去测量一个精确的\hat{x}_{k}呢?

这就是我们卡尔曼滤波器去解决的问题

我们现在遇到的情况跟之前的也是差不多的,只不过我们现在是一个不太准的计算结果和一个不太准的测量结果,我们要根据这两个结果来估计出来一个相对准确的值。来找到一个比他们两个误差都要小的结果,这也就是我们后面要重点分析的。

卡尔曼滤波详细数学推导

引入概念

期望是什么?

在统计学和概率论中,"期望"是一个随机变量的平均值,表示该随机变量的平均预期结果。在离散随机变量的情况下,期望可以通过对所有可能取值的概率加权平均得到。在连续随机变量的情况下,期望则是对变量的值乘以其概率密度函数(PDF)进行积分得到。

设随机变量为X,它的取值为{x1, x2, ..., xn},对应的概率为{p1, p2, ..., pn},则X的期望E(X)可以表示为:

E(X) = x1p1 + x2p2 + ... + xn*pn

换句话说,期望就是所有可能取值的加权平均值。

例如,假设有一个掷骰子的游戏,骰子的点数为1到6,每个点数出现的概率都是1/6。那么掷骰子的期望就是:

E(X) = (11/6) + (21/6) + (31/6) + (41/6) + (51/6) + (61/6) = 3.5

这表示掷骰子的平均预期点数为3.5。

方差是什么?

方差是衡量随机变量离散程度的一个统计量,它表示随机变量与其期望值之间的偏离程度。如果一组数据的方差较大,则说明数据的离散程度较高;反之,方差较小则说明数据较为集中。

可以跟着一起拿纸算一下,在之前我们了解了状态空间方程的表达形式,借此来描述一个系统的动态响应

这里面我们x_{k}是他的状态变量,A是他的状态矩阵,B是控制矩阵,u_{k-1}是控制,w_{k-1}是过程噪声,然后过程噪声是我们不可测的,也是我们没有办法掌握的一个内容,因为他是一个不确定性的表现,在自然界我们一般将其假设为符合正态分布,也就是他的概率分布。

他的概率分布就是也就是概率分布p(w),0代表了它的期望,Q代表了他的协方差矩阵

然后Q又等于w乘w的转置

这个公式是怎么来的呢? 我们用简单的例子说明一下

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1515664.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++进阶--mep和set的模拟实现

红黑树链接入口 底层容器 模拟实现set和map时常用的底层容器是红黑树。 红黑树是一种自平衡的搜索二叉树,通过对节点进行颜色标记来保持平衡。 在模拟实现set和map时,可以使用红黑树来按照元素的大小自动排序,并且保持插入和删除操作的高效…

缓冲区与C库函数的实现

目录 一、缓冲区 二、C库函数的实现 一、缓冲区 缓冲区本质就是一块内存,而缓冲区存在的意义本质是提高使用者(用户)的效率【把缓冲区理解成寄送包裹的菜鸟驿站】 缓冲区的刷新策略 1. 无缓冲(立即刷新) 2. 行缓冲(行刷新) 3. 全缓冲(缓冲区满了,再刷…

三. 操作系统 (6分) [理解|计算]

🌟三. 操作系统 (6分) [理解|计算] PV操作, 分页存储管理, 文件的索引, 位示图 考试重点 文章目录 🌟三. 操作系统 (6分) [理解|计算]==PV操作, 分页存储管理, 文件的索引, 位示图 考试重点==3.1 进程管理3.2 存储管理3.3 设备管理3.4 文件管理3.1 进程管理 进程的特征 进…

部署docker仓库harbor

1、下载包 1、包已上传有两个harbor.v2.6.0.tar与harbor.tar 2、harbor.tar解压后会生成harbor目录,将harbor.v2.6.0.tar移动到harbor目录下。 3、执行harbor目录下的install.sh 4、执行完后修改配置文件 2、修改配置文件 vim /root/harbor/make/ harbor.yml.tmpl …

【JAVA】CSS3:3D、过渡、动画、布局、伸缩盒

1 3D变换 1.1 3D空间与景深 /* 开启3D空间,父元素必须开启 */transform-style: preserve-3d;/* 设置景深(你与z0平面的距离 */perspective:50px; 1.2 透视点位置 透视点位置:观察者位置 /* 100px越大,越感觉自己边向右走并看,…

亚信安慧AntDB:系统稳定性的守护

在国产化升级改造的过程中,AntDB不断地适应不同的需求,为用户提供个性化的解决方案。其致力于确保数据安全和系统稳定,预防数据泄露和系统崩溃等问题的发生。AntDB的团队不仅专注于技术的提升和创新,更关注用户的实际需求&#xf…

Docker 笔记(五)--链接

这篇笔记记录了Docker 的Link。 官方文档: Legacy container links - Communication across links 目录 参考Legacy container linksConnect using network port mappingConnect with the linking systemThe importance of naming Communication across linksEnviro…

《IAB视频广告标准:综合指南(2022)》之概述篇 - 我为什么要翻译介绍美国人工智能科技公司IAB 系列(2)

IAB平台,使命和功能 IAB成立于1996年,总部位于纽约市。 作为美国的人工智能科技巨头社会媒体和营销专业平台公司,互动广告局(IAB- the Interactive Advertising Bureau)自1996年成立以来,先后为700多家媒体…

漫步者、南卡、Oladance开放式耳机怎么样?巅峰测评谁是公认力作

​最近朋友们经常向我询问开放式耳机的选择问题,他们购买了开放式耳机后发现音质不佳,上耳佩戴舒适性几乎为零。市面上的开放式耳机琳琅满目,大家不知道该如何选择。漫步者、南卡、Oladance开放式耳机怎么样?我作为音乐爱好者已经…

Java实现PDF文字内容识别,结合OCR实现PDF图片实现

使用插件:UMI-OCR、PDFBOX 实现思路:通过PDFBOX识别PDF文字,如果是图片,则识别不出来,再调用OCR进行识别返回文字;OCR识别较慢,长图识别不出来,目前HTTP方式只支持图片格式&#xf…

变量柱塞液压泵比例阀放大器

液压泵把动力机的能转换成液压的压力能。使用在开式和闭式系统里在固定和移动的设备上,通过电比例放大器控制比例阀线圈驱动液流方向压力流量。BEUEC比例放大器适用控制方式:电比例控制(12VDC、24VDC),控制闭式泵系列4…

消费补贴模式,刺激消费需求,重塑商业格局

​小编介绍:10年专注商业模式设计及软件开发,擅长企业生态商业模式,商业零售会员增长裂变模式策划、商业闭环模式设计及方案落地;扶持10余个电商平台做到营收过千万,数百个平台达到百万会员,欢迎咨询。 在…

小明的背包——01背包问题

经典版 题目链接:1.小明的背包1 - 蓝桥云课 (lanqiao.cn) 01背包问题中,每种物品只有两种状态,即拿或不拿。设状态dp[i][j]max(dp[i-1][j],dp[i-1][j-w]v);如果不拿物品i,那么最大价值就是dp[i-1][j],如果…

【软件工具】网络性能测试工具 Iperf

Iperf 是一款专业的开源网络性能测试工具,它被广泛用于测量网络带宽、延迟、抖动和数据包丢失等网络性能指标,支持 TCP 和 UDP 等,可用于点对点或客户端-服务器等模式的网络测试。 软件获取 官方下载地址:https://iperf.fr/iper…

最新若依项目快速上手

最新若依项目快速上手 配套视频:若依项目快速上手视频 1. 下载源码 官网:https://ruoyi.vip/ 前端 git clone https://github.com/yangzongzhuan/RuoYi-Vue3.git后端 git clone https://gitee.com/y_project/RuoYi-Vue.git2. 数据库 创建数据库ry-vue…

Day32:安全开发-JavaEE应用Servlet路由技术JDBCMybatis数据库生命周期

目录 JavaEE-HTTP-Servlet&路由&周期 JavaEE-数据库-JDBC&Mybatis&库 思维导图 Java知识点: 功能:数据库操作,文件操作,序列化数据,身份验证,框架开发,第三方库使用等. 框架…

在线编辑字体工具,支持对字体查看编码以及编辑

公司一个沉寂多年的项目需要进行二开,前面的开发的同学已经离开,对于项目情况了解较少,开发的时候发现缺失很多小图标,但是对原来有那些图标也不太了解 目标 1、知晓字体包里的旧的图标是什么样子的?2、在旧字体包中导…

图像处理与图像分析—图像统计特性的计算(纯C语言实现灰度值显示)

根据输入的灰度图像,分别计算图像的均值、方差等统计特征,并计算图像的直方图特征并以图形方式显示图像的直方图(用C或C语言实现)。 学习将会依据教材图像处理与图像分析基础(C/C)版内容展开 在上个笔记中&…

hdml接口无信号,设备管理器报错:由于该设备有问题,Windows 已将其停止。 (代码 43)

今天,由于带电脑外出演示系统,回公司突然hdml接口无信号了,试了同事的电脑没问题,所以排除显示器和线束问题,最后找到设备管理器报错:由于该设备有问题,Windows 已将其停止。 (代码 43)以下是排…

学生时期学习资源同步-1 第一学期结业考试题6

原创作者:田超凡(程序员田宝宝) 版权所有,引用请注明原作者,严禁复制转载