Chinaunix首页 | 论坛 | 博客
  • 博客访问: 37973
  • 博文数量: 15
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 5
  • 用 户 组: 普通用户
  • 注册时间: 2015-11-19 11:26
文章分类

全部博文(15)

文章存档

2017年(2)

2016年(12)

2015年(1)

我的朋友
最近访客

分类: 嵌入式

2017-06-02 19:39:55


1、Matlab中的clc,clear,close命令区别? 
    clc:清除命令窗口的内容,对工作环境中的全部变量无任何影响; 
    clear:清除工作空间的所有变量; 
    clear all:清除工作空间的所有变量,函数,和MEX文件;
    close:关闭当前的Figure窗口; 
    close all:关闭所有的Figure窗口。%如果不关闭,会在原来的figure上重复画图。

2、角度和弧度之间的转换公式? 
    设角度为 angle,弧度为 radian
    radian = angle * pi / 180; 
    angle = radian * 180 / pi; 
    所以在matlab中经常设置一个参数,用于角度与弧度之间的转换:deg_rad=0.01745329252e0;

3、单位矩阵的表示方法? 
    学会在comment window页面print相关函数: 
    表示4行4列的单位矩阵 
    这里写图片描述

4、注意下面角度Angint的表示方法: 
    Angint=[0,10,0]*deg_rad; 
    则:Angint(0) = 0;
    Angint(1) = 0.0175;
    Angint(2) = 0; 
    这种表示方法可以在四元数中应用: 
    例如: q=[cos(Angint(3)/2)*sin(Angint(2)/2)*cos(Angint(1)/2)+sin(Angint(3)/2)*cos(Angint(2)/2)*sin(Angint(1)/2) 
        cos(Angint(3)/2)*cos(Angint(2)/2)*sin(Angint(1)/2)-sin(Angint(3)/2)*sin(Angint(2)/2)*cos(Angint(1)/2) 
        -sin(Angint(3)/2)*cos(Angint(2)/2)*cos(Angint(1)/2)+cos(Angint(3)/2)*sin(Angint(2)/2)*sin(Angint(1)/2)     
        cos(Angint(3)/2)*cos(Angint(2)/2)*cos(Angint(1)/2)+sin(Angint(3)/2)*sin(Angint(2)/2)*sin(Angint(1)/2)
    ]; 可以用q(0)、q(1)、q(2)、q(3)来代入公式计算三轴姿态角。

5、陀螺仪和加速度计的误差有哪些? 
    陀螺仪:随机误差+白噪声+一阶马尔可夫过程
    加速度计:白噪声+一阶马尔可夫过程 
    如图: 
