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

Matlab

  1. function main()
  2. %产生观测数据
  3. total=3*60;%总的时间长度
  4. global T;%采样周期
  5. T=1;
  6. N=total/T;%数据长度
  7. a=50;
  8. var_rx=100;
  9. var_ry=100;
  10. X=[];%观测数据
  11. X_ideal=[];%理想数据
  12. for i=1:N
  13.     [rx,ry]=track(i*T,20);
  14.     X_ideal=[X_ideal,[rx;ry]];
  15.     rx=rx+var_rx*randn(1,1);
  16.     ry=ry+var_ry*randn(1,1);
  17.     X=[X,[rx;ry]];
  18. end
  19. X_filter=zeros(size(X));%滤波后数据
  20. X_mean=X_filter;%蒙特卡洛平均数据
  21. Error_var=zeros(size(X));
  22. M=10;%蒙特卡洛仿真次数
  23. for iCount=1:M
  24.     X_filter=Trace(X);
  25.     X_mean=X_mean+X_filter;
  26.     Error_var=Error_var+(X_ideal-X_filter).^2;
  27.     
  28. end
  29. X_mean=X_mean/M;
  30. Error_var=Error_var/M;
  31. Error_mean=X_ideal-X_mean;%误差均值
  32. Error_var=sqrt(Error_mean.^2);
  33. set(gca,'FontSize',12); set(gcf,'Color','White');
  34. plot(X(1,:),X(2,:),X_mean(1,:),X_mean(2,:),'x');
  35. xlabel('X(米)'),ylabel('Y(米)');
  36. axis equal;
  37. legend('真实轨迹','滤波轨迹');
  38. figure;
  39. k=1:N;
  40. set(gca,'FontSize',12); set(gcf,'Color','White');
  41. subplot(2,1,1),plot(k,Error_var(1,:)/N);title('x方向误差标准值');xlabel('采样次数'),ylabel('RMSE(米)');
  42. subplot(2,1,2),plot(k,Error_var(2,:)/N);title('y方向误差标准值');xlabel('采样次数'),ylabel('RMSE(米)');
  43.     
  44. %理想航迹方程
  45. function [x,y]=track(t,a)
  46. %   t:时间
  47. %   x:横轴位移
  48. %   y:纵轴位移
  49. %   a:转弯处加速度 
  50. %   r:初始位置
  51. %   v:初始速度
  52. r=[0,0]';
  53. v=300+randn(1,1);
  54. w=a/v;%角速度
  55. t1=pi/w;
  56. t2=t1+pi/w;
  57. D=v^2/a*2;%圆周运动直径
  58. if t<=0
  59.    x=0,y=0;
  60.   elseif t>0&&t<=t1
  61.     angel=t*w;
  62.     x=D/2-D/2*cos(angel);
  63.     y=D/2*sin(angel);
  64. elseif t>t1&&t<=t2
  65.     angel=(t-t1)*w;
  66.     x=(3-cos(angel))*D/2;
  67.     y=-D*sin(angel);
  68.     else
  69.     x=D+D+v*(t-t2);
  70.     y=0;
  71. end
  72.     
  73. function R=Trace(X)
  74. %飞行器跟踪模拟
  75. %    X:观测数据
  76. %    R:输出坐标
  77. %观测时间间隔
  78. global T;
  79. %观测矩阵
  80. H=[1,0,0,0,0;...
  81.    0,1,0,0,0];
  82. %位移测量误差
  83. var_rx=100;
  84. var_ry=100;
  85. var_rx2=var_rx^2;
  86. var_ry2=var_ry^2;
  87. %观测噪声协方差矩阵
  88. C=[var_rx2,0;...
  89.    0,var_ry2];
  90. %状态噪声协方差矩阵
  91. var_v=30;
  92. var_a=5;
  93. var_v2=var_v^2;
  94. var_a2=var_a^2;
  95. Q=zeros(5,5);
  96. Q(4,4)=var_v2;
  97. Q(5,5)=var_a2;
  98. %初始状态
  99. s0=[0,0,0,300,0]';
  100. %Kalman滤波跟踪
  101. N=size(X,2);%观测数据长度
  102. s=s0;
  103. a=@traverse;
  104. M=Q;
  105. Xplus=[];%修正后的航迹
  106. for icurrent=1:N
  107.     [s,M]=Karlman(s,M,X(:,icurrent),a,Q,C,H);
  108.     Xplus=[Xplus;(s(1:2))'];
  109. end
  110. R=Xplus';
  111. function s_estimate=traverse(s)
  112. %状态方程
  113. global T;
  114. s_estimate=zeros(5,1);
  115. s_estimate(1)=s(1)+s(4)*cos(s(3))*T;
  116. s_estimate(2)=s(2)-s(4)*sin(s(3))*T;
  117. s_estimate(3)=s(3)+(s(5)/s(4))*T;
  118. s_estimate(4)=s(4);
  119. s_estimate(5)=s(5);
  120. function [s,M]=Karlman(s_forward,M_forward,X,a,Q,C,H)
  121. %卡尔曼滤波
  122. %参数说明
  123. %       X--观测数据矢量
  124. %       A--状态矩阵
  125. %       Q--状态噪声协方差
  126. %       C--观测噪声协方差
  127. %       h--观测方程句柄
  128. %       s--输出数据矢量
  129. %       s_foward--前次输出矢量
  130. %       M--前次预测矩阵
  131. global T;
  132. %预测
  133. s=feval(a,s_forward);  
  134. %状态转换矩阵
  135. A=[1,2*s(4)*sin(s(3))*T+9000,2*s(4)*cos(s(3))*T*(-s(4)*sin(s(3))*T-4500),2*sin(s(3))*T*(-s(4)*sin(s(3))*T-4500),0;...
  136.    1/(2*sqrt(4500-s(4)*cos(s(3))*T)),1,-s(4)*sin(s(3))*T/(2*sqrt(4500-s(4)*cos(s(3))*T)),cos(s(3))*s(4)/(2*sqrt(4500-s(4)*cos(s(3))*T)),0;...
  137.    sin(s(3))/(s(4)*T),cos(s(3))/(s(4)*T),1,-s(5)*T/(s(4))^2,T/s(4);...
  138.    0,0,0,1,0;...
  139.    0,0,0,0,1];
  140. %最小预测MSE矩阵
  141. M=M_forward;
  142. M=A*M*A'+Q;   %协方差的进一步预测
  143. %卡尔曼增益矩阵
  144. K=M*H'*inv(C+H*M*H');
  145. %修正(状态更新方程)
  146. s=s+K*(X-H*s);
  147. %最小MSE矩阵(协方差更新方程)
  148. I=eye(5);
  149. M=[I-K*H]*M*[I+K*H]'-K*C*K';