利用matlab实现扩展卡尔曼滤波(EKF)与无迹卡尔曼滤波(UKF)

例题

将下例进行EKF和UKF代码实现,进行仿真复现。
在这里插入图片描述

EKF算法模型

在这里插入图片描述

clc;
clear;
%测量值模拟
T=0.05;%滤波周期
T_go=10;%滤波时间
N=T_go/T;%观测次数
t=0:T:T_go-T;%假定输出序列(供画图用)
x=zeros(2,N);
z=zeros(2,N);
x(:,1)=[1;0];%真值初始值
mu=[0;0];
Q=[0.01,0;0,0.0001];
R=[0.1,0;0,0.1];

rng(1);
w=mvnrnd(mu,Q,N)';
v=mvnrnd(mu,R,N)';
for k=1:N-1
    x1=x(1,k);x2=x(2,k);
    w1=w(1,k);w2=w(2,k);
    x(:,k+1)=[x1+T*x2+w1;-10*T*sin(x1)+(1-T)*x2+w2];
    x1=x(1,k+1);x2=x(2,k+1);
    v1=v(1,k+1);v2=v(2,k+1);
    z(:,k+1)=[2*sin(x1/2)+v1;x1/2+v2];
end
%EKF估计
xk=zeros(2,N);
xk(:,1)=[1;0];
Pk=[1,0;0,1];
for k=1:N-1
    x1=xk(1,k);x2=xk(2,k);
    Fai=[1,T;-10*T*cos(x1),1-T];
    xk(:,k+1)=[x1+T*x2;-10*T*sin(x1)+(1-T)*x2];
    Pk=Fai*Pk*Fai'+Q;
    x1=xk(1,k+1);x2=xk(2,k+1);
    Hk=[cos(x1/2),0;1/2,0];
    Kk=Pk*Hk'/(Hk*Pk*Hk'+R);
    xk(:,k+1)=xk(:,k+1)+Kk*(z(:,k+1)-[2*sin(x1/2);x1/2]);
    Pk=(eye(2)-Kk*Hk)*Pk*(eye(2)-Kk*Hk)'+Kk*R*Kk';
end

subplot(2,1,1);
plot(t,x(1,:),'-r',t,z(1,:),'-g',t,xk(1,:),'-b');
xlabel('t');
ylabel('x1');
subplot(2,1,2);
plot(t,x(2,:),'-r',t,z(2,:),'-g',t,xk(2,:),'-b');
xlabel('t');
ylabel('x2');
legend('状态值','测量值','EKF');

输出结果:
在这里插入图片描述

UKF算法模型

在这里插入图片描述
在这里插入图片描述

clc;
clear;
%测量值模拟
T=0.05;%滤波周期
T_go=10;%滤波时间
N=T_go/T;%观测次数
t=0:T:T_go-T;%假定输出序列(供画图用)
x=zeros(2,N);
z=zeros(2,N);
x(:,1)=[1;0];%真值初始值
mu=[0;0];
Q=[0.01,0;0,0.0001];
R=[0.1,0;0,0.1];

rng(1);
w=mvnrnd(mu,Q,N)';
v=mvnrnd(mu,R,N)';
for k=1:N-1
    x1=x(1,k);x2=x(2,k);
    w1=w(1,k);w2=w(2,k);
    x(:,k+1)=[x1+T*x2+w1;-10*T*sin(x1)+(1-T)*x2+w2];
    x1=x(1,k+1);x2=x(2,k+1);
    v1=v(1,k+1);v2=v(2,k+1);
    z(:,k+1)=[2*sin(x1/2)+v1;x1/2+v2];
end

%UKF估计
alpha=0.1;
beta=2;
kappa=1;
n=2;%状态维数
lamda=alpha^2*(n+kappa)-n;
xk=zeros(2,N);

