欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 汽车 > 新车 > Arduino中使用库文件读取陀螺仪MPU6050欧拉角

Arduino中使用库文件读取陀螺仪MPU6050欧拉角

2025/10/23 2:38:15 来源:https://blog.csdn.net/panjinliang066333/article/details/142493561  浏览:    关键词:Arduino中使用库文件读取陀螺仪MPU6050欧拉角

目录

1、库文件安装

(1)方法1-网上下载库文件

(2)方法2-本地库文件夹中添加

2、欧拉角获取

(1)打开测试程序

(2)读欧拉角程序

(3)坐标系和欧拉角说明

(4)串口数据读取

3、代码

4、下载链接


1、库文件安装

(1)方法1-网上下载库文件

在库中搜索mpu6050,然后安装它

找到如图所示的版本进行安装

(2)方法2-本地库文件夹中添加

找到方法1中下载的压缩文件

如果找不到可以点击本链接,下载

https://download.csdn.net/download/panjinliang066333/89791896

解压后将文件夹复制到如下文件路径,重启软件即可。

重新启动Arduino软件,即可找到MPU6050库文件提供的案例

2、欧拉角获取

(1)打开测试程序

打开例子,使用例子需要做一点修改。或者下载下面改好的例子

https://download.csdn.net/download/panjinliang066333/89791896

(2)读欧拉角程序

(3)坐标系和欧拉角说明

(4)串口数据读取

3、代码

