%% SIR粒子滤波的应用,算法流程参见博客http://blog.csdn.net/heyijia0327/article/details/40899819
clear all
close all
clc
%% initialize the variables
x = 0.1; % initial actual state
x_N = 1; % 系统过程噪声的协方差 (由于是一维的,这里就是方差)
x_R = 1; % 测量的协方差
T = 75; % 共进行75次
N = 100; % 粒子数,越大效果越好,计算量也越大
%initilize our initial, prior particle distribution as a gaussian around
%the true initial value
V = 2; %初始分布的方差
x_P = []; % 粒子
% 用一个高斯分布随机的产生初始的粒子
for i = 1:N
x_P(i) = x + sqrt(V) * randn;
end
z_out = [x^2 / 20 + sqrt(x_R) * randn]; %实际测量值
x_out = [x]; %the actual output vector for measurement values.
x_est = [x]; % time by time output of the particle filters estimate
x_est_out = [x_est]; % the vector of particle filter estimates.
for t = 1:T
x = 0.5*x + 25*x/(1 + x^2) + 8*cos(1.2*(t-1)) + sqrt(x_N)*randn;
z = x^2/20 + sqrt(x_R)*randn;
for i = 1:N
%从先验p(x(k)|x(k-1))中采样
x_P_update(i) = 0.5*x_P(i) + 25*x_P(i)/(1 + x_P(i)^2) + 8*cos(1.2*(t-1)) + sqrt(x_N)*randn;
%计算采样粒子的值,为后面根据似然去计算权重做铺垫
z_update(i) = x_P_update(i)^2/20;
%对每个粒子计算其权重,这里假设量测噪声是高斯分布。所以 w = p(y|x)对应下面的计算公式
P_w(i) = (1/sqrt(2*pi*x_R)) * exp(-(z - z_update(i))^2/(2*x_R));
end
% 归一化.
P_w = P_w./sum(P_w);
%% Resampling这里没有用博客里之前说的histc函数,不过目的和效果是一样的
for i = 1 : N
x_P(i) = x_P_update(find(rand <= cumsum(P_w),1)); % 粒子权重大的将多得到后代
end % find( ,1) 返回第一个 符合前面条件的数的 下标
%状态估计,重采样以后,每个粒子的权重都变成了1/N
x_est = mean(x_P);
% Save data in arrays for later plotting
x_out = [x_out x];
z_out = [z_out z];
x_est_out = [x_est_out x_est];
end
t = 0:T;
figure(1);
clf
plot(t, x_out, '.-b', t, x_est_out, '-.r','linewidth',3);
set(gca,'FontSize',12); set(gcf,'Color','White');
xlabel('time step'); ylabel('flight position');
legend('True flight position', 'Particle filter estimate');
没有合适的资源?快使用搜索试试~ 我知道了~
温馨提示
基于粒子滤波算法的锂离子电池剩余使用寿命估计(MATLAB完整源码和数据) 基于粒子滤波算法的锂离子电池剩余使用寿命估计(MATLAB完整源码和数据) 基于粒子滤波算法的锂离子电池剩余使用寿命估计(MATLAB完整源码和数据)
资源推荐
资源详情
资源评论
收起资源包目录
基于粒子滤波算法的锂离子电池剩余使用寿命估计.zip (12个子文件)
matlab
hfun.m 592B
B0006.mat 15.29MB
randomR.m 656B
data
main.m 2KB
B0018.mat 8.11MB
B0005.mat 15.22MB
residualR.m 1005B
pf.m 2KB
Battery_Capacity.mat 7KB
B0007.mat 15.31MB
1.png 48KB
2.png 25KB
共 12 条
- 1
资源评论
- wyflaopo!2023-03-09就是另一个帖子的代码整合起来的东西
- qq_411469322023-12-28感谢大佬,让我及时解决了当下的问题,解燃眉之急,必须支持!
- qq_408962202023-08-21资源使用价值高,内容详实,给了我很多新想法,感谢大佬分享~
- 大航在coding2023-06-22总算找到了自己想要的资源,对自己的启发很大,感谢分享~
前程算法屋
- 粉丝: 4075
- 资源: 711
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功