【状态估计】卡尔曼滤波器、扩展卡尔曼滤波器、双卡尔曼滤波器和平方根卡尔曼滤波器研究(Matlab代码实现)

  

💥💥💞💞欢迎来到本博客❤️❤️💥💥

🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。

⛳️座右铭:行百里者,半于九十。

📋📋📋本文目录如下:🎁🎁🎁

目录

💥1 概述

📚2 运行结果

🎉3 参考文献

🌈4 Matlab代码实现


💥1 概述

本文包括:

1) 标准卡尔曼滤波器 2) 扩展卡尔曼滤波器 3) 双卡尔曼滤波器 4) 平方根卡尔曼滤波器
 

在所有 4 种情况下,KF 函数都接受多维系统的噪声样本作为输入,并根据噪声样本中固有的时变过程/噪声协方差生成真实系统状态的 KF 估计值。

指数加权(或未加权)移动平均线用于估计噪声测量的时变系统协方差。

标准卡尔曼滤波器是最基本的卡尔费休实现。它假设一个模型,即噪声测量包含真实的系统状态和白噪声。

扩展卡尔曼滤波器是标准卡尔曼滤波器的推广,允许用户指定非线性系统模型,然后在 EKF 执行期间迭代线性化。

双卡尔曼滤波器同时解决了两个标准卡尔曼滤波器问题:

1) 将自回归模型拟合到数据并应用卡尔曼滤波来更新 AR 模型

2) 在执行标准 KF 更新之前,在每次迭代中应用 AR 模型

平方根卡尔曼滤波是执行标准/双卡尔曼滤波的更稳健且数值稳定的方法,尤其是当感兴趣的协方差矩阵条件不佳或几乎不是正定矩阵时。平方根卡尔曼滤波思想是以平方根形式 P = U D U' 传播过程误差协方差 P,其中 U 和 D 迭代更新,P 未显式计算。这样做将保证P是正定的,从而增加KF的数值稳定性。

📚2 运行结果

 

 

 部分代码:

% Number of iterations  
N = 1000;

% True State
x = zeros(2,N);

% Apriori state estimates
x_apriori = zeros(2,N);

% Aposteriori state estimates
x_aposteriori = zeros(2,N);

% Apriori error covariance estimates
P_apriori = zeros(2,2,N);

% Aposteriori error covariance estimates
P_aposteriori = zeros(2,2,N);

% Measurements
z = zeros(2,N);

% Kalman Gain
K = zeros(2,2,N);
%--------------------------------------------------------------------------

%--------------------------------------------------------------------------
% Knobs to turn
%--------------------------------------------------------------------------
% True initial state
x(:,1) = [ 0         ;
           3*pi/500 ];

% Initial aposteriori state estimate
x_aposteriori(:,1) = [ 1         ;
                       1*pi/500 ];

% Process noise covariance
Q = [   0.001    0 ;
          0      0 ];

% Measurement noise covariance
R = [ 0.1    0   ;
      0    0.01 ];

end
%--------------------------------------------------------------------------

%--------------------------------------------------------------------------
% Plot Results
%--------------------------------------------------------------------------
figure

subplot(2,1,1)
% Actual state position
b = plot(2:N,x(1,2:N),'b');
hold on
% State position estimates
r = plot(2:N,x_aposteriori(1,2:N),'r');
% State measurements
g = plot(2:N,z(1,2:N),'g+');
title('Extended Kalman Filtering of a Sine Wave - Position');
legend([b r g],'True Position','Position Estimates','Position Measurements');
xlabel('Time')
ylabel('Position')
grid on

subplot(2,1,2)
% Actual state frequency
b = plot(2:N,x(2,2:N),'b');
hold on
% State frequency estimates
r = plot(2:N,x_aposteriori(2,2:N),'r');
% Frequency measurements
g = plot(2:N,z(2,2:N),'g+');
title('Extended Kalman Filtering of a Sine Wave - Frequency');
legend([b r g],'True Frequency','Frequency Estimates','Frequency Measurements');
xlabel('Time')
ylabel('Frequency')
grid on

🎉3 参考文献

部分理论来源于网络,如有侵权请联系删除。

[1]景仙林,魏永虎.自回归的卡尔曼滤波算法在UWB定位中的应用[J].地理空间信息,2023,21(05):117-119.

