MPU6050详细介绍

一、MPU6050介绍

MPU6050是由三个陀螺仪和三个加速度传感器组成的6轴运动处理组件

内部主要结构:陀螺仪、加速度计、数字运动处理器DMP(Digital Motion Processor)

MPU6050有两个IIC接口,第一IIC接口可作为主接口给单片机传输数据;第二IIC接口用于连接一个第三方数字传感器(如外部磁力传感器等),然后通过这个IIC接口输出完整的9轴信号,否则只有6轴。

那么三轴、六轴、九轴传感器,这些传感器指的什么?其中到底又有哪些区别呢?

实际上,只要说到多少轴的传感器一般是就是指加速度传感器(即加速计)、角速度传感器(即陀螺仪)、磁感应传感器(即电子罗盘)。这三类传感器测量的数据在空间坐标系中都可以被分解为X,Y,Z三个方向轴的力,因此也常常被称为3轴加速度计、3轴陀螺仪、3轴磁力计。

上面3类传感器有其各自的功能特点及应用,比如加速计可以测量设备的测斜情况,陀螺仪可以测量设备自身的旋转运动,还有磁力计可以定位设备的方位。通过它们相互组合和匹配融合又可以衍生出更多的不同应用,在叫法上通过这样简单的轴数上相加的可以变成六轴传感器或者九轴传感器。

六轴传感器:通常指的是三轴加速度计+三轴陀螺仪,三轴加速器是检测横向加速的,三轴陀螺仪是检测角度旋转和平衡的,可以用在体感游戏上。

九轴传感器:就是三轴加速度计+三轴陀螺仪+三轴磁强计的组合,在飞行器上是广泛应用的。 另外,在九轴传感器基础上在加入气压传感器,从而能获取海拔高度的数据,也有人把这些传感器组合称为十轴传感器。

二、MPU6050引脚说明

1、SCL、SDA:是连接MCU的IIC接口,MCU通过这个IIC接口来控制MPU6050,此时MPU6050作为一个IIC从机设备,接单片机的I2C_SCL。

2、XCL、XDA:辅助IIC用来连接其他器件,可用来连接外部从设备,比如磁传感器,这样就可以组成一个九轴传感器,不需要连接单片机。(并不常用)

3、AD0:地址管脚,可以不接单片机。当MPU6050作为一个IIC从机设备的时候,有8位地址,高7位的地址是固定的,就是WHOAMI寄存器的默认——0x68,最低的一位是由AD0的连线决定的。

AD0接GND时,高8位的最后一位是0,所以iic从机地址是0x68;

AD0接VCC时,高8位的最后一位是1,所以iic从机地址是0x69。

4、INT:数据输出的中断引脚,可以不接单片机,准备好数据之后,通过中断告诉STM32,从而获取数据。

5、VCC:接3.3V或5V电源,GND:接地

三、MPU6050工作原理

通过MPU6050读取加速度和角度的原始数据,数据管理平台(DMP)将原始角速度转化为四元数,进而完成欧拉角的计算。

MPU6050自带数字运动处理器(DMP),通过主IIC接口,可以向CPU提供四元数,CPU可利用四元数得到欧拉角。

MPU6050含有一个第二IIC接口,可用于连接外部磁力传感器;

角速感测范围±250、±500、±1000与±2000°/sec

四元数是什么?

四元数就是简单的超复数,由实数加上三个虚数单位 i、j和k 组成,

就是形如a + bi+ cj + dk的数,其中a、b、c 、d是实数,

i2 = j2 = k2 = -1, io = jo = ko = 1 。

对于i、j和k本身的几何意义可以理解为一种旋转,其中

i 旋转代表Z轴与Y轴相交平面中Z轴正向向Y轴正向的旋转,

j 旋转代表X轴与Z轴相交平面中X轴正向向Z轴正向的旋转,

k旋转代表Y轴与X轴相交平面中Y轴正向向X轴正向的旋转,

-i、-j、-k分别代表i、j、k旋转的反向旋转。

欧拉角(ψ,θ,φ)

用来确定定点转动刚体位置的3个一组独立角参量,由章动角θ、旋进角(即进动角)ψ和自转角φ组成。简单来说,欧拉角就是物体绕坐标系三个坐标轴(x,y,z)的旋转角度。

以航空次序欧拉角为例,简单理解欧拉角的三个参量:

