一、简介

依据MPU6050六轴运动传感器的原始数据,计算设备当前状态的加速度、角速度和倾斜角度。本项目的主控芯片是nRF52832(SDK:Nordic SDK 17.0.2.),但算法通用,读取原始数据的完整工程来自艾克姆,已上传个人主页。

二、MPU6050初始化和寄存器配置

一般在唤醒MPU6050之前都会用MCU读一下设备地址以检测设备以及通信是否正常:

// !< WHO_AM_I register identifies the device. Expected value is 0x68.#define ADDRESS_WHO_AM_I          (0x75U) bool mpu6050_verify_product_id(void){    uint8_t who_am_i;    if (mpu6050_register_read(ADDRESS_WHO_AM_I, &who_am_i, 1))    {        if (who_am_i != MPU6050_WHO_AM_I)        {            return false;        }        else        {            return true;        }    }    else    {        return false;    }}

上述函数返回true后,才可以开始配置寄存器:

#define MPU_PWR_MGMT1_REG  0x6B//电源管理寄存器1#define MPU_SAMPLE_RATE_REG  0x19//采样频率分频器#define MPU_CFG_REG  0x1A//配置寄存器#define MPU_INT_EN_REG  0x38//中断使能寄存器#define MPU_GYRO_CFG_REG  0x1B//陀螺仪配置寄存器#define MPU_ACCEL_CFG_REG  0x1C//加速度计配置寄存器//唤醒MPU6050(void)mpu6050_register_write(MPU_PWR_MGMT1_REG , 0x00);   //设置采样率(Sample Rate = Gyroscope Output Rate / (1 + SMPLRT_DIV)):1KHz (void)mpu6050_register_write(MPU_SAMPLE_RATE_REG , 0x07);//设置低通滤波器,截止频率是1K,带宽是5K (void)mpu6050_register_write(MPU_CFG_REG , 0x06); //关闭中断(void)mpu6050_register_write(MPU_INT_EN_REG, 0x00); //陀螺仪自检及测量范围,典型值:0x18(不自检,2000deg/s)(void)mpu6050_register_write(MPU_GYRO_CFG_REG , 0x18); //配置加速度传感器量程 +-2G s,不自检 (void)mpu6050_register_write(MPU_ACCEL_CFG_REG,0x00); 

三、加速度、角速度计算公式

1.加速度

某个轴的加速度 a = Range* G * ACC / 32768 . 其中G是当地重力加速度,ACC是该轴的加速度原始数据,Range是由配置加速度量程时写入的参数决定的,关系如下:

根据初始化时写入的数据,不自检,AFS_SEL = 0x00,这里Range = 2:

//配置加速度传感器量程 +-2G s,不自检 (void)mpu6050_register_write(MPU_ACCEL_CFG_REG,0x00); 

2.角速度

某个轴的角速度 g = Range * Gyro / 32768 . Gyro是这个轴的角速度原始数据,Range是由配置角速度量程时写入的参数决定的,关系如下:

根据初始化时写入的数据,不自检,FS_SEL = 0x11,这里Range = 2000:

//陀螺仪自检及测量范围,典型值:0x18(不自检,2000deg/s)(void)mpu6050_register_write(MPU_GYRO_CFG_REG , 0x18);

四、倾斜角度公式

倾斜角度依据加速度原始数据计算,公式如下:

#define x                         0#define z                         1Angle[x] = atan2(AccValue.X, AccValue.Y)*180/3.14f;Angle[z] = atan2(AccValue.Z, AccValue.Y)*180/3.14f;

该公式适用的初始姿态是竖直的,也就是MPU6050的Y轴竖直向上时是初始状态,此时的角度为0。Angle[x] 是x轴与竖直平面的夹角度数,Angle[z] 是z轴与水平平面的夹角度数。

参考:(16条消息) 关于MPU6050的数据获取、分析与处理_acktomas的博客-CSDN博客_mpu6050读取