[2]李成城,马立森,田原,贾运红,贾曲,田伟琴,张凯.基于CLAHE与卡尔曼滤波的掘进机机载视频稳像算法[J].工矿自动化,2023,49(05):66-73.DOI:10.13272/j.issn.1671-251x.2022100002.

[3]岳兴春,彭勇,宋威,黄嘉诚,周钰琛.融合EMA和卡尔曼滤波的MEMS去噪研究与应用[J].仪表技术与传感器,2023(04):83-86+92.

🌈4 Matlab代码实现

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 卡尔曼滤波(Kalman Filter)和平方根容积卡尔曼滤波(Square Root Cubature Kalman Filter)是常用的估计滤波算法,主要应用于状态估计和系统辨识问题。下面我将分别介绍其Matlab实验代码。 卡尔曼滤波的Matlab实验代码如下所示: ```matlab % 定义系统模型 A = [1 0.1; 0 1]; % 状态转移矩阵 B = [0.005; 0.1]; % 控制输入矩阵 H = [1 0]; % 观测矩阵 Q = [0.01 0; 0 0.01]; % 过程噪声协方差矩阵 R = 1; % 观测噪声方差 % 初始化滤波器状态 x_k = [0; 0]; % 状态向量 P_k = [1 0; 0 1]; % 状态协方差矩阵 % 初始化观测数据 y_k = [10; 8]; % 观测向量 % 迭代更新滤波器 for i = 1:length(y_k) % 预测步骤 x_k1 = A * x_k; P_k1 = A * P_k * A' + B * Q * B'; % 更新步骤 K_k = P_k1 * H' / (H * P_k1 * H' + R); x_k = x_k1 + K_k * (y_k(i) - H * x_k1); P_k = (eye(2) - K_k * H) * P_k1; end % 输出滤波结果 disp(x_k) ``` 平方根容积卡尔曼滤波的Matlab实验代码如下所示: ```matlab % 定义系统模型 A = [1 0.1; 0 1]; % 状态转移矩阵 B = [0.005; 0.1]; % 控制输入矩阵 H = [1 0]; % 观测矩阵 Q = [0.01 0; 0 0.01]; % 过程噪声协方差矩阵 R = 1; % 观测噪声方差 % 初始化滤波器状态 x_k = [0; 0]; % 状态向量 P_k = [1 0; 0 1]; % 状态协方差矩阵 % 初始化观测数据 y_k = [10; 8]; % 观测向量 % 迭代更新滤波器 for i = 1:length(y_k) % 预测步骤 x_k1 = A * x_k; P_k1 = A * P_k * A' + B * Q * B'; % 更新步骤 K_k = P_k1 * H' / (H * P_k1 * H' + R); x_k = x_k1 + K_k * (y_k(i) - H * x_k1); P_k = (eye(2) - K_k * H) * P_k1; % 平方根容积卡尔曼滤波的特殊步骤 [U, S, V] = svd(P_k); S_sqrt = sqrtm(S); P_k = U * S_sqrt * V'; end % 输出滤波结果 disp(x_k) ``` 这是一个简单的卡尔曼滤波和平方根容积卡尔曼滤波的Matlab实验代码,用于对给定观测数据进行状态估计。根据实际需求,你可以对系统模型和参数进行相应的调整和修改。 ### 回答2: 卡尔曼滤波(Kalman Filter)和平方根容积卡尔曼滤波 (Square Root Cubature Kalman Filter)是两种常见的滤波算法。以下是一个使用MATLAB实现的简单示例代码。 卡尔曼滤波的MATLAB实验代码: ```matlab % 定义系统模型 A = [1 1; 0 1]; % 状态转移矩阵 B = [0.5; 1]; % 输入转移矩阵 C = [1 0]; % 观测矩阵 Q = [0.01 0; 0 0.01]; % 状态过程噪声协方差矩阵 R = 1; % 观测噪声协方差矩阵 % 初始化滤波器 x = [0; 0]; % 状态估计初始值 P = [1 0; 0 1]; % 状态估计误差协方差矩阵 % 定义观测数据 Y = [1.2; 2.1; 3.7; 4.3]; % 观测数据 % 开始滤波 for i = 1:length(Y) % 预测状态 x = A * x + B * 0; % 无输入 P = A * P * A' + Q; % 更新状态 K = P * C' / (C * P * C' + R); x = x + K * (Y(i) - C * x); P = (eye(size(A)) - K * C) * P; % 输出状态估计值 disp(['第', num2str(i), '次观测的状态估计值为:']); disp(x); end ``` 平方根容积卡尔曼滤波的MATLAB实验代码: ```matlab % 定义系统模型 A = [1 1; 0 1]; % 状态转移矩阵 B = [0.5; 1]; % 输入转移矩阵 C = [1 0]; % 观测矩阵 Q = [0.01 0; 0 0.01]; % 状态过程噪声协方差矩阵 R = 1; % 观测噪声协方差矩阵 % 初始化滤波器 x = [0; 0]; % 状态估计初始值 P = [1 0; 0 1]; % 状态估计误差协方差矩阵 % 定义观测数据 Y = [1.2; 2.1; 3.7; 4.3]; % 观测数据 % 开始滤波 for i = 1:length(Y) % 预测状态 x = A * x + B * 0; % 无输入 P = sqrtm(A * P * A' + Q); % 更新状态 G = P * C' / (C * P * C' + R); x = x + G * (Y(i) - C * x); P = sqrtm((eye(size(A)) - G * C) * P * (eye(size(A)) - G * C)' + G * R * G'); % 输出状态估计值 disp(['第', num2str(i), '次观测的状态估计值为:']); disp(x); end ``` 以上是一个简单的卡尔曼滤波和平方根容积卡尔曼滤波的MATLAB实验代码示例。这些代码用于实现两种滤波算法,并使用预定义的系统模型和观测数据进行状态估计。实际应用中,需要根据具体问题进行参数调整和适应性修改。 ### 回答3: 卡尔曼滤波(Kalman Filter)和平方根容积卡尔曼滤波(Square Root Cubature Kalman Filter)都是常用于状态估计的滤波算法。 卡尔曼滤波是一种最优线性估计算法,基于状态空间模型,在系统的观测和模型误差服从高斯分布的条件下,通过使用先验信息和测量更新,来估计系统的状态。卡尔曼滤波的基本原理是通过不断地对先验状态和先验协方差进行更新和修正,得到最优估计平方根容积卡尔曼滤波是对传统卡尔曼滤波的改进算法之一,主要用于解决非线性系统的状态估计问题。相比于传统的卡尔曼滤波,平方根容积卡尔曼滤波使用了卡尔曼滤波的根协方差表示,通过对根协方差进行传输和修正,避免了传统卡尔曼滤波中协方差矩阵计算的数值不稳定问题,提供了更好的数值精度和计算效率。 以下是MATLAB实验代码的伪代码示例: ``` % 卡尔曼滤波 % 初始化状态和观测噪声的协方差矩阵 Q = ... % 状态噪声的协方差矩阵 R = ... % 观测噪声的协方差矩阵 % 初始化状态和协方差矩阵 x = ... % 状态向量 P = ... % 状态协方差矩阵 for k = 1:N % 预测步骤 x_hat = ... % 先验状态估计 P_hat = ... % 先验协方差估计 % 更新步骤 K = P_hat * C' / (C * P_hat * C' + R) % 卡尔曼增益 x = x_hat + K * (z - C * x_hat) % 后验状态估计 P = (eye(size(K,1)) - K * C) * P_hat % 后验协方差估计 end % 平方根容积卡尔曼滤波 % 初始化状态和观测噪声的协方差矩阵 Q = ... % 状态噪声的协方差矩阵 R = ... % 观测噪声的协方差矩阵 % 初始化状态和根协方差矩阵 x = ... % 状态向量 S = ... % 根协方差矩阵 for k = 1:N % 预测步骤 x_hat = ... % 先验状态估计 S_hat = ... % 先验根协方差估计 % 更新步骤 y = z - H * x_hat % 观测残差 K = S_hat * H' / (H * S_hat * H' + R) % 平方根卡尔曼增益 x = x_hat + K * y % 后验状态估计 S = (eye(size(K,1)) - K * H) * S_hat % 后验根协方差估计 end ``` 注意,在实际应用中,需要根据具体问题的状态模型和观测模型进行相应的参数设置和代码实现。以上代码仅为伪代码示例,具体的实现方式可能有所不同。可根据实际需求和问题进行算法选择和代码编写。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值