OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 5398|回复: 2

找到圆点博士的一个关于四元数姿态融合的算法 但是不知道输入的参数是怎样处理过的数据 求大神解答呀

[复制链接]

5

主题

43

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
218
金钱
218
注册时间
2020-4-18
在线时间
59 小时
发表于 2021-5-22 16:22:45 | 显示全部楼层 |阅读模式
unsigned char BS004_IMU_Update(float ax,float ay,float az,float gx,float gy,float gz) //ËÄÔaêyμÃÅ·à-½Ç
{
        float norm;//ê¸á¿μÄÄ£
        float vx, vy, vz;//μ±Ç°×Ë쬼ÆËãμÃà′μÄÖØá|ÔúèyÖáéÏμÄ·Öá¿
        float ex, ey, ez;  //μ±Ç°×Ë쬼ÆËãμÃà′μÄÖØá|¼óËù¶èÔúèyÖáéÏμÄ·Öá¿
  //       
        //Ô2μã2©ê¿:ËÄÔaêy3Ë·¨ÔËËã
        float q0q0 = q0 * q0;                                                       
        float q0q1 = q0 * q1;
        float q0q2 = q0 * q2;
        float q1q1 = q1 * q1;
        float q1q3 = q1 * q3;
        float q2q2 = q2 * q2;
        float q2q3 = q2 * q3;
        float q3q3 = q3 * q3;
  if(ax*ay*az==0)//′|óú×ÔóéÂäìå×′ì¬ê±2»½øDD×Ë쬽aËã  »á2úéú·ÖĸÎTÇî′óμÄÇé¿ö
                return 0;
        //Ô2μã2©ê¿:1éò»»ˉ′|àí
        norm = sqrt(ax*ax + ay*ay + az*az);     
        if(norm==0) return 0;       
        ax = ax / norm;//±ä¸üá¿3ìò22»DèòaDT¸ÄKP2Îêy  ÔúÕaàï1éò»»ˉ
        ay = ay / norm;
        az = az / norm;   
  //       
        //Ô2μã2©ê¿:½¨á¢D¡ËÄÖá×ø±êÏμ       
        vx = 2*(q1q3 - q0q2);                                                               
        vy = 2*(q0q1 + q2q3);
        vz = q0q0 - q1q1 - q2q2 + q3q3;
        。。。。。。。。。。。。。
、、、、、、、、、
}
大神们  这个 输入的参数  是处理过的寄存器原始数据吗   那又是如何处理的呢

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

5

主题

43

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
218
金钱
218
注册时间
2020-4-18
在线时间
59 小时
 楼主| 发表于 2021-5-22 16:23:39 | 显示全部楼层
回复 支持 反对

使用道具 举报

4

主题

456

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1072
金钱
1072
注册时间
2021-4-26
在线时间
352 小时
发表于 2021-5-24 10:15:14 | 显示全部楼层
帮顶,楼主发个截图可读性会好一些
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-22 16:59

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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