卡尔曼滤波模型及Matlab模型建立

2023-05-16

目录

一、卡尔曼滤波

1.概念解析:

2.卡尔曼滤波的最优估计模型

3.实例——小车匀加速直线运动

4.Matlab建模

 二、扩展卡尔曼滤波(EKF:Extended KAlman Filter)

1.非线性系统的局部线性化

2.扩展卡尔曼滤波模型


一、卡尔曼滤波

        卡尔曼滤波的目的:由于人的主观认识(数学模型的建立而产生的理论状态值)和测量(传感器等测量值)都不准确,引入卡尔曼滤波,综合两者的误差,得到最优的对于真实值的预测。

1.概念解析:

        对于已知状态空间表达\left\{\begin{matrix} x_{k}=Ax_{k-1}+Bu_{k-1}+w_{k-1})(1)\\ z_{k}=Hx_{k-1}+v_{k}(2) \end{matrix}\right.线性系统,通过递归算法,基于对下一时刻状态估计误差与观测器的测量误差数据融合得到下一时刻状态的最优预测值

        其中,引入估计误差的协方差矩阵P表征状态变量之间的相关性;引入系统误差w和观测误差v表征在预测及测量过程中会存在偏差的实际情况。由于任何外部状态通常呈现正态分布,假设w\sim N(0,Q),v\sim N(0,R)(即w服从以0为期望,Q为协方差矩阵的正态分布;v服从以0为期望,R为协方差矩阵的正态分布)。

        状态方程中,x_{k}表示第k时刻的状态量,u_{k}表示第k时刻的输入量,z_{k}表示k时刻的观测值,矩阵H为观测矩阵。

概念框图:

2.卡尔曼滤波的最优估计模型

        1)预测:①先验\widehat{x_{k}^{-}}=A\widehat{x_{k-1}}+Bu_{k-1}

                        ②先验误差协方差P_{k}^{-}=AP_{k-1}A^{T}+Q

        2)  校正:①卡尔曼增益K_{k}=\frac{P_{k}^{-}H^{T}}{HP_{k}^{-}H^{T}+R}

                        ②后验估计\widehat{x_{k}}=\widehat{x_{k}^{-}}+K_{k}(z_{k}-H\widehat{x_{k}^{-}})

                        ③更新误差协方差P_{k}=P_{k}^{-}-K_{k}HP_{k}^{-}=(I-K_{k}H)P_{k}^{-}

        公式推导详见:(DR_CAN老师讲解的所有系列都超级推荐!!!)【卡尔曼滤波器】3_卡尔曼增益超详细数学推导 ~全网最完整_哔哩哔哩_bilibili

        简单解释:①k时刻的先验估计为上一时刻的最优预测值;

                        ②误差协方差矩阵P用来描述该时刻状态变量间的联系;Q为噪音矩阵,意思是变量间关系也受外界影响;

                         ③R为观测矩阵,卡尔曼增益的大小取决于系统变量间的关系(协方差矩阵P)及观测器的性能(H、R)

                        ④后验估计值对观测结果的依赖程度体现在K_{k},目的是让最优估计值的方差更小

                        ⑤每一帧状态变量改变后,变量间的关系随之改变,故P_{k}要时刻更新。

3.实例——小车匀加速直线运动

 

4.Matlab建模

        假设模型参数:过程预测噪声的协方差矩阵Q=\begin{bmatrix} 1 &0 \\ 0&1 \end{bmatrix},

观测噪声的协方差矩阵R=\begin{bmatrix} 1 &0 \\ 0&1 \end{bmatrix},状态方程中A=\begin{bmatrix} 1 &1 \\ 0&1 \end{bmatrix},B=\begin{bmatrix} \frac{1}{2}\\ 1 \end{bmatrix},观测矩阵H=\begin{bmatrix} 1 &0 \\ 0&1 \end{bmatrix}

        初始状态:X_{0}=\begin{bmatrix} 0 & 1 \end{bmatrix}\widehat{X_{0}}=\begin{bmatrix} 0 & 1 \end{bmatrix}P_{0}=\begin{bmatrix} 1 &0 \\ 0&1 \end{bmatrix},则代码如下:

