搜索
bottom↓
回复: 3

新人求问四元数欧拉角计算问题

[复制链接]

出0入0汤圆

发表于 2015-3-15 15:41:26 | 显示全部楼层 |阅读模式
现在我能正确的读到MPU6050各寄存器的数据,也能将他们处理成正确的加速度,角速度真值,然后用这个函数,输入参数是三轴加速度,角速度真值,但是得到的欧拉角波形是这样的

,显然不对,请高手分析一下是什么原因?
void IMU_update(int gx, int gy, int gz, int ax, int ay, int az)//gx£¬gy£¬gzÊÇÈýÖá½ÇËٶȣ¬ax,ay,azÊÇÈýÖá¼ÓËÙ¶È
{
  float norm;
  float hx, hy, hz, bx, bz;
  float vx, vy, vz,wx, wy, wz;
  float ex, ey, ez;
       
  float q0q0 = q0*q0;
  float q0q1 = q0*q1;
  float q0q2 = q0*q2;
  float q0q3 = q0*q3;
  float q1q1 = q1*q1;
  float q1q2 = q1*q2;
  float q1q3 = q1*q3;
  float q2q2 = q2*q2;
  float q2q3 = q2*q3;
  float q3q3 = q3*q3;

  norm = sqrt(ax*ax + ay*ay + az*az);           
  ax = ax / norm;
  ay = ay / norm;
  az = az / norm;
           
  vx = 2*(q1q3 - q0q2);                                                                               
  vy = 2*(q0q1 + q2q3);
  vz = q0q0 - q1q1 - q2q2 + q3q3 ;

  ex = (ay*vz - az*vy) ;                                                                                                  
  ey = (az*vx - ax*vz) ;
  ez = (ax*vy - ay*vx) ;

  exInt = exInt + ex * Ki;                                                                                                 
  eyInt = eyInt + ey * Ki;
  ezInt = ezInt + ez * Ki;

  gx = gx + Kp*ex + exInt;                                                                                                                       
  gy = gy + Kp*ey + eyInt;
  gz = gz + Kp*ez + ezInt;                                                                                          
                                          
  q0 = q0 + (-q1*gx - q2*gy - q3*gz)*halfT;                
  q1 = q1 + (q0*gx + q2*gz - q3*gy)*halfT;
  q2 = q2 + (q0*gy - q1*gz + q3*gx)*halfT;
  q3 = q3 + (q0*gz + q1*gy - q2*gx)*halfT;

  norm = sqrt(q0*q0 + q1*q1 + q2*q2 + q3*q3);               
  q0 = q0 / norm;
  q1 = q1 / norm;
  q2 = q2 / norm;
  q3 = q3 / norm;
       

Yaw = atan2(2 * q1 * q2 + 2 * q0 * q3, -2 * q2*q2 - 2 * q3* q3+1)* 57.3;//yaw
Pitch = asin(-2 * q1 * q3 + 2 * q0* q2)* 57.3; // pitch
  Roll = atan2(2 * q2 * q3 + 2 * q0 * q1, -2 * q1 * q1 - 2 * q2* q2 + 1)* 57.3; // roll
       
}


本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

阿莫论坛20周年了!感谢大家的支持与爱护!!

一只鸟敢站在脆弱的枝条上歇脚,它依仗的不是枝条不会断,而是自己有翅膀,会飞。

出0入0汤圆

发表于 2015-3-16 19:49:57 | 显示全部楼层
p,i,T参数都调好了吗?

出0入0汤圆

 楼主| 发表于 2015-3-17 09:03:29 | 显示全部楼层
fastchaser 发表于 2015-3-16 19:49
p,i,T参数都调好了吗?

halfT用的是6050姿态解算时间的一半(初始化的时候设置125HZ,时间是0.008s,halfT取的0.004),Kp和Ki与这个有关么?如果有关的话应该如何整定?麻烦了!

出0入0汤圆

发表于 2015-3-17 11:59:12 | 显示全部楼层
FreeStyler 发表于 2015-3-17 09:03
halfT用的是6050姿态解算时间的一半(初始化的时候设置125HZ,时间是0.008s,halfT取的0.004),Kp和Ki与 ...

看不懂你的图   不过这个姿态解算 算法需要注意的就是p,i参数,halfT周期参数,以及载体坐标系的坐标轴定义方向了  没其他问题。 p  i 调参 我也没想到好办法呢  等大神解答。
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-5-15 00:25

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表