【数字信号去噪】变分贝叶斯卡尔曼滤波器数字信号滤波【含Matlab源码 2256期】

本文介绍了变分贝叶斯方法在卡尔曼滤波中的应用,特别是如何处理参数估计问题,通过迭代计算参数更新。提供了MATLAB代码示例,展示了在不同噪声条件下的滤波效果,以及一种自适应变分贝叶斯容积卡尔曼滤波方法。
摘要由CSDN通过智能技术生成

⛄一、变分贝叶斯卡尔曼滤波器数字信号滤波

1变分贝叶斯
在参数估计的问题中,在获得了观测样本的数据集Z后,根据贝叶斯准则,核心是参数集 θ 的后验概率密度函数的计算
在这里插入图片描述
而式( 1) 计算的一个难点在于分母,边缘似然概率密度函数p( Z) 的计算。正如引言所述,通常情况下p( Z) 的计算难以得到精确的解析解,引入变分贝叶斯方法,引入一个简单的近似分布函数q( θ) , 并取p( Z) 的对数形式:
在这里插入图片描述
在这里插入图片描述
可以发现,每个参数 θi的近似分布可以通过求对数联合概率密度函数关于其他参数分布q( θj≠i) 的期望求得,所以每一个参数分布的计算都依赖于其他参数的分布。这就形成了迭代的机制: 在给定先验知识的情况下,初始化参数值,通过变分贝叶斯算法循环迭代计算,进行参数更新,直至自由能量( 对数边缘似然函数的下界) 达到最大值,判定算法收敛并结束, 此时可以得到系统模型参数的估计值。

⛄二、部分源代码

clear all;
close all;
%%%%%Model parameters%%%%%%%
nxp = 10;
nx = 4; % number of state variables
nz = 2; % number of measures
T = 1;
q = 10;
r = 1;
F = [eye(2) Teye(2);zeros(2) eye(2)];
H = [eye(2) zeros(2)];
Q0 = q * [T^3/3
eye(2) T2/2*eye(2);T2/2eye(2) Teye(2)];
R0 = r * [1 0.5;0.5 1];
L = 500;
Tn = L;
N = 5; %%%%%%The number of variational iteration
times_Of_R = 5;
%%%%%Initial values
x_Ini = [100;100;10;10];
P_Ini = diag([100 100 100 100]);
X = zeros(4,L);
XKF_True = zeros(4,L);
XKF_Const = zeros(4,L);
XKF_VB = zeros(4,L);

mse_Kf_1 = zeros(L,nxp);
mse_Kf_2 = zeros(L,nxp);
mse_Ktf_1 = zeros(L,nxp);
mse_Ktf_2 = zeros(L,nxp);
mse_VB_1 = zeros(L,nxp);
mse_VB_2 = zeros(L,nxp);
for k = 1:nxp
x=x_Ini;
X(:,1) = x;
%%%%Kalman filter with nominal noise covariance matrices (KFNCM)
XKF_Const(:,1) = x;
x1=x;
P_Const = P_Ini;
%%%%Kalman filter with true noise covariance matrices (KFTCM)
XKF_True(:,1) = x;
x2 = x;
P_True = P_Ini;

%%%%Kalman filter of variational Bayesian Approximations
XKF_VB(:,1) = x;
x3 = x;
P_VB = P_Ini;
alfa = [1 1]';
beta = diag(R0);
mk = x;
for t = 2:Tn
    %%%%True noise covariance matrices
    Q = (1+0.5*cos(pi*t/Tn))*Q0;
    R = (1+0.6*cos(pi*t/Tn))*R0;
    %%%%Square-root of noise covariance matrices
    SQ = utchol(Q);
    SR = utchol(R);
    %%%%Simulate true state and measurement
    x = F*x+SQ*randn(nx,1);
    z = H*x+SR*randn(nz,1);
    X(:,t) = x;
    %%%%Filtering
    [x1,P_Const,Ppf] = kf(x1,P_Const,F,H,z,Q0,R0*times_Of_R);
    [x2,P_True,Pptf] = kf(x2,P_True,F,H,z,Q,R);
    [x3,P_VB,alfa,beta,mk] = vbkf(x3,P_VB,alfa,beta,mk,F,H,z,Q0,N);
    %%%%Save data
    XKF_Const(:,t) = x1;
    XKF_True(:,t) = x2;
    XKF_VB(:,t) = x3;
end

⛄三、运行结果

在这里插入图片描述

⛄四、matlab版本及参考文献

1 matlab版本
2019b

2 参考文献
[1]沈锋,徐广辉,桑靖.一种自适应变分贝叶斯容积卡尔曼滤波方法[J].电机与控制学报. 2015,19(04)

3 备注
简介此部分摘自互联网,仅供参考,若侵权,联系删除

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值