%%先对不同变量进行定义
    %Q为过程预测噪声的协方差矩阵
    %R为观测噪声协方差矩阵
    %状态变量X=[p v],p为小车的位置,v为速度;输入u为加速度(=外力/质量)
    %X为实际状态
    %X_bar 为先验估计
    %Xbar为后验估计,最优估计值
    %P_为先验估计误差的协方差矩阵
    %P为后验估计误差的协方差矩阵
    %Z为观测量
    %K为卡尔曼增益
    
%%定义超参数
over = 50;%指定循环的遍数,即预测50s内的运动
Q = [0.1 0;0 0.1];%假设的过程预测噪声的协方差矩阵(实际上是一个变量,很难得到)
R = [1 0;0 1];%假设的观测噪声协方差矩阵(实际上也是变量,但是可以得到)

%定义尺寸参数
T = [over,2];%定义over行2列(2维状态)的矩阵,用于记录所有时刻的预测状态
delta_t = 1;%时间间隔

%假设小车为匀加速运动,加速度为1
u = 1;

%建立预测模型
A = [1 delta_t;0 1];
B = [(delta_t^2)/2;delta_t];

H =[1 0;0 1];%假设观测值的观测矩阵

I = [1 0;0 1];%定义单位矩阵

%初始化参数,由于Kk、Pk为二维矩阵,故包含所有迭代数据的K、P均为2行T列矩阵
X = zeros(T);
X_bar = zeros(T);
Xbar = zeros(T);
Z = zeros(T);
K = zeros([2*over,2]);
P = zeros([2*over,2]);
P_ = zeros([2*over,2]);

%在t=0时刻的初始值
P(1:2,:)=[1 0; 0 1];%初始前两行协方差矩阵为[1 0;0 1],表示状态变量间相互独立
X(1,:) = [0 1];%实际状态初始值,即假设初始位置为0,初始速度为1
Xbar(1,:) = [0 1];%状态预测量的初始值;my error:①Xbar(1)表示矩阵的第一个元素②Xbar(1,:)可以表示第一行,注意是冒号:

%%卡尔曼滤波的核心算法
for n = 2:over
    %计算X的实际值:X(k)=AX(k-1)+W
    w1 = normrnd(0,sqrt(Q(1)),[1,1]);%w1是以0为均值,Q矩阵第一个元素的开方为标准差的服从正态分布的随机数
    w2 = normrnd(0,sqrt(Q(4)),[1,1]);%w2是以0为均值,Q矩阵右下方元素的开方为标准差的服从正态分布的随机数
    W = [w1 w2];%过程估计误差矩阵
    Tmp1 = A*X(n-1,:)'+B*u+W';
    X(n,:) = Tmp1';%在t=n时刻的状态实际值X(n)
    
    %计算状态的观测值:Z(k)=HX(k)+V
    v1 = normrnd(0,sqrt(R(1)),[1,1]);%v1是以0为均值,R矩阵左上角元素的开方为标准差的服从正态分布的随机数
    v2 = normrnd(0,sqrt(R(4)),[1,1]);%v2是以0为均值,R矩阵右下方元素的开方为标准差的服从正态分布的随机数
    V = [v1 v2];%观测误差矩阵
    Tmp2 = H*X(n,:)'+V';
    Z(n,:) = Tmp2';%在t=n时刻的状态观测值Z(n)
    
    %先验预测:X_bar(k)=AXbar(k-1)+Bu(k-1)
    Tmp3 = A*Xbar(n-1,:)'+B*u;%更新先验估计,k时刻的先验模型为上一时刻(k-1)的状态最优模型;注意计算时用X与u的转置,因为状态方程中状态x与输入u是列向量
    X_bar(n,:) = Tmp3';
    
    P_(((2*n-1):(2*n)),:) = A*P(((2*n-3):(2*n-2)),:) *A'+Q;%更新先验估计误差协方差:P_bar(k)=A*Pbar(k)*A'+Q
    
    %后验校正
    %卡尔曼增益
    K(((2*n-1):(2*n)),:) = P_(((2*n-1):(2*n)),:)*H'/(H*(P_(((2*n-1):(2*n)),:)*H' + R));
    %后验估计预测值:Xbar(k)=X_bar(k)+K(Z(k)-H*X_bar(k))
    Tmp4 = X_bar(n,:)' + K(((2*n-1):(2*n)),:)*(Z(n,:)'-H*X_bar(n,:)');
    Xbar(n,:) = Tmp4';
    
    P(((2*n-1):(2*n)),:) = (I-K(((2*n-1):(2*n)),:)*H)*P_(((2*n-1):(2*n)),:);%协方差矩阵P(k)更新:P(k)=(I-KH)*P_bar(k)