这里写图片描述 

    6、在滤波的过程中,要明确滤波时间和采样频率。

    7、IMU数据仿真分析:
    (1)先模拟加速度计和陀螺仪的真实输出: 
    [ Angle,Wibb,Fb ] = imu_true_out( tt,ynong,T );%tt=tt+TT;TT=1/f为时间间隔 
    注意:加速度计的输出要进行坐标转换: ao=Cnb*([0,0,g]’, 
    其中:
    Cnb
     
    如果你要在加速度计的输出上添加一个随机干扰(可模拟非重力加速度干扰),可以使用函数awgn();%Add white Gaussian noise to a signal. 
    ao=Cnb*([0,0,g]’+[0,awgn(0,ynong),0]’);%如果在指点的时间内添加这种干扰,可以加一个if函数 
    (2)模拟加速度计和陀螺仪的误差: 
    [Gyro_b,Gyro_r,Gyro_wg,Acc_r]=imu_err_random(tt,TT,Gyro_b,Gyro_r,Gyro_wg,Acc_r);
    
    function[Gyro_b,Gyro_r,Gyro_wg,Acc_r]=imu_err_random(t,T,Gyro_b,Gyro_r,Gyro_wg,Acc_r)             
    
g=9.7803698; %重力加速度 (单位:米/秒/秒)
    
Wie=7.292115147e-5;  %地球自转角速度(单位:弧度/秒)

    deg_rad=0.01745329252e0;%Transferfrom angle degree to rad 
	
    Da_bias=[0.001;0.001;0.001]*g;  %加速度零偏(应与非随机性误差中的加速度零偏保持一致) 
    Ta=1800.0; %加速度一阶马尔可夫过程相关时间
    Tg=3600.0; %陀螺一阶马尔可夫过程相关时间 
    %%%%%%%%%%%%%%%%%%随机误差%%%%%%%%%%%%%%% 
    if( t==0)
        Acc_r=Da_bias.*randn(3,1); %加速度一阶马尔可夫过程1.0e-4g 
        Gyro_b=0.01*deg_rad/3600.0*randn(3,1); %随机常数0.1(deg/h
        Gyro_r=0.01*deg_rad/3600.0*randn(3,1); %陀螺一阶马尔可夫过程
0.1(deg/h) 
        Gyro_wg=0.01*deg_rad/3600.0*randn(3,1);%陀螺白噪声0.1(deg/h)
    else 
        Acc_wa=sqrt(2*T/Ta)*Da_bias.*randn(3,1);%加速度一阶马尔可夫过程白噪声 
        Acc_r=exp(-1.0*T/Ta)*Acc_r; %加速度一阶马尔可夫过程 
        Gyro_wr=0.01*sqrt(2*T/Tg)*deg_rad/3600.0*randn(3,1);%陀螺一阶马尔可夫过程白噪声0.1(deg/h) 
        Gyro_r=exp(-1.0*T/Tg)*Gyro_r+Gyro_wr;%陀螺一阶马尔可夫过程0.1(deg/h) 
        Gyro_wg=0.01*deg_rad/3600.0*randn(3,1);%陀螺白噪声0.1(deg/h) 
    end

  • 				
    • 然后再在while(1)中将真实值+误差值按时间序列存储在数组中以备用,如下:             

      while tt<=T
        [Gyro_b,Gyro_r,Gyro_wg,Acc_r]=imu_err_random(tt,TT,Gyro_b,Gyro_r,Gyro_wg,Acc_r); 
        Ture_Angle(:,kk)=Angle/deg_rad;%模拟输出的三轴姿态角 
        gyro(:,kk)=Wibb+Gyro_b+Gyro_r+Gyro_wg;%模拟输出的陀螺仪输出 
        acc(:,kk)=Fb+Acc_r;%模拟输出的加速度计输出 
        tt=tt+TT;kk=kk+1;%这里TT=1/f=1/100为采样时间间隔,f为采样频率,T为采样时间,文中设置为30s 
    end
		

8、函数randn的意思?           R = randn(3,1);%产生3行1列的随机R矩阵,R矩阵满足方差为1,均值为0;注意这里不是说这三个数的方差为1,均值为0,而是每次运行randn时,当运行的量足够大时,所有的R(0)的方差为1,均值为0,R(1)、R(2)     同理。例如1. randn(1) ;%生成一个随机数,要想满足方差为1,均值为0,也必须运行足够多的次数  例如2. x = .6 + sqrt(0.1) * randn(1);%产生均值为0.6,方差为0.1的一个5*5的随机数;sqrt(0.1)对0.1进行     开方,直接写0.1那这里就是表示标准差了

 

1、axis()函数的用法? 
    axis([xmin xmax ymin ymax]);%定义x轴和y轴之间的间
2、set()函数的用法?
    
例如:
    
plot(t,acc(2,:),'linewidth',1.3);
    
set(gcf,'Position',[100 100 400 300]);%这里的100是指生成的图片距离左下角的距离,400和300分别表示长和宽 axis([0 T -4.9 2.0]); 
    
set(gca, 'YTick', [-4.9 -2.4 -0.1 2.0]) 
    
set(gca,'fontname','宋体','fontsize',10);%用于改变坐标轴坐标大小,10代表坐标大小; 
    
xlabel('时间/s','fontname','宋体','fontsize',10);%用于改变x轴标注的文字和大小。 
    
ylabel('加速度计数据/(g)','fontname','宋体','fontsize',10);%用于改变x轴标注的文字和大小。 
    legend('accy');%标注
    
这里写图片描述
3、subplot()函数的用法? 
    
subplot(3,1,3);%表示绘制3行1列三个图,这里是第三个图

            
1、EKF的matlab实现: 
    卡尔曼最初提出的滤波理论只适用于线性系统,Bucy,Sunahara等人提出并研究了扩展卡尔曼滤波(Extended Kalman Filter,简称EKF),将卡尔曼滤波理论进一步应用到非线性领域。EKF的基本思想是将非线性系统线性化,然后
    进行卡尔曼滤波,因此EKF是一种次优滤波。其后,多种二阶广义卡尔曼滤波方法的提出及应用进一步提高了卡尔曼滤波对非线性系统的估计性能。二阶滤波方法考虑了Taylor级数展开的二次项,因此减少了由于 线性化所引起的 估计误
    差,但大大增加了运算量,因此在实际中反而没有一阶EKF应用广泛。 

                 在状态方程或测量方程为非线性时,通常采用扩展卡尔曼滤波(EKF)。EKF**对非线性函数的Taylor展开式进行一阶 线性化截断,忽略其余高阶项,从而将非线性问题转化为线性,可以将卡尔曼线性滤波应用于非线性系统中。这样一
                来,解决了非线性问题。EKF虽然应用于非线性状态估计系统中已经得到了学术界认可并为人广泛使用,然而该种方法也带来了两个缺点,其一是当强非线性时EKF违背局部线性假设,Taylor展开式中被忽略的高阶项带来大的 误差时,
                EKF算法可能会使滤波发散;另外,由于EKF在线性化处理时需要用雅克比(Jacobian)矩阵,其繁琐的计算过程导致该方法实现相对困难。所以,在满足 线性系统、高斯白噪声、所有随机变量服从高斯(Gaussian)分布这3个假设条件时,
                 EKF是最小方差准则下的次优滤波器,其性能依赖于局部非线性度**。


%---------------------------EKF算法实现------------------------------------ 
    fork=2:kk-1
%---------------不考虑噪声时,根据状态方程预测当前值-------------------------- 
    Ag=AntiMatrix(gyro(:,k-1));%计算陀螺仪输出的反对称矩阵
   Ag=[-Ag,   gyro(:,k-1)
    -gyro(:,k-1)', 0];
   Ag=expm(Ag/2/f); %系统一步转移矩阵 
   Tg=AntiMatrix(q(1:3,k-1)); 
  Tg=[Tg+eye(3)*q(4,k-1)
    -(q(1:3,k-1))'];
  Tg=-0.5*Tg/f;%计算系统噪声矩阵
  q(:,k)=Ag*q(:,k-1);%计算姿态四元数的状态估计值
  %------------------------计算此时的方差-------------------------------------
   p=Ag*p*Ag'+Tg*Q*Tg';
  %------------------------计算卡尔曼增益------------------------------------- 
    r=[0,0,g]'; 
    qv=q(1:3,k); %状态方程四元数矢量部分 
    qs=q(4,k);   %状态方程四元数标量部分 
    %计算量测向量 
    Hg=2*[qv'*r*eye(3)+qv*r'-r*qv'+qs*AntiMatrix(r),qs*r+AntiMatrix(r)*qv];
    Kg=p*Hg'*(Hg*p*Hg'+R)^-1;
     %计算卡尔曼增益%------------------根据当前量测值,对预测更新--------------------------------
     Cnb=(qs^2-qv'*qv)*eye(3)+2*qv*qv'-2*qs*AntiMatrix(qv); 
      h=Cnb*r;
      q(:,k)=q(:,k)+Kg*(acc(:,k)-h);
      %-----------------------更新估计值方差--------------------------------------
       p=(eye(4)-Kg*Hg)*p;
       %---------------------------归一化-----------------------------------------
        h(k)=sqrt(q(1,k)^2+q(2,k)^2+q(3,k)^2+q(4,k)^2);q(:,k)=q(:,k)/h(k);
        %----------------------------姿态角计算-------------------------------------
    %补偿后(-180,180)180会出现奇点,-180度正常,但是不影响,实际上-180和180是重合的  
    T33=(q(3,k))^2-(q(2,k))^2-(q(1,k))^2+(q(4,k))^2; 

    T13=2*(q(1,k)*q(3,k)-q(4,k)*q(2,k));

    T23=2*(q(2,k)*q(3,k)+q(4,k)*q(1,k));

    ifT33>0    %根据物理意义不可能出现0

        ANGLE0(1,k)=-180/pi*atan(T13/T33);

    else

        ANGLE0(1,k)=180/pi*(-pi*sign(T13)-atan(T13/T33)); 

    end 

    ANGLE0(2,k)=180/pi*asin(T23);%俯仰角,绕X轴转动 

end

2、矩阵的几种表示方法简介: 


注意此程序的特点,需关注以下问题:   1)如何根据陀螺仪输出计算系统一步转移矩阵;  2)如何根据四元数计算系统的噪声矩阵;   四元数卡尔曼滤波算法的状态方程(由陀螺仪输出计算得到):     四元数卡尔曼滤波的时间输出过程如下:     3)如何根据四元数计算系统的量测向量;   Hg=2*[qv’*r*eye(3)+qv*r’-r*qv’+qs*AntiMatrix(r),qs*r+AntiMatrix(r)*qv];  4)如何根据四元数计算系统的转态转移矩阵;   Cnb=(qs^2-qv’*qv)*eye(3)+2*qv*qv’-2*qs*AntiMatrix(qv);  注意对预测值(即四元数)的更新过程:  q(:,k)=q(:,k)+Kg*(acc(:,k)-h);  因为是由加速度计构建系统的量测方程的,acc(:,k)表示加速度计的量测值,h=Cnb*r为先验估计(不考虑误差,r=[0,0,g]’;),这里是将地理坐标系转化为导航坐标系。  实际上,kalman的5个公式一部分是从状态方程和量测方程上获取的。  5)如何根据四元数计算系统的姿态角:   这里写图片描述这里写图片描述这里写图片描述这里写图片描述这里写图片描述这里写图片描述

1)以下两种表示的是一样的(用逗号或空格隔开表示行):     2)以下两种表示的是一样的(换行或用分号隔开表示的列):     3)矩阵的转置:     4)反对称矩阵用函数表示AntiMatrix():  

这里写图片描述这里写图片描述这里写图片描述这里写图片描述

function[A] =AntiMatrix(B)

  A=[0,-B(3,1),
B(2,1)

    B(3,1),0,
-B(1,1)

   -B(2,1),B(1,1),0];

end

行矩阵不存在反对称矩阵。

1、四元数的几何意义是什么?


这里写图片描述

2、kalman的前提条件:

1)线性系统    2)系统噪声和测量噪声服从高斯分布

阅读(3314) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~