找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2914|回复: 1
打印 上一主题 下一主题
收起左侧

STM32F1读取MUP9250姿态解算获得pitch,roll,yaw

[复制链接]
跳转到指定楼层
楼主
ID:225844 发表于 2018-4-9 12:49 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
u8 mpu_mpl_get_data(float *pitch,float *roll,float *yaw)
{
        unsigned long sensor_timestamp,timestamp;
        short gyro[3], accel_short[3],compass_short[3],sensors;
        unsigned char more;
        long compass[3],accel[3],quat[4],temperature;
    long data[9];
    int8_t accuracy;

        if(dmp_read_fifo(gyro, accel_short, quat, &sensor_timestamp, &sensors,&more))return 1;         

    if(sensors&INV_XYZ_GYRO)
    {
        inv_build_gyro(gyro,sensor_timestamp);          //°ÑDÂêy¾Y·¢Ëí¸øMPL
        mpu_get_temperature(&temperature,&sensor_timestamp);
        inv_build_temp(temperature,sensor_timestamp);   //°ÑζèÖμ·¢¸øMPL£¬Ö»óDíóÂYòÇDèòaζèÖμ
    }

    if(sensors&INV_XYZ_ACCEL)
    {
        accel[0] = (long)accel_short[0];
        accel[1] = (long)accel_short[1];
        accel[2] = (long)accel_short[2];
      inv_build_accel(accel,0,sensor_timestamp);      //°Ñ¼óËù¶èÖμ·¢¸øMPL
    }

    if (!mpu_get_compass_reg(compass_short, &sensor_timestamp))
    {
        compass[0]=(long)compass_short[0];
        compass[1]=(long)compass_short[1];
        compass[2]=(long)compass_short[2];
                       
        inv_build_compass(compass,0,sensor_timestamp); //°Ñ′Åá|¼ÆÖμ·¢¸øMPL
    }
    inv_execute_on_data();
    inv_get_sensor_type_euler(data,&accuracy,&timestamp);

    *roll  = (data[0]/q16);
    *pitch = -(data[1]/q16);
    *yaw   = -data[2] / q16;
        return 0;
}

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:336453 发表于 2018-5-23 13:51 | 只看该作者
请问这个q16是什么,谢谢
回复

使用道具 举报

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

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

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