%1.初始化
xk(:,1)=[1;0];
Pk=[1,0;0,1];
wm=zeros(1,5);
wc=zeros(1,5);
wm(1)=lamda/(n+lamda);
wc(1)=lamda/(n+lamda)+1-alpha^2+beta;
for i=2:2*n+1
    wm(i)=1/(2*(n+lamda));
    wc(i)=1/(2*(n+lamda));
end

for k=1:N-1
%2.计算k-1时刻采样点和权值
    xsigma=zeros(2,5);
    xsigma(:,1)=xk(:,k);
    xsigma(:,2)=xk(:,k)+sqrt(n+lamda)*sqrt(Pk(:,1));
    xsigma(:,3)=xk(:,k)+sqrt(n+lamda)*sqrt(Pk(:,2));
    xsigma(:,4)=xk(:,k)-sqrt(n+lamda)*sqrt(Pk(:,1));
    xsigma(:,5)=xk(:,k)-sqrt(n+lamda)*sqrt(Pk(:,2));
%3.计算k时刻的一步预测模型值
    xsigmapre=zeros(2,5);
    for i=1:5
        xsigmapre(:,i)=[xsigma(1,i)+T*xsigma(2,i);-10*T*sin(xsigma(1,i))+(1-T)*xsigma(2,i)];
    end
    xkpre=xsigmapre*wm';
    Pkpre=Q;
    for i=1:5
        Pkpre=Pkpre+wc(i)*(xsigmapre(:,i)-xkpre)*(xsigmapre(:,i)-xkpre)';
    end
%4.计算k时刻的一步预测样本点(重新采样)    
%     xsigma(:,1)=xkpre;
%     xsigma(:,2)=xkpre+sqrt(n+lamda)*sqrt(Pkpre(1));
%     xsigma(:,3)=xkpre+sqrt(n+lamda)*sqrt(Pkpre(2));
%     xsigma(:,4)=xkpre-sqrt(n+lamda)*sqrt(Pkpre(1));
%     xsigma(:,5)=xkpre-sqrt(n+lamda)*sqrt(Pkpre(2));
%5.计算k时刻的预测量测值
    zsigmapre=zeros(2,5);
    for i=1:5
       zsigmapre(:,i)=[2*sin(xsigma(1,i)/2);xsigma(1,i)/2] ;  
    end
    zkpre=zsigmapre*wm';
    Pzzk=R;
    Pxzk=zeros(2);
    for i=1:5
        Pzzk=Pzzk+wc(i)*(zsigmapre(:,i)-zkpre)*(zsigmapre(:,i)-zkpre)';
        Pxzk=Pxzk+wc(i)*(xsigma(:,i)-xkpre)*(zsigmapre(:,i)-zkpre)';
    end
%6.量测更新
    Kk=Pxzk/Pzzk;
    xkpre=xkpre+Kk*(z(:,k+1)-zkpre);
    Pkpre=Pkpre-Kk*Pzzk*Kk';
    
    xk(:,k+1)=xkpre;
    Pk=Pkpre;
end

subplot(2,1,1);
plot(t,x(1,:),'-r',t,z(1,:),'-g',t,xk(1,:),'-b');
xlabel('t');
ylabel('x1');
subplot(2,1,2);
plot(t,x(2,:),'-r',t,z(2,:),'-g',t,xk(2,:),'-b');
xlabel('t');
ylabel('x2');
legend('状态值','测量值','UKF');