end

%%绘图
figure
LineWidth = 2;
%分裂窗口为2*1个子窗口
%位置曲线图
subplot(2,1,1)
plot(Z(:,1),'k-')%画出测量值
hold on;

plot(Xbar(:,1),'b-')%画出最优估计值
hold on;

plot(X(:,1),'y-')%画出实际状态值
hold on;
title('位置状态曲线')

legend('位置测量值','位置最优估计值','实际位置')%同一图像中包含多条曲线时,依次加标注
%速度曲线图
subplot(2,1,2)
plot(Z(:,2),'k-')%画出测量值
hold on;

plot(Xbar(:,2),'b-')%画出最优估计值
hold on;

plot(X(:,2),'y-')%画出实际状态值
hold on;
title('速度状态曲线')

legend('速度测量值','速度最优估计值','实际速度')

运行的状态曲线为:

 

 

注:Q,R的数值不断调整,得到的估计效果不同

        参数寻优:使最优估计值更好地拟合实际值。

 二、扩展卡尔曼滤波(EKF:Extended KAlman Filter)

        对于非线性系统,其状态空间不能表示为x_{k}=Ax_{k-1}+Bu_{k-1}的形式,则上述卡尔曼滤波模型不成立,并且正态分布的随机变量经过非线性系统的处理后,不再满足正态分布(Q,R也应作相应改变)。

