【选址问题】卡尔曼滤波器和粒子滤波器的代码,用于解决船只位置的问题(Matlab实现)

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

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

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

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

目录

💥1 概述

📚2 运行结果

🎉3 参考文献

🌈4 Matlab代码实现


💥1 概述

卡尔曼滤波器

原理基础

卡尔曼滤波器是一种针对线性系统且噪声服从高斯分布情况的最优递归滤波器。它借助系统的动态模型与测量模型,在预测与更新这两个步骤中不断迭代,从而对船只的状态(位置、速度等)进行最优估计。预测步骤依据系统的动态特性对下一时刻的状态进行预估,更新步骤则结合实际测量值对预测结果进行修正。

代码实现关键要点
  • 参数初始化:需要设定初始状态估计值、状态协方差矩阵、状态转移矩阵、测量矩阵、过程噪声协方差矩阵和测量噪声协方差矩阵。
  • 预测步骤:依据状态转移矩阵对状态进行预测,同时更新协方差矩阵以反映预测的不确定性。
  • 更新步骤:通过计算卡尔曼增益,结合测量值对预测状态进行校正,进而得到更精准的状态估计。

粒子滤波器

原理基础

粒子滤波器是一种基于蒙特卡罗模拟的滤波方法,适用于非线性、非高斯系统。它借助一组随机样本(粒子)来近似表示系统状态的概率分布。在每个时间步,粒子根据系统的动态模型进行状态转移,并依据测量值对粒子的权重进行更新,最后通过重采样去除权重小的粒子,保留并复制权重大的粒子。

代码实现关键要点
  • 粒子初始化:随机生成一组粒子,每个粒子代表一个可能的状态,并为其分配初始权重。
  • 预测步骤:依据系统的动态模型对每个粒子的状态进行更新。
  • 更新步骤:根据测量值计算每个粒子的权重,权重反映该粒子与测量值的匹配程度。
  • 重采样步骤:根据粒子的权重对粒子进行重采样,以防止粒子退化。

总结

卡尔曼滤波器适用于线性高斯系统,计算效率高;粒子滤波器适用于非线性非高斯系统,能处理更复杂的情况。上述代码提供了基本的实现框架,你可以根据实际需求调整参数和模型,以更好地解决船只位置估计问题。

📚2 运行结果

部分代码:

clear all;
% x(t+1) = Ax(t) + w
% y(t) = d(x(t)) + v
% w ~ N(0, Q)
% v ~ N(0, R)

%% Parameters
A = 1.001; % transition matrix
Q = 0.25; % covariance of noise w
R = 0.3; % covariance of noise v
x0 = 0; % initial state
len = 200; % length of the sequence
N = 5000; % number of particle

%% Initialization
x_true = zeros(1, len);
x_pred = zeros(1, len);
y = zeros(1, len);
x_true(1) = x0;
x_pred(1) = x0;
seed = 7;

%% Preparation of true location
randn('state', seed);
y(1) = d(x_true(1)) + normrnd(0, R^0.5);

for i = 2:len
    x_true(i) = A * x_true(i - 1) + normrnd(0, Q^0.5);
    y(i) = d(x_true(i)) + normrnd(0, R^0.5);
end

%% Prediction
particle = zeros(1, N) + x0; % initialize particles with x0
w = zeros(1, N) + 1 / N; % initialize weights with 1/N

for i = 2:len
    disp(i)
    % p(x(t)|x(t-1))
    particle = A .* particle + normrnd(0, Q^0.5, [1, N]);
    % w = p(y|x)*(1/N)
    w = exp(- (y(i) - d(particle)).^2 / (2 * R)) / sqrt(2 * pi * R);
    % normalization using 1/N
    w = w ./ sum(w);
    % resampling and update particle
    for n = 1:N
        particle(n) = particle(find(rand <= cumsum(w), 1));
    end

    % estimated variable
    x_pred(i) = mean(particle);
end

%% Evaluation
mse = sum((x_pred - x_true).^2) ./ size(x_true, 2);
disp(['MSE:', num2str(mse)]);

%% Illustration
plot(x_pred, '-', 'linewidth', 1.5)
hold on
plot(x_true, '--', 'linewidth', 1.5)
xlabel('time step');
ylabel('x');
legend('prediction of x', 'true x');
grid on;
title(['Particle Filter (x0=', num2str(x0), ' A=', num2str(A),' N=', num2str(N), ')']);
saveas(gcf, 'Particle.png');

🎉3 参考文献

文章中一些内容引自网络,会注明出处或引用为参考文献,难免有未尽之处,如有不妥,请随时联系删除。

[1]周斌,王秀境,肖建华,等.基于粒子滤波器模型的无人机北斗抗欺骗式干扰技术[J].电力信息与通信技术,2022,20(12):18-24.DOI:10.16543/j.2095-641x.electric.power.ict.2022.12.003.

[2]贺宁,张思媛,李若夏,等.基于高斯混合集合卡尔曼滤波器的锂电池剩余使用寿命预测[C]//中国自动化学会.2022中国自动化大会论文集.西安建筑科技大学机电工程学院;西安建筑科技大学信息与控制工程学院;,2022:57-62.DOI:10.26914/c.cnkihy.2022.053798.

🌈4 Matlab代码实现

图片

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值