输出结果:
在这里插入图片描述

  • 12
    点赞
  • 60
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
### 回答1: 车辆状态估计是指根据车辆传感器数据和先验信息,通过数学方法推测出车辆当前的状态信息,如位置、速度、方向等。扩展卡尔曼滤波(Extended Kalman Filter, EKF)和无迹卡尔曼滤波(Unscented Kalman Filter, UKF)是常用的状态估计算法。 EKF是对卡尔曼滤波算法的扩展,解决了非线性系统的状态估计问题。它通过一系列线性化技术来近似非线性系统,并根据线性化的模型进行滤波。EKF对非线性性能较强,但在高维状态空间或非线性程度较高的系统中计算复杂度较高。 UKF则是对EKF的改进,无需进行系统线性化。它通过一种称为无迹变换(unscented transformation)的方法,通过一组经过特定变换的采样点来近似系统的非线性变换。这种采样方法能够更好地保持状态向量的高斯分布特性,从而提高滤波精度。UKF适用于一些非线性程度较高或状态空间较大的问题,较EKF具有更好的性能和计算效率。 总而言之,扩展卡尔曼滤波EKF)和无迹卡尔曼滤波UKF)是常用于车辆状态估计的算法。EKF通过线性化非线性系统来进行滤波,适用于中等复杂度的非线性问题。UKF则通过无迹变换来近似非线性变换,适用于非线性程度较高或状态空间较大的问题。根据具体的应用场景和系统特性,选择适当的算法可以提高车辆状态估计的精度和效率。 ### 回答2: 车辆状态估计是指通过利用车辆传感器提供的数据,推测车辆在特定时刻的位置、速度、方向等状态的过程。而扩展卡尔曼滤波(Extended Kalman Filter,EKF)和无迹卡尔曼滤波(Unscented Kalman Filter,UKF)是常用的车辆状态估计算法。 扩展卡尔曼滤波EKF)是基于卡尔曼滤波的一种改进算法,可以用于非线性系统的状态估计。对于车辆的状态估计,EKF通过对车辆的运动模型和观测模型进行线性化,然后使用卡尔曼滤波的递推公式来进行状态的预测和更新。EKF通过不断迭代预测和更新步骤,逐步优化对车辆状态的估计。 无迹卡尔曼滤波UKF)是对EKF的一种改进算法,主要解决了EKF由于线性化误差引起的估计误差问题。UKF通过使用一组特定的采样点(称为Sigma点)来代替传统的线性化过程,以更准确地近似非线性系统的状态分布。通过对Sigma点进行预测和更新,UKF能够更好地估计车辆的状态。 总结而言,扩展卡尔曼滤波EKF)和无迹卡尔曼滤波UKF)都是常用的车辆状态估计算法。它们通过对车辆的运动模型和观测模型进行线性化或者非线性化处理,通过迭代预测和更新的方式,对车辆的状态进行估计。其中,UKF通过使用一组特定的采样点来更准确地估计非线性系统的状态分布,相对于EKF具有更高的精度。 ### 回答3: 车辆状态估计是指对车辆的运动状态进行估计和预测的过程。在车辆动态系统中,状态包括位置、速度、加速度等信息,这些信息对于自动驾驶、智能交通等应用非常重要。 扩展卡尔曼滤波(Extended Kalman Filter,EKF)是一种基于卡尔曼滤波(Kalman Filter)的状态估计方法。EKF通过建立非线性运动方程和测量方程的雅可比矩阵,将非线性系统近似为线性系统进行状态估计。其主要思想是通过使用一阶泰勒展开对非线性方程进行线性化,得到近似的线性方程,然后利用卡尔曼滤波算法进行状态估计。由于EKF是对非线性系统的线性化近似,因此在系统非线性程度较高时,其估计精度可能会有所下降。 无迹卡尔曼滤波(Unscented Kalman Filter,UKF)是对EKF的改进和扩展UKF通过使用一种特定的变换(无迹变换)将高斯分布转化为一组采样点,并在非线性方程中使用这些采样点来近似非线性函数的传播。无迹变换可以更好地保留非线性函数的特性,从而提高了状态估计的精度。相对于EKF而言,UKF在非线性程度高的情况下表现更加稳定和精确。 总之,EKetF和UkF是两种常用的车辆状态估计方法。EKetF是对非线性系统的线性化近似,而UKF通过无迹变换来更好地保留非线性函数的特性。在车辆状态估计应用中,选择合适的方法取决于系统的非线性程度和对估计精度的要求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

唱戏先生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值