ψ 通常代表方向或偏航(heading or yaw)

θ 通常代表升降或俯仰(elevation or pitch)

φ 通常代表倾斜或横滚(bank or roll)

姿态角

什么是姿态角(Euler角) pitch yaw roll

陀螺仪是测角速度的,加速度传感器是测角加速度的,二者数据通过算法就可以得到航向角(yaw) 横滚角(roll) 俯仰角(pitch)了,单位均为度。

姿态角和欧拉角区别

对于旋转问题,欧拉角指的是绕某个轴旋转的角度,姿态角指的是载体系与导航系之间的关系。

滚转角是z轴与通过x轴的铅锤面的夹角,

航向角是x轴投影到水平面与导航系的夹角

俯仰角则是x轴与水平面的夹角。

虽然姿态角与欧拉角概念不同,但由于导航系到载体系旋转矩阵的旋转顺序是ZYX(NED坐标系),所以滚转角,航向角,俯仰角可以等价于欧拉角。姿态角可以说是其中一对特殊的欧拉角。

代码实现姿态角

#include "stm32f1xx_hal.h"
#include "MPU6050.h" // 确保你已经包含了适用于STM32的MPU6050库MPU6050 mpu6050(I2C_ADDRESS_AD0_LOW); // 使用正确的I2C地址void SystemClock_Config(void);
void MX_I2C1_Init(void);
void MPU6050_Init(void);int main(void) {HAL_Init();SystemClock_Config();MX_I2C1_Init();MPU6050_Init(); // 初始化MPU6050if (!mpu6050.testConnection()) {// 传感器连接失败的处理while (1);}while (1) {int16_t ax, ay, az, gx, gy, gz;mpu6050.getMotion6(&ax, &ay, &az, &gx, &gy, &gz);float accX = ax * MPU6050_SENSITIVITY_16G / 32768.0f;float accY = ay * MPU6050_SENSITIVITY_16G / 32768.0f;float accZ = az * MPU6050_SENSITIVITY_16G / 32768.0f;float gyroX = gx * MPU6050_SENSITIVITY_2000DPS / 32768.0f;float gyroY = gy * MPU6050_SENSITIVITY_2000DPS / 32768.0f;float gyroZ = gz * MPU6050_SENSITIVITY_2000DPS / 32768.0f;// 计算姿态角,这里使用简单的数学转换作为示例float pitch = atan(accY / sqrt(accX * accX + accZ * accZ)) * (180.0f / M_PI);float roll = atan(accX / sqrt(accY * accY + accZ * accZ)) * (180.0f / M_PI);float yaw = atan2(gy, gz) * (180.0f / M_PI); // 简单的yaw计算,可能需要更复杂的滤波// 输出姿态角printf("Pitch: %f, Roll: %f, Yaw: %f\r\n", pitch, roll, yaw);HAL_Delay(100); // 简单的时间延迟}
}

int16_t ax, ay, az, gx, gy, gz;这些是16位整数变量,用于存储从MPU-6050读取的原始加速度计和陀螺仪数据。

getMotion6函数从MPU-6050读取六个值:X轴加速度(ax)、Y轴加速度(ay)、Z轴加速度(az)、X轴角速度(gx)、Y轴角速度(gy)和Z轴角速度(gz)。

这些行将原始加速度计数据转换为实际的加速度值(单位:g,1g ≈ 9.81 m/s²)。MPU6050_SENSITIVITY_16G是加速度计的灵敏度因子,32768.0f是16位整数的最大值(即2^15)。

同理,下面一行,将原始陀螺仪数据转换为实际的角速度值(单位:度/秒)。MPU6050_SENSITIVITY_2000DPS是陀螺仪的灵敏度因子。

俯仰角是通过解算加速度计在Y轴上的分量与X轴和Z轴分量的平方和的平方根的比值得到的。atan函数返回的是弧度值,通过乘以(180.0f / M_PI)转换为度。

横滚角是通过解算加速度计在X轴上的分量与Y轴和Z轴分量的平方和的平方根的比值得到的。

 

偏航角通常更复杂,因为它可能受到加速度计和陀螺仪数据的共同影响。这里的简化版本仅使用陀螺仪的Y轴和Z轴数据,atan2函数返回正确的象限角度,然后转换为度。

