⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mykalmanfilter.m

📁 各种滤波器
💻 M
字号:
function X_estimate=myKalmanFilter(A,C,Q,R,X0,y)
% myKalmanFilter 对实测值y进行Kalman滤波,该系统为
% X(n+1)=A X(n))+v1(n);
% y(n)=C X(n)+v2(n);
% v1和v2是噪声,其方差分别为Q和R,初始条件为X0;

N=length(y);
m=length(C);
X_estimate=zeros(m,N);   % 对实际值的滤波估计
X_estimate(:,1)=X0;
P_estimate=R;            % 估计误差

for k=2:N
    X_predict=A*X_estimate(:,k-1);       % 一步预测
    P_predict=A*P_estimate*A'+Q;                % 预测误差
    K=P_predict*C'/(C*P_predict*C'+R);          % Kalman增益
    X_estimate(:,k)=X_predict+K*(y(k)-C*X_predict);    % 由实测修正滤波估计
    P_estimate=P_predict-K*C*P_predict;         % 滤波估计误差
end

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -