深度解读卡尔曼滤波原理

上传人:daj****de2 文档编号:193588382 上传时间:2023-03-11 格式:DOCX 页数:15 大小:464.38KB
返回 下载 相关 举报
深度解读卡尔曼滤波原理_第1页
第1页 / 共15页
深度解读卡尔曼滤波原理_第2页
第2页 / 共15页
深度解读卡尔曼滤波原理_第3页
第3页 / 共15页
点击查看更多>>
资源描述
什么是卡尔曼滤波?你可以在任何含有不确定信息的动态系统中使用卡尔曼滤波,对系统 下一步的走向做出有根据的预测,即使伴随着各种干扰,卡尔曼滤波总是 能指出真实发生的情况。在连续变化的系统中使用卡尔曼滤波是非常理想的,它具有占用内存 小的优点(除了前一个状态量外,不需要保留其它历史数据),并且速度很 快,很适合应用于实时问题和嵌入式系统。实际上,如果以正确的方式看待它,卡尔曼滤波是非常简单和容易理 解的,下面我将用漂亮的图片和色彩清晰的阐述它,你只需要懂一些基本 的概率和矩阵的知识就可以了。我们能用卡尔曼滤波做什么?用玩具举例:你开发了一个可以在树林里到处跑的小机器人,这个机 器人需要知道它所在的确切位置才能导航。我们可以说机器人有一个状态,表示位置和速度:nt注意这个状态只是关于这个系统基本属性的一堆数字,它可以是任何 其它的东西。在这个例子中是位置和速度,它也可以是一个容器中液体的 总量,汽车发动机的温度,用户手指在触摸板上的位置坐标,或者任何你 需要跟踪的信号。这个机器人带有GPS,精度大约为10米,还算不错,但是,它需要将 自己的位置精确到10米以内。树林里有很多沟壑和悬崖,如果机器人走 错了一步,就有可能掉下悬崖,所以只有 GPS是不够的。或许我们知道一些机器人如何运动的信息:例如,机器人知道发送给 电机的指令,知道自己是否在朝一个方向移动并且没有人干预,在下一个 状态,机器人很可能朝着相同的方向移动。当然,机器人对自己的运动是 一无所知的:它可能受到风吹的影响,轮子方向偏了一点,或者遇到不平 的地面而翻倒。所以,轮子转过的长度并不能精确表示机器人实际行走的 距离,预测也不是很完美。GPS传感器告诉了我们一些状态信息,我们的预测告诉了我们机器人 会怎样运动,但都只是间接的,并且伴随着一些不确定和不准确性。但 是,如果使用所有对我们可用的信息,我们能得到一个比任何依据自身估 计更好的结果吗?回答当然是YES,这就是卡尔曼滤波的用处。卡尔曼滤波是如何看到你的问题的下面我们继续以只有位置和速度这两个状态的简单例子做解释。我们并不知道实际的位置和速度,它们之间有很多种可能正确的组合,但其中一些的可能性要大于其它部分:卡尔曼滤波假设两个变量(位置和速度,在这个例子中)都是随机的,并且服从高斯分布。每个变量都有一个均值U,表示随机分布的中心(最可能的状态),以及方差。2,表示不确定性。在上图中,位置和速度是不相关的,这意味着由其中一个变量的状态 无法推测出另一个变量可能的值。下面的例子更有趣:位置和速度是相关 的,观测特定位置的可能性取决于当前的速度:这种情况是有可能发生的,例如,我们基于旧的位置来估计新位置。 如果速度过高,我们可能已经移动很远了。如果缓慢移动,则距离不会很远。跟踪这种关系是非常重要的,因为它带给我们更多的信息:其中一个 测量值告诉了我们其它变量可能的值,这就是卡尔曼滤波的目的,尽可能 地在包含不确定性的测量数据中提取更多信息!这种相关性用协方差矩阵来表示,简而言之,矩阵中的每个元素工表示第i个和第j个状态变量之间的相关度。(你可能已经猜到协方差所以在时刻使用矩阵来描述问题我们基于高斯分布来建立状态变量矩阵是一个对称矩阵,这意味着可以任意交换 i和j)。协方差矩阵通常 用“工”来表示,其中的元素则表示为“工”。最佳估计一(即均值,其它地方常用u表示),k需要两个信息:以及协方差矩阵;position,refocity(1)(当然,在这里我们只用到了位置和速度,实际上这个状态可以包含 多个变量,代表任何你想表示的信息)。接下来,我们需要根据当前状态 (k-1时刻)来预测下一状态(k时刻)。记住,我们并不知道对下一状态的 所有预测中哪个是“真实”的,但我们的预测函数并不在乎。它对所有的 可能性进行预测,并给出新的高斯分布。它将我们原始估计中的每个点都移动到了一个新的预测位置,如果原始估计是正确的话,这个新的预测位置就是系统下一步会移动到的位置。那我们又如何用矩阵来预测下一个时刻的位置和速度呢 ?下面用一个基本 的运动学公式来表示:Pk = Pk-i +3 = m(?)现在,我们有了一个预测矩阵来表示下一时刻的状态,但是,我们仍 然不知道怎么更新协方差矩阵。此时,我们需要引入另一个公式,如果我 们将分布中的每个点都乘以矩阵 A,那么它的协方差矩阵工会怎样变化 呢?很简单,下面给出公式:16(*) = C*5j(Ae) ASAr结合方程和得到:危=风相(5)PFkPiFf)外部控制量我们并没有捕捉到一切信息,可能存在外部因素会对系统进行控制, 带来一些与系统自身状态没有相关性的改变。以火车的运动状态模型为例,火车司机可能会操纵油门,让火车加 速。相同地,在我们机器人这个例子中,导航软件可能会发出一个指令让- 轮子转向或者停止。如果知道这些额外的信息,我们可以用一个向量UA来表示,将它加到我们的预测方程中做修正。假设由于油门的设置或控制命令,我们知道了期望的加速度a,根据基本的运动学方程可以得到:P* = pk-1 十 A询A1 + ;Vk =以矩阵的形式表示就是:十5 + $“=F 鬲t +B&Bk称为控制矩阵,口卜称为控制向量(对于没有外部控制的简单系统来 说,这部分可以忽略)。让我们再思考一下,如果我们的预测并不是100%准确的,该怎么办呢? 外部干扰如果这些状态量是基于系统自身的属性或者已知的外部控制作用来变 化的,则不会出现什么问题。但是,如果存在未知的干扰呢?例如,假设我们跟踪一个四旋翼飞行 器,它可能会受到风的干扰,如果我们跟踪一个轮式机器人,轮子可能会 打滑,或者路面上的小坡会让它减速。这样的话我们就不能继续对这些状 态进行跟踪,如果没有把这些外部干扰考虑在内,我们的预测就会出现偏 差。在每次预测之后,我们可以添加一些新的不确定性来建立这种与“外 界”(即我们没有跟踪的干扰)之间的不确定性模型:原始估计中的每个状态变量更新到新的状态后,仍然服从高斯分布。我们可以说士白【的每个状态变量移动到了一个新的服从高斯分布的区域,协方差为Qk。换句话说就是,我们将这些没有被跟踪的干扰当作协方差为 Qk的噪声来处理。这产生了具有不同协方差(但是具有相同的均值)的新的高斯分布。我们通过简单地添加Qk得到扩展的协方差,下面给出预测步骤的完整 表达式:由上式可知,新的最优估计是根据上一最优估计预测得到的,并加上 已知外部控制量的修正。而新的不确定性由上一不确定性预测得到,并加上外部环境的干扰。好了,我们对系统可能的动向有了一个模糊的估计,用 志由和Pk来表示。如果再结合传感器的数据会怎样呢?用测量值来修正估计值我们可能会有多个传感器来测量系统当前的状态,哪个传感器具体测 量的是哪个状态变量并不重要,也许一个是测量位置,一个是测量速度, 每个传感器间接地告诉了我们一些状态信息。注意,传感器读取的数据的单位和尺度有可能与我们要跟踪的状态的 单位和尺度不一样,我们用矩阵Hk来表示传感器的数据。我们可以计算出传感器读数的分布,用之前的表示方法如下式所示:卡尔曼滤波的一大优点就是能处理传感器噪声,换句话说,我们的传 感器或多或少都有点不可靠,并且原始估计中的每个状态可以和一定范围 内的传感器读数对应起来。从测量到的传感器数据中,我们大致能猜到系统当前处于什么状态。 但是由于存在不确定性,某些状态可能比我们得到的读数更接近真实状 态。我们将这种不确定性(例如:传感器噪声)用协方差Rk表示,该分布的 均值就是我们读取到的传感器数据,称之为冒。现在我们有了两个高斯分布,一个是在预测值附近,一个是在传感器 读数附近。我们必须在预测值(粉红色)和传感器测量值(绿色)之间找到最优解。 那么,我们最有可能的状态是什么呢?对于任何可能的读数(z1,z2),有两种情况:(1)传感器的测量值;(2)由前一状态得到的预测值。如果我 们想知道这两种情况都可能发生的概率,将这两个高斯分布相乘就可以 了。剩下的就是重叠部分了,这个重叠部分的均值就是两个估计最可能的值,也就是给定的所有信息中的最优估计。瞧!这个重叠的区域看起来像另一个高斯分布。如你所见,把两个具有不同均值和方差的高斯分布相乘,你会得到一 个新的具有独立均值和方差的高斯分布!下面用公式讲解。融合高斯分布先以一维高斯分布来分析比较简单点,具有方差。2和U的高斯曲 线可以用下式表示:如果把两个服从高斯分布的函数相乘会得到什么呢?w)= N0 心 crr)H1卜身抑槌半心= e wKlie娜 wwrioirtCC(11)(12)闵将式(9)代入到式(10)中(注意重新归一化,使总概率为1)可以得到:企2 ff0将式(11)中的两个式子相同的部分用 k表示:k一听涉=囱+k(#L出) 成”3一 kfj-QI下面进一步将式(12)和(13)写成矩阵的形式,如果S表示高斯分布的协方差,表示每个维度的均值,则:K=E0(S0 + i)T(14)正二 M + K(MM)(15)= Sa- KE0矩阵K称为卡尔曼增益,下面将会用到。放松!我们快要完成了 !将所有公式整合起来我们有两个高斯分布,预测部分0.: :H出.瓦P*田;,和测 量部分贝1,芸 悬S,将它们放到式(15)中算出它们之间的重叠部 分:H成=H囱由式(14)可得卡尔曼增益为:+K(京-H鬲)-KHmHf(16)将式(16)和式(17)的两边同时左乘矩阵的逆(注意K里面包含了 H)将 其约掉,再将式(16)的第二个等式两边同时右乘矩阵HTk的逆得到以下等(19)左;=十K*(尿一瓦血)KJRHf (瓦 + 敬尸上式给出了完整的更新步骤方程。克冲就是新的最优估计,我们可以将它和 放到下一个预测和更新方程中不断迭代。林Mem filter |施6册/ 口。时总结以上所有公式中,你只需要用到式(7)、(18)、(19)。(如果忘了的 话,你可以根据式(4)和(15)重新推导一下)我们可以用这些公式对任何线性系统建立精确的模型,对于非线性系 统来说,我们使用扩展卡尔曼滤波,区别在于EKF多了一个把预测和测量部分进行线性化的过程。
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 图纸设计 > 毕设全套


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!