Ex3210.asv
上传用户:shigeng
上传日期:2017-01-30
资源大小:122k
文件大小:2k
开发平台:

Matlab

  1. function Particle
  2. % Particle filter 
  3. x = 0; % 初始状态
  4. Q = 1; % 过程噪声协方差
  5. R = 1; % 测量噪声协方差
  6. tf = 180; % 仿真长度
  7. N = 100; % 粒子滤波器粒子数
  8. xhat = x;
  9. P = 2;
  10. xhatPart = x;
  11. % 初始化粒子过滤器
  12. for i = 1 : N
  13.     xpart(i) = x + sqrt(P) * randn;
  14. end
  15. xArr = [x];
  16. yArr = [x + sqrt(R) * randn];
  17. xhatArr = [x];
  18. PArr = [P];
  19. xhatPartArr = [xhatPart];
  20. close all;
  21. for k = 1 : tf
  22.     % 系统仿真
  23.     t=0:180;
  24.     t1=20000/300;
  25.     t2=t1+200*pi/20;
  26.     if  t>=0&&t<=t1
  27.         x=0;
  28. elseif t>t1&&t<=t2
  29.     x=sqrt(562.5^2-(x+4500)^2)+ sqrt(Q) * randn;
  30. else
  31.     x=-9000;
  32. end
  33.     y = x + sqrt(R) * randn;%观测方程
  34.      %  卡尔曼滤波
  35.      if t>t1&&t<=t2
  36.     F = (x+4500)/sqrt(562.5^2-(x+4500)^2);
  37.     P = F * P * F' + Q;
  38.     H = xhat / 10;
  39.     K = P * H' * inv(H * P * H' + R);
  40.     xhat = sqrt(562.5^2-(xhat+4500)^2);%预测
  41.     xhat = xhat + K * (y - xhat);%更新
  42.     P = (1 - K * H) * P;
  43. else F=0;
  44.     P = F * P * F' + Q;
  45.     H = xhat / 10;
  46.     K = P * H' * inv(H * P * H' + R);
  47.     xhat = sqrt(562.5^2-(xhat+4500)^2);%预测
  48.     xhat = xhat + K * (y - xhat);%更新
  49.     P = (1 - K * H) * P;
  50.    
  51.     for i = 1 : N
  52.         xpartminus(i) = sqrt(562.5^2-(xpartminus+4500)^2) + sqrt(Q) * randn;
  53.         ypart = xpartminus(i);
  54.         vhat = y - ypart;%观测和预测的差
  55.         q(i) = (1 / sqrt(R) / sqrt(2*pi)) * exp(-vhat^2 / 2 / R);
  56.     end
  57.     %正常化的可能性,每个先验估计
  58.     qsum = sum(q);
  59.     for i = 1 : N
  60.         q(i) = q(i) / qsum;%归一化权重
  61.     end
  62.     % 重采样
  63.     for i = 1 : N
  64.         u = rand; % 均匀随机数介于0和1
  65.         qtempsum = 0;
  66.         for j = 1 : N
  67.             qtempsum = qtempsum + q(j);
  68.             if qtempsum >= u
  69.                 xpart(i) = xpartminus(j);
  70.                 break;
  71.             end
  72.         end
  73.     end
  74.     xhatPart = mean(xpart);
  75.     xArr = [xArr x];
  76.     yArr = [yArr y];
  77.     xhatArr = [xhatArr xhat];
  78.     PArr = [PArr P];
  79.     xhatPartArr = [xhatPartArr xhatPart];
  80.     
  81. t = 0 : tf;
  82.     if k == 20   
  83.     end
  84. end
  85. figure;
  86. plot(t, xArr, 'b.', t,xhatArr,'r',t, xhatPartArr, 'k-');
  87. xlabel('time step'); ylabel('state');
  88. legend('True state','KF', 'Particle filter estimate');