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

📄 smooth_update.m

📁 基于matlab的卡尔曼滤波程序对相关研究有借鉴价值
💻 M
字号:
function [xsmooth, Vsmooth, VVsmooth_future] = smooth_update(xsmooth_future, Vsmooth_future, ...    xfilt, Vfilt,  Vfilt_future, VVfilt_future, A, Q, B, u)% One step of the backwards RTS smoothing equations.% function [xsmooth, Vsmooth, VVsmooth_future] = smooth_update(xsmooth_future, Vsmooth_future, ...%    xfilt, Vfilt,  Vfilt_future, VVfilt_future, A, B, u)%% INPUTS:% xsmooth_future = E[X_t+1|T]% Vsmooth_future = Cov[X_t+1|T]% xfilt = E[X_t|t]% Vfilt = Cov[X_t|t]% Vfilt_future = Cov[X_t+1|t+1]% VVfilt_future = Cov[X_t+1,X_t|t+1]% A = system matrix for time t+1% Q = system covariance for time t+1% B = input matrix for time t+1 (or [] if none)% u = input vector for time t+1 (or [] if none)%% OUTPUTS:% xsmooth = E[X_t|T]% Vsmooth = Cov[X_t|T]% VVsmooth_future = Cov[X_t+1,X_t|T]%xpred = E[X(t+1) | t]if isempty(B)  xpred = A*xfilt;else  xpred = A*xfilt + B*u;endVpred = A*Vfilt*A' + Q; % Vpred = Cov[X(t+1) | t]J = Vfilt * A' * inv(Vpred); % smoother gain matrixxsmooth = xfilt + J*(xsmooth_future - xpred);Vsmooth = Vfilt + J*(Vsmooth_future - Vpred)*J';VVsmooth_future = VVfilt_future + (Vsmooth_future - Vfilt_future)*inv(Vfilt_future)*VVfilt_future;

⌨️ 快捷键说明

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