这些计算提供了一个基本的姿态估计,但可能不够稳定或准确,特别是在存在噪声和传感器误差的情况下。在实际应用中,通常会使用更高级的滤波算法(如卡尔曼滤波器、马德威克算法或非线性观测器)来提高姿态估计的准确性和稳定性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/403990.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CSP-CCF 202012-1 期末预测之安全指数

一、问题描述 二、解答 #include<iostream> using namespace std; int main() {int n;cin >> n;int w[100001] { 0 };int score[100001] { 0 };for (int i 1; i < n; i){cin >> w[i] >> score[i];}int y 0;for (int i 1; i < n; i){y y …

电脑监控软件有哪些,哪款更好用?一网打尽!电脑监控软件大搜罗,总有一款适合你!

甲&#xff1a;哎&#xff0c;您听说了吗&#xff1f;这年头&#xff0c;电脑监控软件那是五花八门&#xff0c;跟变戏法似的&#xff01; 乙&#xff1a;哦&#xff1f;怎么个五花八门法&#xff1f; 甲&#xff1a;嘿&#xff0c;您还别说&#xff0c;从实时监控到网络追踪…

在HFSS中对曲线等结构进行分割(Split)

在HFSS中对曲线进行分割 我们往往需要把DXF等其他类型文件导入HFSS进行分析&#xff0c;但是有时需要对某一个曲线单独进行分割成两段修改。 如果是使用HFSS绘制的曲线&#xff0c;我们修改起来非常方便&#xff0c;修改参数即可。但是如果是导入的曲线&#xff0c;则需要使用…

js实现图片以鼠标为中心滚轮缩放-vue

功能背景 实现以鼠标在图中的位置为中心进行图片的滚轮缩放&#xff0c;现在是无论鼠标位置在哪都以图片中心进行缩放&#xff0c;这不符合预期&#xff1b; 关键点 缩放前鼠标在的位置是 A&#xff08;clinetX,clientY&#xff09; 点&#xff0c;缩放后鼠标的位置是 A’&a…

技术分享-商城篇-订单支付微信篇(十二)

B2C商城微信支付全解析&#xff1a;H5支付、小程序支付、JSAPI支付与APP支付 引言 在之前的文章中&#xff0c;我们聊了B2B2C的商城相关功能模块&#xff0c;如&#xff1a;首页布局、商品、购物车、购物结算、订单支付等&#xff0c;但是B2C商城的订单支付方式的选择&#x…

【Docker】Centos系统没有Vpn时候安装Docker

【Docker】没有Vpn时候安装Docker 背景1.安装docker之前先卸载2.基础配置3.安装docker5. 问题解决6.配置docker镜像源&#xff0c;解决网络超时 背景 工作中习惯VPN或者服务器节点为国外或者香港节点&#xff0c;最近买了一台国内服务器网络受到各种限制。 1.安装docker之前先…

uniapp/vue个性化单选、复选组件

个性化单选和复选组件在网页设计中非常常见&#xff0c;它们不仅能够提升用户界面的美观度&#xff0c;还能改善用户体验。此组件是使用vue uniapp实现的个性化单选复选组件。设计完成后&#xff0c;点击生成源码即可。 拖动组件过设计区 每行显示数量 默认支持每行三个&#…

扎心“我学了六个月 Python,怎么还是会找不到工作”

前言 &#x1f449; 小编已经为大家准备好了完整的代码和完整的Python学习资料&#xff0c;朋友们如果需要可以扫描下方CSDN官方认证二维码或者点击链接免费领取【保证100%免费】 在编程界&#xff0c;Python是一种神奇的存在。有人认为&#xff0c;只有用Python才能优雅写代码…

等保测评中的安全需求分析:构建精准的信息安全防护体系

在数字化转型的时代背景下&#xff0c;信息安全成为企业发展的关键因素之一。等保测评&#xff0c;作为我国信息安全等级保护制度的重要组成部分&#xff0c;要求企业进行详细的安全需求分析&#xff0c;以构建精准、有效的信息安全防护体系。本文旨在探讨等保测评中的安全需求…

ThreeJs学习笔记--坐标系,光源,相机控件

坐标系 一、创建添加坐标系 给场景添加坐标系THREE.AxesHelper()的参数表示坐标系坐标轴线段尺寸大小&#xff0c;你可以根据需要改变尺寸 const axesHelper new THREE.AxesHelper(200)//数值是坐标的尺寸 scene.add(axesHelper)//添加到场景里 坐标系包含三个坐标轴&…