1.非线性系统的局部线性化

        在操作点附近进行局部线性化(泰勒展开),得到非线性系统的最优预测模型——扩展卡尔曼滤波模型:

        对于系统\left\{\begin{matrix} x_{k}=f(x_{k-1},u_{k-1},w_{k-1})\\ z_{k}=h(x_{k},v_{k}) \end{matrix}\right.,f、h均为非线性函数

                由于系统存在估计和观测等误差,无法在真实点进行线性化,模型中选取f在(k-1)时刻的后验估计点\widehat{x_{k-1}}处进行线性化:

f(x_{k})=f(\widehat{x_{k-1}},u_{k-1},w_{k-1})+A_{k-1}(x_{k}-\widehat{x_{k-1}})+W_{k-1}w_{k-1}

z_{k}=h(\widetilde{x_{k}},v_{k})+H_{k}(x_{k}-\widetilde{x_{k}})+V_{k}v_{k}

                其中,\widetilde{x_{k}}为估计误差为0时的预测点,即\widetilde{x_{k}}=f(\widehat{x_{k-1}},u_{k-1},0);矩阵A_{k},W_{k},H_{k},V_{k}均为雅克比矩阵做系数矩阵,且随k变化而时刻更新

                A_{k-1}=\frac{\partial f}{\partial x}|_{(\widehat{x_{k-1}},u_{k-1})},W_{k-1}=\frac{\partial f}{\partial w}|_{(\widehat{x_{k-1}},u_{k-1})},H_{k}=\frac{\partial h}{\partial x}|_{\widetilde{x_{k}}},V_{k}=\frac{\partial h}{\partial v}|_{\widetilde{x_{k}}}

        综上,得到的线性系统为:

\left\{\begin{matrix} x_{k}=\widetilde{x_{k}}+A_{k-1}(x_{k}-\widehat{x_{k-1}})+W_{k-1}w_{k-1}\\z_{k}=\widetilde{z_{k}}+H_{k}(x_{k}-\widetilde{x_{k}})+V_{k}v_{k} \end{matrix}\right.

        其中,w_{k}\sim N(0,Q),v_{k}\sim N(0,R).

        对w_{k},v_{k}做线性变换的W_{k-1}w_{k-1},V_{k}v_{k}仍满足正态分布,即W_{k}w_{k}\sim N(0,WQW^{T})V_{k}v_{k}\sim N(0,VRV^{T})

2.扩展卡尔曼滤波模型

        将线性化后的模型代入卡尔曼滤波模型,有:

(推荐大家观看b站up主:DR_CAN  的视频,并和我一起交流学习经验,欢迎批评指正!!)

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

卡尔曼滤波模型及Matlab模型建立 的相关文章

随机推荐

  • python并行运算

    并行运算 Python有多种方法可以进行并行计算 xff0c 以下是其中几种常见的方法 xff1a 多进程 xff1a Python中的multiprocessing模块提供了多进程的支持 xff0c 可以使用Process类来创建新进程
  • python的格式str.format

    下面是一些常用的格式化规则 对齐规则 使用 lt 或 gt 分别表示左对齐 居中对齐和右对齐 宽度规则 使用一个整数表示输出结果的宽度 精度规则 使用 加一个整数表示浮点数的小数点后的位数 类型规则 使用一个字符来指定输出结果的类型 常用的
  • apt 和 apt-get 区别

    文章目录 1 apt 的由来2 apt 和 apt get 的区别3 应该使用 apt 还是 apt get xff1f 1 apt 的由来 Ubuntu Linux Mint和elementary OS 等发行版的 Linux 均是基于D
  • 你是我的眼:水哥王昱珩带你重新打量这世界

    水哥 王昱珩在 最强大脑 舞台上凭借着 微观辨水 一战成名 在节目中 xff0c 他以1秒四杯的速度从520杯同质同量同水源的水中 xff0c 迅速找出了之前被随机选中的那杯 xff0c 甚至看出了这杯水从被选中拿起观察再到放回原位 xff
  • 性能优化与内存优化

    性能优化 主要以这四个方向进行优化 xff1a 稳定流畅耗损apk 瘦身 稳定 避免内存溢出异常捕获反馈机制 流畅 卡顿的原因 xff1a 布局复杂动画过多View 的过度绘制UI 耗时操作频繁 GC 耗损 减少没必要的网络访问或合并相关网
  • (2)工作空间

    工作空间 特点创建工作空间编译添加环境变量 特点 1 工作空间的主要作用是存放工程文件和文件代码 xff08 存放工作空间和代码的一个文件夹 xff09 2 ROS的开发依赖于工作空间 3 编写源代码 编译都是在工作空间下完成的 4 一般工
  • 工程伦理 清华大学 MOOC 期末答案 2020冬

    前言 xff1a 答案是本人自己查阅 不保证其完全正确性 xff0c 仅供参考 点个赞再走呗 xff1a xff09 1 单选题 1分 以下不属于安全文化的核心的是 D A 人的安全知识 B 人的安全意识 C 人的安全技能 D 人的安全装备
  • HTML移动端的基本了解

    文章目录 前言 一 PC端与移动端的区别 PC端 xff1a 移动端 xff1a 二 视口 布局视口 视觉视口 理想视口 meta视口标签 三 二倍图 四 移动端开发选择 单独制作移动端页面 主流 响应式页面兼容移动端 其次 总结 前言 分
  • 树莓派4B(armv7l,arm32)buster部署英特尔第二代神经计算棒,示例:运行darknet-yolov4-tiny

    记录整个部署的步骤 英特尔第二代神经计算棒 xff08 Intel NCS2 xff09 的使用需要到OpenVINO官网下载安装某一个版本的软件 xff0c 目前是支持Windows Linux和树莓派的Raspbian OS 下面贴出来
  • 树莓派结合英特尔神经计算棒二代(NCS2)的openvino包部署人工智能应用

    利用树莓派和英特尔神经计算棒二代 xff08 NCS2 xff09 进行边缘端AI硬件平台部署三部曲 xff1a 二 xff09 树莓派4B和NCS2配置时cmake编译报错以及import error can t find moudle
  • 树莓派报错“Cannot currently show the desktop”的完美解决办法

    最近在利用树莓派部署神经网络的时候出现了一些大大小小的问题 xff0c 很多问题都可以在网上直接或间接地找到答案 xff0c 但有个别问题即使按照网上的高赞博客说的去做了仍然没用 笔者根据最近遇到的有关树莓派VNC win10远程桌面连接
  • Nvidia Jetson XAvier NX开发套件从装机到pytorch环境搭建YoloV5+DeepSort+TensorRT

    目录 1 刷机与装机1 1 准备VMware工作站和linux的unbuntu16 04虚拟机 xff1a 1 2 将SD上的系统移动至SSD1 3 SSH配置1 4 查看Jetpack版本1 5 启动风扇 2 深度学习环境配置2 1 py
  • Python+OpenCV+matplotlib+wxPython实现的图像处理程序

    Python 43 OpenCV 43 matplotlib 43 wxPython实现的图像处理程序 背景 xff1a 本学期多媒体技术原理与应用课程的实验部分代码结果截图结语 背景 xff1a 本学期多媒体技术原理与应用课程的实验 本学
  • 按量购买阿里云服务器、k8s集群

    基础配置 创建私有网络 注意这里的交换区必须和服务器的所选区相同 连接测试 ping a 172 31 0 141 172 31 0 143 172 31 0 142 ping一下私有网络 ping 172 32 0 141 设置弹性ip
  • 小米6渲染图曝光 边框惊艳 国产曲面旗舰要发黑色版

    昨天咱们刚刚说过 小米6会有陶瓷版本 并且估计会在四月发布 今天 网友的渲染图又来了 没上车的赶紧上车 别忘了底部打卡 最近 对于小米6的传言很众多 xff0c 但不管怎么说 xff0c 骁龙835处理器 IMX400传感器以及高屏占比等都
  • 时间戳对齐的简单算法(原创)

    实际融合算法过程中常常出现时间戳对不齐的情况 为了解决此问题 xff0c 用了两个队列来解决时间戳匹配问题 时间戳对齐算法实现原理如下下图为插入状态 如图所示共有两个队列 xff0c 有七个状态 xff0c 通过对于轮速递推结果的动态保存
  • java中equals和==的区别(简单介绍)

    java中equals和 61 61 的区别 简单介绍 equals方法是java lang Object类的方法 有两种用法说明 一 对于字符串变量来说 xff0c 使用 61 61 和 equals 方法比较字符串时 xff0c 其比较
  • 如何上传到GitHub的main分支而不是master分支

    由于在2020年10月01日后 xff0c 在 GitHub 上创建的仓库都默认命名为 main 而非原本的 master 所以 有人看了我的 https blog csdn net m0 46419510 article details
  • Python中的Pandas、Matplotlib库详解

    文章目录 Pandas数据分析库Pandas的基本数据结构访问数据算术运算和对齐数据整理 Matplotlib绘图库Matplotlib简介几种常见的图形多图绘制使用Pandas绘图 Pandas数据分析库 1 xff09 Pandas是目
  • 卡尔曼滤波模型及Matlab模型建立

    目录 一 卡尔曼滤波 1 概念解析 xff1a 2 卡尔曼滤波的最优估计模型 3 实例 小车匀加速直线运动 4 Matlab建模 二 扩展卡尔曼滤波 xff08 EKF Extended KAlman Filter xff09 1 非线性系