#include "I2Cdev.h"
#include "MPU6050_6Axis_MotionApps20.h"
#if I2CDEV_IMPLEMENTATION == I2CDEV_ARDUINO_WIRE#include "Wire.h"
#endifMPU6050 mpu;#define OUTPUT_READABLE_YAWPITCHROLL
#define INTERRUPT_PIN 2  
#define LED_PIN 13 
bool blinkState = false;// MPU control/status vars
bool dmpReady = false;  // set true if DMP init was successful
uint8_t mpuIntStatus;   // holds actual interrupt status byte from MPU
uint8_t devStatus;      // return status after each device operation (0 = success, !0 = error)
uint16_t packetSize;    // expected DMP packet size (default is 42 bytes)
uint16_t fifoCount;     // count of all bytes currently in FIFO
uint8_t fifoBuffer[64]; // FIFO storage buffer// orientation/motion vars
Quaternion q;           // [w, x, y, z]         quaternion container
VectorInt16 aa;         // [x, y, z]            accel sensor measurements
VectorInt16 aaReal;     // [x, y, z]            gravity-free accel sensor measurements
VectorInt16 aaWorld;    // [x, y, z]            world-frame accel sensor measurements
VectorFloat gravity;    // [x, y, z]            gravity vector
float euler[3];         // [psi, theta, phi]    Euler angle container
float ypr[3];           // [yaw, pitch, roll]   yaw/pitch/roll container and gravity vector// packet structure for InvenSense teapot demo
uint8_t teapotPacket[14] = { '$', 0x02, 0,0, 0,0, 0,0, 0,0, 0x00, 0x00, '\r', '\n' };// ================================================================
// ===               INTERRUPT DETECTION ROUTINE                ===
// ================================================================volatile bool mpuInterrupt = false;     // indicates whether MPU interrupt pin has gone high
void dmpDataReady() 
{mpuInterrupt = true;
}void setup() 
{// join I2C bus (I2Cdev library doesn't do this automatically)#if I2CDEV_IMPLEMENTATION == I2CDEV_ARDUINO_WIREWire.begin();Wire.setClock(400000); // 400kHz I2C clock. Comment this line if having compilation difficulties#elif I2CDEV_IMPLEMENTATION == I2CDEV_BUILTIN_FASTWIREFastwire::setup(400, true);#endifSerial.begin(115200);while (!Serial); Serial.println(F("Initializing I2C devices..."));mpu.initialize();pinMode(INTERRUPT_PIN, INPUT);Serial.println(F("Testing device connections..."));Serial.println(mpu.testConnection() ? F("MPU6050 connection successful") : F("MPU6050 connection failed"));Serial.println(F("\nSend any character to begin DMP programming and demo: "));while (Serial.available() && Serial.read()); // empty bufferwhile (!Serial.available());                 // wait for datawhile (Serial.available() && Serial.read()); // empty buffer again// load and configure the DMPSerial.println(F("Initializing DMP..."));devStatus = mpu.dmpInitialize();// supply your own gyro offsets here, scaled for min sensitivitympu.setXGyroOffset(220);mpu.setYGyroOffset(76);mpu.setZGyroOffset(-85);mpu.setZAccelOffset(1788); // 1688 factory default for my test chip// make sure it worked (returns 0 if so)if (devStatus == 0) {// Calibration Time: generate offsets and calibrate our MPU6050mpu.CalibrateAccel(6);mpu.CalibrateGyro(6);mpu.PrintActiveOffsets();// turn on the DMP, now that it's readySerial.println(F("Enabling DMP..."));mpu.setDMPEnabled(true);// enable Arduino interrupt detectionSerial.print(F("Enabling interrupt detection (Arduino external interrupt "));Serial.print(digitalPinToInterrupt(INTERRUPT_PIN));Serial.println(F(")..."));attachInterrupt(digitalPinToInterrupt(INTERRUPT_PIN), dmpDataReady, RISING);mpuIntStatus = mpu.getIntStatus();Serial.println(F("DMP ready! Waiting for first interrupt..."));dmpReady = true;packetSize = mpu.dmpGetFIFOPacketSize();} else {Serial.print(F("DMP Initialization failed (code "));Serial.print(devStatus);Serial.println(F(")"));}// configure LED for outputpinMode(LED_PIN, OUTPUT);
}void loop() 
{// if programming failed, don't try to do anythingif (!dmpReady) return;// read a packet from FIFOif (mpu.dmpGetCurrentFIFOPacket(fifoBuffer)) { // Get the Latest packet #ifdef OUTPUT_READABLE_QUATERNION// display quaternion values in easy matrix form: w x y zmpu.dmpGetQuaternion(&q, fifoBuffer);Serial.print("quat\t");Serial.print(q.w);Serial.print("\t");Serial.print(q.x);Serial.print("\t");Serial.print(q.y);Serial.print("\t");Serial.println(q.z);#endif#ifdef OUTPUT_READABLE_EULER// display Euler angles in degreesmpu.dmpGetQuaternion(&q, fifoBuffer);mpu.dmpGetEuler(euler, &q);Serial.print("euler\t");Serial.print(euler[0] * 180/M_PI);Serial.print("\t");Serial.print(euler[1] * 180/M_PI);Serial.print("\t");Serial.println(euler[2] * 180/M_PI);#endif#ifdef OUTPUT_READABLE_YAWPITCHROLL// display Euler angles in degreesmpu.dmpGetQuaternion(&q, fifoBuffer);mpu.dmpGetGravity(&gravity, &q);mpu.dmpGetYawPitchRoll(ypr, &q, &gravity);Serial.print("ypr\t");Serial.print(ypr[0] * 180/M_PI);Serial.print("\t");Serial.print(ypr[1] * 180/M_PI);Serial.print("\t");Serial.println(ypr[2] * 180/M_PI);#endif#ifdef OUTPUT_READABLE_REALACCEL// display real acceleration, adjusted to remove gravitympu.dmpGetQuaternion(&q, fifoBuffer);mpu.dmpGetAccel(&aa, fifoBuffer);mpu.dmpGetGravity(&gravity, &q);mpu.dmpGetLinearAccel(&aaReal, &aa, &gravity);Serial.print("areal\t");Serial.print(aaReal.x);Serial.print("\t");Serial.print(aaReal.y);Serial.print("\t");Serial.println(aaReal.z);#endif#ifdef OUTPUT_READABLE_WORLDACCEL// display initial world-frame acceleration, adjusted to remove gravity// and rotated based on known orientation from quaternionmpu.dmpGetQuaternion(&q, fifoBuffer);mpu.dmpGetAccel(&aa, fifoBuffer);mpu.dmpGetGravity(&gravity, &q);mpu.dmpGetLinearAccel(&aaReal, &aa, &gravity);mpu.dmpGetLinearAccelInWorld(&aaWorld, &aaReal, &q);Serial.print("aworld\t");Serial.print(aaWorld.x);Serial.print("\t");Serial.print(aaWorld.y);Serial.print("\t");Serial.println(aaWorld.z);#endif#ifdef OUTPUT_TEAPOT// display quaternion values in InvenSense Teapot demo format:teapotPacket[2] = fifoBuffer[0];teapotPacket[3] = fifoBuffer[1];teapotPacket[4] = fifoBuffer[4];teapotPacket[5] = fifoBuffer[5];teapotPacket[6] = fifoBuffer[8];teapotPacket[7] = fifoBuffer[9];teapotPacket[8] = fifoBuffer[12];teapotPacket[9] = fifoBuffer[13];Serial.write(teapotPacket, 14);teapotPacket[11]++; // packetCount, loops at 0xFF on purpose#endif// blink LED to indicate activityblinkState = !blinkState;digitalWrite(LED_PIN, blinkState);}delay(1000);
}

4、下载链接

https://download.csdn.net/download/panjinliang066333/89791896

参考

https://zhuanlan.zhihu.com/p/710727388

mpu6050陀螺仪计角度的精准实现方法,基于arduino实现_failed to find mpu6050 chip-CSDN博客

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com