本地ComfyUI安装全记录

资料 先看我写的stable diffusion全记录 ComfyUI 完全入门&#xff1a;安装部署 ComfyUI 完全入门&#xff1a;图生视频 ComfyUI【强烈推荐】 秋葉aaaki comfy UI整合包 可以使用stable diffusion的大模型&#xff0c;通过修改文件重新指向 修改路径即可 下载秋叶大佬的…

python之matplotlib (3 坐标轴设置)

写在前面 在说明坐标轴设置之前&#xff0c;我有必要和大家说清楚图像设置的一些方法&#xff0c;避免陷入困扰模糊的地步。前面我们说过&#xff0c;画图的三种方法&#xff08;python之matplotlib &#xff08;1 介绍及基本用法&#xff09;-CSDN博客&#xff09;。而设置也…

yolov8目标检测与速度估计

我们可能都见过限速路牌。我们中的一些人甚至可能收到过通过邮寄或电子邮件发送的自动限速违规通知。人工智能&#xff08;AI&#xff09;交通管理系统可以利用计算机视觉技术自动标记超速违规行为。路灯和高速公路上的摄像头拍摄的实时画面可用于估算车速和加强道路安全。 车速…

博世(BOSCH)× Milvus:智能驾驶领域的数据挖掘革新

01.博世智能驾控&#xff1a;智能驾驶技术的领航者 博世&#xff08;BOSCH&#xff09;智能驾控是全球汽车技术领域的领导者&#xff0c;以其在自动驾驶技术上的创新和深厚历史而闻名。博世的自动驾驶解决方案&#xff0c;包括先进的驾驶辅助系统&#xff08;ADAS&#xff09;…

【数据结构与算法】归并排序

归并排序目录 一.归并排序的原理二.有序的归并实现三.无序的归并实现(分治法)四.归并排序的实现五.完整代码 一.归并排序的原理 如何将这两个数组排序? 二.有序的归并实现 将一个数组分为两段,那边的值小就加入到新数组中,直到一边已经加完了. 有一种情况就是一边已经加入…

骑行耳机哪个牌子好用?选购骑行耳机需要注意的五大选购陷阱!

作为一名有着多年骑行经验的专业评测师&#xff0c;对骑行装备已经有着超过五年的研究&#xff0c;骑行耳机也不例外&#xff0c;期间也是亲身测试了数十款骨传导耳机&#xff0c;可以说骑行耳机是专为骑行爱好者设计的&#xff0c;不需要入耳佩戴&#xff0c;而且佩戴舒服&…

基于云快充协议1.5-1.6版本的充电桩系统软件-充电桩系统 -新能源车充电平台源码

介绍 SpringBoot 框架&#xff0c;充电桩平台充电桩系统充电平台充电桩互联互通协议云快充协议1.5-1.6协议新能源汽车二轮车公交车二轮车充电-四轮车充电充电源代码充电平台源码Java源码 充电桩平台充电桩系统充电桩小程序充电桩管理系统充电桩项目充电桩协议充电桩微信小程序S…

鸿蒙开发入门day10-组件导航

(创作不易&#xff0c;感谢有你&#xff0c;你的支持&#xff0c;就是我前行的最大动力&#xff0c;如果看完对你有帮助&#xff0c;还请三连支持一波哇ヾ(&#xff20;^∇^&#xff20;)ノ&#xff09; 目录 组件导航 (Navigation) 设置页面显示模式 设置标题栏模式 设置菜…

整数分解5.3.2

题 前面写过逆序的 最后一个数后面不要有空格 #include <stdio.h>int main() {int x;scanf("%d",&x);int d;do{dx%10;printf("%d",d);if(x>10){printf(" ");}x/10;}while(x>0);printf("\n");return 0; } 现在这个是…

Linux网络:基于OS的网络架构

Linux网络&#xff1a;OS视角下的网络架构 网络分层模型OSI 七层模型TCP/IP 五层模型 协议操作系统与网络网络相关命令ifconfigpingnetstat 本博客将基于操作系统&#xff0c;讲解计算机网络的设计理念&#xff0c;帮助大家理解操作系统与网络之间的关系。 网络分层模型 网络…