English | 简体中文 | 繁體中文 | 日本語 | Deutsch | 한국어
MPU6050是世界上第一款集成的6軸運動跟踪設備,它將3軸陀螺儀、3軸加速度計和數位運動處理器(DMP)全部封裝在4.0x4.0x0.9mm的晶片中。 通過其專用的IIC匯流排,它可以直接接受外部3軸磁力計的輸入,提供完整的9軸運動融合輸出。 擁有6軸集成、數位運動處理器((DMP)和運行時校準固件的MPU6050運動跟踪設備,可以使製造商降低離散運動跟踪設備昂貴又複雜的選擇、鑒定和系統集成成本,保證消費者產品的最佳運動跟踪效能。 MPU6050還設計用於在其輔助IIC匯流排上與多個非慣性數位感測器(如壓力感測器)的介面並具備自動FIFO採集功能。 MPU6050與MPU30X0系列的封裝外形相容。 MPU6050具有3個用於陀螺儀輸出的16比特ADC和3個用於加速度計輸出的16比特ADC。 用戶可程式設計陀螺儀滿標度範圍為±250dps、±500dps、±1000dps和±2000dps,加速度計滿標度範圍為±2g、±4g、±8g和±16g。
LibDriver MPU6050是LibDriver推出的MPU6050的全功能驅動,該驅動提供加速度讀取、角速度讀取、姿態角讀取、DMP讀取和敲擊檢測等功能並且它符合MISRA標準。
/src目錄包含了LibDriver MPU6050的源文件。
/interface目錄包含了LibDriver MPU6050與平台無關的IIC總線模板。
/test目錄包含了LibDriver MPU6050驅動測試程序,該程序可以簡單的測試芯片必要功能。
/example目錄包含了LibDriver MPU6050編程範例。
/doc目錄包含了LibDriver MPU6050離線文檔。
/datasheet目錄包含了MPU6050數據手冊。
/project目錄包含了常用Linux與單片機開發板的工程樣例。所有工程均採用shell腳本作為調試方法,詳細內容可參考每個工程裡面的README.md。
/misra目錄包含了LibDriver MISRA程式碼掃描結果。
參考/interface目錄下與平台無關的IIC總線模板,完成指定平台的IIC總線驅動。
將/src目錄,您使用平臺的介面驅動和您開發的驅動加入工程,如果您想要使用默認的範例驅動,可以將/example目錄加入您的工程。
您可以參考/example目錄下的程式設計範例完成適合您的驅動,如果您想要使用默認的程式設計範例,以下是它們的使用方法。
#include "driver_mpu6050_basic.h"
uint8_t res;
uint32_t i;
uint32_t times;
float g[3];
float dps[3];
float degrees;
mpu6050_address_t addr;
/* init */
addr = MPU6050_ADDRESS_AD0_LOW;
res = mpu6050_basic_init(addr);
if (res != 0)
{
return 1;
}
...
/* read all */
times = 3;
for (i = 0; i < times; i++)
{
/* read */
if (mpu6050_basic_read(g, dps) != 0)
{
(void)mpu6050_basic_deinit();
return 1;
}
...
if (mpu6050_basic_read_temperature(°rees) != 0)
{
(void)mpu6050_basic_deinit();
return 1;
}
...
/* output */
mpu6050_interface_debug_print("mpu6050: %d/%d.\n", i + 1, times);
mpu6050_interface_debug_print("mpu6050: acc x is %0.2fg.\n", g[0]);
mpu6050_interface_debug_print("mpu6050: acc y is %0.2fg.\n", g[1]);
mpu6050_interface_debug_print("mpu6050: acc z is %0.2fg.\n", g[2]);
mpu6050_interface_debug_print("mpu6050: gyro x is %0.2fdps.\n", dps[0]);
mpu6050_interface_debug_print("mpu6050: gyro y is %0.2fdps.\n", dps[1]);
mpu6050_interface_debug_print("mpu6050: gyro z is %0.2fdps.\n", dps[2]);
mpu6050_interface_debug_print("mpu6050: temperature %0.2fC.\n", degrees);
...
/* delay 1000 ms */
mpu6050_interface_delay_ms(1000);
...
}
...
/* deinit */
(void)mpu6050_basic_deinit();
return 0;
#include "driver_mpu6050_fifo.h"
uint32_t i;
uint32_t times;
uint16_t len;
uint8_t (*g_gpio_irq)(void) = NULL;
static int16_t gs_accel_raw[128][3];
static float gs_accel_g[128][3];
static int16_t gs_gyro_raw[128][3];
static float gs_gyro_dps[128][3];
mpu6050_address_t addr;
/* gpio init */
if (gpio_interrupt_init() != 0)
{
return 1;
}
g_gpio_irq = mpu6050_fifo_irq_handler;
/* init */
addr = MPU6050_ADDRESS_AD0_LOW;
if (mpu6050_fifo_init(addr) != 0)
{
g_gpio_irq = NULL;
(void)gpio_interrupt_deinit();
return 1;
}
/* delay 100 ms */
mpu6050_interface_delay_ms(100);
...
times = 3;
for (i = 0; i < times; i++)
{
len = 128;
/* read */
if (mpu6050_fifo_read(gs_accel_raw, gs_accel_g,
gs_gyro_raw, gs_gyro_dps, &len) != 0)
{
(void)mpu6050_fifo_deinit();
g_gpio_irq = NULL;
(void)gpio_interrupt_deinit();
return 1;
}
...
/* output */
mpu6050_interface_debug_print("mpu6050: %d/%d.\n", i + 1, times);
mpu6050_interface_debug_print("mpu6050: fifo %d.\n", len);
mpu6050_interface_debug_print("mpu6050: acc x[0] is %0.2fg.\n", gs_accel_g[0][0]);
mpu6050_interface_debug_print("mpu6050: acc y[0] is %0.2fg.\n", gs_accel_g[0][1]);
mpu6050_interface_debug_print("mpu6050: acc z[0] is %0.2fg.\n", gs_accel_g[0][2]);
mpu6050_interface_debug_print("mpu6050: gyro x[0] is %0.2fdps.\n", gs_gyro_dps[0][0]);
mpu6050_interface_debug_print("mpu6050: gyro y[0] is %0.2fdps.\n", gs_gyro_dps[0][1]);
mpu6050_interface_debug_print("mpu6050: gyro z[0] is %0.2fdps.\n", gs_gyro_dps[0][2]);
...
/* delay 100 ms */
mpu6050_interface_delay_ms(100);
...
}
...
/* deinit */
(void)mpu6050_fifo_deinit();
g_gpio_irq = NULL;
(void)gpio_interrupt_deinit();
return 0;
#include "driver_mpu6050_dmp.h"
uint32_t i;
uint32_t times;
uint32_t cnt;
uint16_t len;
uint8_t (*g_gpio_irq)(void) = NULL;
static int16_t gs_accel_raw[128][3];
static float gs_accel_g[128][3];
static int16_t gs_gyro_raw[128][3];
static float gs_gyro_dps[128][3];
static int32_t gs_quat[128][4];
static float gs_pitch[128];
static float gs_roll[128];
static float gs_yaw[128];
mpu6050_address_t addr;
static void a_receive_callback(uint8_t type)
{
switch (type)
{
case MPU6050_INTERRUPT_MOTION :
{
mpu6050_interface_debug_print("mpu6050: irq motion.\n");
break;
}
case MPU6050_INTERRUPT_FIFO_OVERFLOW :
{
mpu6050_interface_debug_print("mpu6050: irq fifo overflow.\n");
break;
}
case MPU6050_INTERRUPT_I2C_MAST :
{
mpu6050_interface_debug_print("mpu6050: irq i2c master.\n");
break;
}
case MPU6050_INTERRUPT_DMP :
{
mpu6050_interface_debug_print("mpu6050: irq dmp\n");
break;
}
case MPU6050_INTERRUPT_DATA_READY :
{
mpu6050_interface_debug_print("mpu6050: irq data ready\n");
break;
}
default :
{
mpu6050_interface_debug_print("mpu6050: irq unknown code.\n");
break;
}
}
}
static void a_dmp_tap_callback(uint8_t count, uint8_t direction)
{
switch (direction)
{
case MPU6050_DMP_TAP_X_UP :
{
mpu6050_interface_debug_print("mpu6050: tap irq x up with %d.\n", count);
break;
}
case MPU6050_DMP_TAP_X_DOWN :
{
mpu6050_interface_debug_print("mpu6050: tap irq x down with %d.\n", count);
break;
}
case MPU6050_DMP_TAP_Y_UP :
{
mpu6050_interface_debug_print("mpu6050: tap irq y up with %d.\n", count);
break;
}
case MPU6050_DMP_TAP_Y_DOWN :
{
mpu6050_interface_debug_print("mpu6050: tap irq y down with %d.\n", count);
break;
}
case MPU6050_DMP_TAP_Z_UP :
{
mpu6050_interface_debug_print("mpu6050: tap irq z up with %d.\n", count);
break;
}
case MPU6050_DMP_TAP_Z_DOWN :
{
mpu6050_interface_debug_print("mpu6050: tap irq z down with %d.\n", count);
break;
}
default :
{
mpu6050_interface_debug_print("mpu6050: tap irq unknown code.\n");
break;
}
}
}
static void a_dmp_orient_callback(uint8_t orientation)
{
switch (orientation)
{
case MPU6050_DMP_ORIENT_PORTRAIT :
{
mpu6050_interface_debug_print("mpu6050: orient irq portrait.\n");
break;
}
case MPU6050_DMP_ORIENT_LANDSCAPE :
{
mpu6050_interface_debug_print("mpu6050: orient irq landscape.\n");
break;
}
case MPU6050_DMP_ORIENT_REVERSE_PORTRAIT :
{
mpu6050_interface_debug_print("mpu6050: orient irq reverse portrait.\n");
break;
}
case MPU6050_DMP_ORIENT_REVERSE_LANDSCAPE :
{
mpu6050_interface_debug_print("mpu6050: orient irq reverse landscape.\n");
break;
}
default :
{
mpu6050_interface_debug_print("mpu6050: orient irq unknown code.\n");
break;
}
}
}
/* init */
if (gpio_interrupt_init() != 0)
{
return 1;
}
g_gpio_irq = mpu6050_dmp_irq_handler;
/* run dmp function */
addr = MPU6050_ADDRESS_AD0_LOW;
if (mpu6050_dmp_init(addr, a_receive_callback,
a_dmp_tap_callback, a_dmp_orient_callback) != 0)
{
g_gpio_irq = NULL;
(void)gpio_interrupt_deinit();
return 1;
}
/* delay 500 ms */
mpu6050_interface_delay_ms(500);
...
times = 3;
for (i = 0; i < times; i++)
{
len = 128;
/* read */
if (mpu6050_dmp_read_all(gs_accel_raw, gs_accel_g,
gs_gyro_raw, gs_gyro_dps,
gs_quat,
gs_pitch, gs_roll, gs_yaw,
&len) != 0)
{
(void)mpu6050_dmp_deinit();
g_gpio_irq = NULL;
(void)gpio_interrupt_deinit();
return 1;
}
/* output */
mpu6050_interface_debug_print("mpu6050: %d/%d.\n", i + 1, times);
mpu6050_interface_debug_print("mpu6050: fifo %d.\n", len);
mpu6050_interface_debug_print("mpu6050: pitch[0] is %0.2fdeg.\n", gs_pitch[0]);
mpu6050_interface_debug_print("mpu6050: roll[0] is %0.2fdeg.\n", gs_roll[0]);
mpu6050_interface_debug_print("mpu6050: yaw[0] is %0.2fdeg.\n", gs_yaw[0]);
mpu6050_interface_debug_print("mpu6050: acc x[0] is %0.2fg.\n", gs_accel_g[0][0]);
mpu6050_interface_debug_print("mpu6050: acc y[0] is %0.2fg.\n", gs_accel_g[0][1]);
mpu6050_interface_debug_print("mpu6050: acc z[0] is %0.2fg.\n", gs_accel_g[0][2]);
mpu6050_interface_debug_print("mpu6050: gyro x[0] is %0.2fdps.\n", gs_gyro_dps[0][0]);
mpu6050_interface_debug_print("mpu6050: gyro y[0] is %0.2fdps.\n", gs_gyro_dps[0][1]);
mpu6050_interface_debug_print("mpu6050: gyro z[0] is %0.2fdps.\n", gs_gyro_dps[0][2]);
/* delay 500 ms */
mpu6050_interface_delay_ms(500);
....
/* get the pedometer step count */
res = mpu6050_dmp_get_pedometer_counter(&cnt);
if (res != 0)
{
(void)mpu6050_dmp_deinit();
g_gpio_irq = NULL;
(void)gpio_interrupt_deinit();
return 1;
}
...
}
...
/* deinit */
(void)mpu6050_dmp_deinit();
g_gpio_irq = NULL;
(void)gpio_interrupt_deinit();
return 0;
在線文檔: https://www.libdriver.com/docs/mpu6050/index.html。
離線文檔: /doc/html/index.html。
請參攷CONTRIBUTING.md。
版權 (c) 2015 - 現在 LibDriver 版權所有
MIT 許可證(MIT)
特此免費授予任何獲得本軟件副本和相關文檔文件(下稱“軟件”)的人不受限制地處置該軟件的權利,包括不受限制地使用、複製、修改、合併、發布、分發、轉授許可和/或出售該軟件副本,以及再授權被配發了本軟件的人如上的權利,須在下列條件下:
上述版權聲明和本許可聲明應包含在該軟件的所有副本或實質成分中。
本軟件是“如此”提供的,沒有任何形式的明示或暗示的保證,包括但不限於對適銷性、特定用途的適用性和不侵權的保證。在任何情況下,作者或版權持有人都不對任何索賠、損害或其他責任負責,無論這些追責來自合同、侵權或其它行為中,還是產生於、源於或有關於本軟件以及本軟件的使用或其它處置。