在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

如何將加速度計和陀螺儀數據融合在一起

454398 ? 來源:網絡整理 ? 作者:網絡整理 ? 2019-11-11 17:19 ? 次閱讀

步驟1:MPU-6050模塊

MPU-6050模塊具有8個引腳,

INT:中斷數字輸出引腳。

AD0: I2C從地址LSB引腳。這是設備7位從機地址中的第0位。如果連接到VCC,則將其讀為邏輯1,并且從機地址更改。

XCL:輔助串行時鐘引腳。此引腳用于將其他具有I2C接口功能的傳感器SCL引腳連接到MPU-6050。

XDA:輔助串行數據引腳。該引腳用于將其他啟用I2C接口的傳感器SDA引腳連接到MPU-6050。

SCL:串行時鐘引腳。將此引腳連接到微控制器的SCL引腳。 SDA:串行數據引腳。將此引腳連接到微控制器的SDA引腳。

GND:接地引腳。將此引腳接地。

VCC:電源引腳。將此引腳連接到+ 5V DC電源。 MPU-6050模塊的從站地址(當AD0 = 0時,即未連接到Vcc)為

從站寫地址(SLA + W): 0xD0

從站讀取地址(SLA + R): 0xD1

步驟2:計算

MPU6050模塊的陀螺儀和加速度計傳感器數據由2的補碼形式的16位原始數據組成。

MPU6050模塊的溫度傳感器數據由16位數據組成(不是2的補碼形式)。

現在假設我們選擇了

-加速度計滿量程范圍+/- 2g,靈敏度比例因子為16,384 LSB(Count)/g。

-陀螺儀的滿量程范圍為+/- 250°/s,靈敏度比例因子為131 LSB(計數)/°/s。然后,

要獲取傳感器原始數據,我們首先需要對加速度計和陀螺儀的傳感器數據進行2的補碼運算。在獲得傳感器原始數據之后,我們可以通過將傳感器原始數據除以它們的靈敏度比例因子來計算加速度和角速度,方法如下:

以g(g力)計的加速度計值

ul》

沿X軸的加速度=(加速度計X軸原始數據/16384)g。

沿Y軸的加速度=(加速度計Y軸原始數據/16384)g。

沿Z軸的加速度=(加速度計Z軸原始數據/16384)g。

陀螺儀值,以°/s(每秒度)為單位

沿X軸的角速度=(陀螺儀X軸原始數據/131)°/s。

沿Y軸的角速度=(陀螺儀Y軸原始數據/131)°/s。

沿Z軸的角速度=(陀螺儀Z軸原始數據/131)°/s。

以°/c為單位的溫度值(每度攝氏度)

以攝氏度為單位的溫度=((溫度傳感器數據)/340 + 36.53)°/c。

例如

假設在2‘補碼之后得到加速度計X軸原始值= +15454

然后Ax = +15454/16384 = 0.94 g。

更多

所以我們知道我們在+/- 2G和+/- 250deg/s的靈敏度下運行,但是我們的值如何與這些加速度/角度相對應。

這兩者都是直線圖,我們可以從中得出結果,對于1G,我們將讀取16384,對于1deg/sec,我們將讀取131.07(盡管由于二進制,0.07將被忽略),這些值只是通過繪制直線圖得出的在32767時2G在-32768時為-2G,在250/-250時為-2G。

所以現在我們知道了靈敏度值(16384和131.07),我們只需要減去這些值的偏移量即可。然后

這些對于X和Y值都適用,但是由于Z記錄為1G而不是0,因此在除以靈敏度之前,我們需要減去1G(16384)。

步驟3:MPU6050-Atmega328p連接

。..

連接如下:-

MPU6050 《======》 Arduino Nano。

VCC 《====== 》 5v輸出引腳

GND 《======》接地引腳

SDA 《======》 A4引腳//串行數據

SCL 《======》 A5引腳//串行時鐘

俯仰和橫滾計算:

滾動是圍繞旋轉x軸和螺距是沿y軸的旋轉。

結果以弧度為單位。 (乘以180并除以pi即可轉換為度)

步驟4:代碼和說明

#include

const int MPU=0x68; //I2C address of the MPU-6050

int16_t AcX,AcY,AcZ,Tmp,GyX,GyY,GyZ; //16-bit integers

int AcXcal,AcYcal,AcZcal,GyXcal,GyYcal,GyZcal,tcal; //calibration variables

double t,tx,tf,pitch,roll;

void setup()

{

Wire.begin(); //initiate wire library and I2C

Wire.beginTransmission(MPU); //begin transmission to I2C slave device

Wire.write(0x6B); // PWR_MGMT_1 register

Wire.write(0); // set to zero (wakes up the MPU-6050)

Wire.endTransmission(true); //ends transmission to I2C slave device

Serial.begin(9600); //serial communication at 9600 bauds

}

void loop()

{

Wire.beginTransmission(MPU); //begin transmission to I2C slave device

Wire.write(0x3B); // starting with register 0x3B (ACCEL_XOUT_H)

Wire.endTransmission(false); //restarts transmission to I2C slave device

Wire.requestFrom(MPU,14,true); //request 14 registers in total

//Acceleration data correction

AcXcal = -950;

AcYcal = -300;

AcZcal = 0;

//Temperature correction

tcal = -1600;

//Gyro correction

GyXcal = 480;

GyYcal = 170;

GyZcal = 210;

//read accelerometer data

AcX=Wire.read()《《8|Wire.read(); // 0x3B (ACCEL_XOUT_H) 0x3C (ACCEL_XOUT_L)

AcY=Wire.read()《《8|Wire.read(); // 0x3D (ACCEL_YOUT_H) 0x3E (ACCEL_YOUT_L)

AcZ=Wire.read()《《8|Wire.read(); // 0x3F (ACCEL_ZOUT_H) 0x40 (ACCEL_ZOUT_L)

//read temperature data

Tmp=Wire.read()《《8|Wire.read(); // 0x41 (TEMP_OUT_H) 0x42 (TEMP_OUT_L)

//read gyroscope data

GyX=Wire.read()《《8|Wire.read(); // 0x43 (GYRO_XOUT_H) 0x44 (GYRO_XOUT_L)

GyY=Wire.read()《《8|Wire.read(); // 0x45 (GYRO_YOUT_H) 0x46 (GYRO_YOUT_L)

GyZ=Wire.read()《《8|Wire.read(); // 0x47 (GYRO_ZOUT_H) 0x48 (GYRO_ZOUT_L)

//temperature calculation

tx = Tmp + tcal;

t = tx/340 + 36.53; //equation for temperature in degrees C from datasheet

tf = (t * 9/5) + 32; //fahrenheit

//get pitch/roll

getAngle(AcX,AcY,AcZ);

//printing values to serial port

Serial.print(“Angle: ”);

Serial.print(“Pitch = ”); Serial.print(pitch);

Serial.print(“ Roll = ”); Serial.println(roll);

Serial.print(“Accelerometer: ”);

Serial.print(“X = ”); Serial.print(AcX + AcXcal);

Serial.print(“ Y = ”); Serial.print(AcY + AcYcal);

Serial.print(“ Z = ”); Serial.println(AcZ + AcZcal);

Serial.print(“Temperature in celsius = ”); Serial.print(t);

Serial.print(“ fahrenheit = ”); Serial.println(tf);

Serial.print(“Gyroscope: ”);

Serial.print(“X = ”); Serial.print(GyX + GyXcal);

Serial.print(“ Y = ”); Serial.print(GyY + GyYcal);

Serial.print(“ Z = ”); Serial.println(GyZ + GyZcal);

delay(1000);

}

//function to convert accelerometer values into pitch and roll

void getAngle(int Ax,int Ay,int Az)

{

double x = Ax;

double y = Ay;

double z = Az; pitch = atan(x/sqrt((y*y) + (z*z))); //pitch calculation

roll = atan(y/sqrt((x*x) + (z*z))); //roll calculation

//converting radians into degrees

pitch = pitch * (180.0/3.14);

roll = roll * (180.0/3.14) ;

}

-----------------------------------------------------------------------------------------------

Results:-

--------------------------------------------------------------------------------------

Angle: Pitch = 88.89 Roll = -0.47

Accelerometer: X = 15974 Y = -440 Z = 312

Temperature in celsius = 29.38 fahrenheit = 84.88

Gyroscope: X = -111 Y = 341 Z = 211

Angle: Pitch = 89.41 Roll = -0.27

Accelerometer: X = 16102 Y = -380 Z = 172

Temperature in celsius = 29.42 fahrenheit = 84.96

Gyroscope: X = -115 Y = 373 Z = 228

Angle: Pitch = 89.28 Roll = -0.34

Accelerometer: X = 16058 Y = -400 Z = 204

Temperature in celsius = 29.42 fahrenheit = 84.96

Gyroscope: X = -98 Y = 354 Z = 224

Angle: Pitch = 88.83 Roll = -0.54

Accelerometer: X = 15978 Y = -460 Z = 320

Temperature in celsius = 29.33 fahrenheit = 84.79

Gyroscope: X = -124 Y = 376 Z = 207

Angle: Pitch = 89.21 Roll = -0.31

Accelerometer: X = 15978 Y = -392 Z = 228

Temperature in celsius = 29.42 fahrenheit = 84.96

Gyroscope: X = -121 Y = 364 Z = 189

Angle: Pitch = 89.00 Roll = -0.56

Accelerometer: X = 15890 Y = -464 Z = 260

Temperature in celsius = 29.38 fahrenheit = 84.88

Gyroscope: X = -111 Y = 361 Z = 221

Angle: Pitch = 88.67 Roll = -0.65

Accelerometer: X = 16018 Y = -492 Z = 360

Temperature in celsius = 29.38 fahrenheit = 84.88

Gyroscope: X = -130 Y = 340 Z = 216

Angle: Pitch = 88.53 Roll = -0.43

Accelerometer: X = 16110 Y = -428 Z = 432

Temperature in celsius = 29.42 fahrenheit = 84.96

Gyroscope: X = -92 Y = 380 Z = 217

Angle: Pitch = 88.85 Roll = -0.60

Accelerometer: X = 15930 Y = -476 Z = 304

Temperature in celsius = 29.47 fahrenheit = 85.05

Gyroscope: X = -102 Y = 374 Z = 219

Angle: Pitch = 88.87 Roll = -0.24

Accelerometer: X = 16222 Y = -372 Z = 344

Temperature in celsius = 29.52 fahrenheit = 85.13

Gyroscope: X = -96 Y = 351 Z = 226

Angle: Pitch = 89.05 Roll = -0.26

Accelerometer: X = 15970 Y = -376 Z = 284

Temperature in celsius = 29.38 fahrenheit = 84.88

Gyroscope: X = -105 Y = 367 Z = 201

Angle: Pitch = 89.13 Roll = -0.62

Accelerometer: X = 16034 Y = -484 Z = 200

Temperature in celsius = 29.52 fahrenheit = 85.13

Gyroscope: X = -110 Y = 391 Z = 207

Angle: Pitch = 88.98 Roll = -0.51

Accelerometer: X = 16178 Y = -452 Z = 280

Temperature in celsius = 29.47 fahrenheit = 85.05

Gyroscope: X = -117 Y = 379 Z = 221

Angle: Pitch = 89.27 Roll = -0.43

Accelerometer: X = 16066 Y = -428 Z = 192

Temperature in celsius = 29.42 fahrenheit = 84.96

Gyroscope: X = -101 Y = 359 Z = 208

Angle: Pitch = 89.31 Roll = -0.19

Accelerometer: X = 16150 Y = -356 Z = 212

Temperature in celsius = 29.52 fahrenheit = 85.13

Gyroscope: X = -115 Y = 361 Z = 189

Angle: Pitch = 88.76 Roll = -0.51

Accelerometer: X = 16026 Y = -452 Z = 348

Temperature in celsius = 29.42 fahrenheit = 84.96

Gyroscope: X = -139 Y = 368 Z = 192

Angle: Pitch = 88.57 Roll = -0.69

Accelerometer: X = 16086 Y = -504 Z = 388

Temperature in celsius = 29.33 fahrenheit = 84.79

Gyroscope: X = -118 Y = 352 Z = 214

步驟5:了解傾斜角

加速度計

地球的重力是恒定的加速度,力始終指向降到地球中心

當加速度計與重力平行時,測得的加速度將為1G,當加速度計與重力垂直時,加速度將為0G。

傾斜角可以使用以下公式從測量的加速度中計算出:

θ= sin-1(測量的加速度/重力加速度)

陀螺儀

陀螺儀(又稱速率傳感器)用于測量角速度(ω)。

為了獲得機器人的傾斜角,我們需要將陀螺儀的數據如下式所示:

ω=dθ/dt,

θ=∫ωdt

Gyro和加速度傳感器Fusio n

在研究了陀螺儀和加速度計的特性之后,我們知道它們各有優缺點。根據加速度計數據計算出的傾斜角具有較慢的響應時間,而根據陀螺儀數據計算出的積分傾斜角會在一段時間內發生漂移。換句話說,可以說加速度計數據對長期有用,而陀螺儀數據對短期有用。

責任編輯:wv

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 陀螺儀
    +關注

    關注

    44

    文章

    785

    瀏覽量

    98746
  • 加速度計
    +關注

    關注

    6

    文章

    702

    瀏覽量

    45910
收藏 人收藏

    評論

    相關推薦

    MEMS加速度計的工作原理是什么

    MEMS加速度計的工作原理主要基于牛頓第二定律,即力等于質量乘以加速度。以下是對其工作原理的介紹: 、核心部件與結構 MEMS加速度計的核心部件包括
    的頭像 發表于 11-20 10:09 ?696次閱讀

    EPSON工業級加速度計選型

    愛普生加速度計(Accelerometers)是種工業級三軸輸出壓電式加速度傳感器,采用具有專利技術的雙音叉式石英傳感器元件和Quarts光刻技術,通過壓電效應來計算出諸如此類的內容物體運動的方向
    的頭像 發表于 09-19 15:31 ?309次閱讀
    EPSON工業級<b class='flag-5'>加速度計</b>選型

    5G信號鏈與電平轉換結合在一起

    電子發燒友網站提供《5G信號鏈與電平轉換結合在一起.pdf》資料免費下載
    發表于 09-18 14:49 ?0次下載
    <b class='flag-5'>將</b>5G信號鏈與電平轉換結<b class='flag-5'>合在一起</b>

    陀螺儀LSM6DSV16X與AI集成(11)----融合磁力進行姿態解算

    MotionFX庫包含用于校準陀螺儀加速度計和磁力傳感器的例程。 磁力數據
    的頭像 發表于 09-06 16:57 ?1996次閱讀
    <b class='flag-5'>陀螺儀</b>LSM6DSV16X與AI集成(11)----<b class='flag-5'>融合</b>磁力<b class='flag-5'>計</b>進行姿態解算

    陀螺儀LSM6DSOW開發(9)----加速度校準

    MotionAC 是 STMicroelectronics 提供的款用于加速度計校準的中間件庫。該庫可以實時計算加速度計的偏移和比例因子,并對傳感器數據進行補償,從而提高測量精度
    的頭像 發表于 08-23 10:07 ?1686次閱讀
    <b class='flag-5'>陀螺儀</b>LSM6DSOW開發(9)----<b class='flag-5'>加速度</b>校準

    陀螺儀LSM6DSOW開發(5)----MotionFX庫解析空間坐標

    本文探討如何使用MotionFX庫解析空間坐標。MotionFX庫是種用于傳感器融合的強大工具,可以加速度計
    的頭像 發表于 08-15 18:13 ?1689次閱讀
    <b class='flag-5'>陀螺儀</b>LSM6DSOW開發(5)----MotionFX庫解析空間坐標

    e2studio開發三軸加速度計LIS2DW12(2)----基于中斷信號獲取加速度數據

    本文介紹實時獲取和處理加速度數據。程序的核心流程包括初始化硬件接口、配置加速度計的參數,以及通過輪詢檢查中斷信號來不斷讀取加速度數據
    的頭像 發表于 08-09 15:43 ?532次閱讀
    e2studio開發三軸<b class='flag-5'>加速度計</b>LIS2DW12(2)----基于中斷信號獲取<b class='flag-5'>加速度數據</b>

    陀螺儀LSM6DSOW開發(4)----中斷獲取FIFO數據

    本文探討如何使用中斷機制獲取FIFO數據并應用MotionFX庫解析空間坐標。MotionFX庫是種用于傳感器融合的強大工具,可以
    的頭像 發表于 08-08 16:03 ?715次閱讀
    <b class='flag-5'>陀螺儀</b>LSM6DSOW開發(4)----中斷獲取FIFO<b class='flag-5'>數據</b>

    陀螺儀LSM6DSOW開發(2)----上報匿名上位機實現可視化

    本文檔詳細介紹了如何使用匿名助手的上位機實現加速度計陀螺儀數據的可視化顯示。內容涵蓋了加速度計陀螺儀的工作原理、上位機通信協議、
    的頭像 發表于 08-05 09:52 ?1491次閱讀
    <b class='flag-5'>陀螺儀</b>LSM6DSOW開發(2)----上報匿名上位機實現可視化

    驅動LSM6DS3TR-C實現高效運動檢測與數據采集(10)----融合磁力進行姿態解算

    MotionFX庫包含用于校準陀螺儀加速度計和磁力傳感器的例程。 磁力數據
    的頭像 發表于 08-02 15:50 ?2250次閱讀
    驅動LSM6DS3TR-C實現高效運動檢測與<b class='flag-5'>數據</b>采集(10)----<b class='flag-5'>融合</b>磁力<b class='flag-5'>計</b>進行姿態解算

    陀螺儀LSM6DSV16X與AI集成(8)----MotionFX庫解析空間坐標

    本文探討如何使用MotionFX庫解析空間坐標。MotionFX庫是種用于傳感器融合的強大工具,可以加速度計
    的頭像 發表于 07-18 10:43 ?1209次閱讀
    <b class='flag-5'>陀螺儀</b>LSM6DSV16X與AI集成(8)----MotionFX庫解析空間坐標

    三軸加速度計LIS2DUX12開發(2)----靜態校準

    零偏是影響加速度計輸出精度的重要指標之,零偏可分為靜態零偏和動態零偏 。靜態零偏也稱為固定零偏,通常經標定與補償減小靜態零偏。動態零偏是由于加速度計自身的缺陷或環境因素(如溫度、振動、電子干擾等
    的頭像 發表于 05-17 15:27 ?1249次閱讀
    三軸<b class='flag-5'>加速度計</b>LIS2DUX12開發(2)----靜態校準

    陀螺儀傳感器,IMU和加速度計的產品和選型

    愛普生陀螺儀傳感器是種角速度傳感器,作為種石英電子式陀螺儀芯片,具有溫度特性好、功耗低、成本低、穩定性好等特點。目前EPSON主力單軸
    的頭像 發表于 04-01 16:41 ?934次閱讀
    <b class='flag-5'>陀螺儀</b>傳感器,IMU和<b class='flag-5'>加速度計</b>的產品和選型

    愛普生三軸加速度計傳感器HGPM01

    HGPM01是基于高性能陀螺儀陀傳感器和加速度計開發的模組,內置3軸陀螺儀和3軸加速度計傳感器。依賴于高精度的傳感器、高性能的處理器和高級的數字信號處理算法,該模組輸出非常穩定的角
    的頭像 發表于 03-05 14:36 ?476次閱讀
    愛普生三軸<b class='flag-5'>加速度計</b>傳感器HGPM01

    MEMS加速度計與MEMS陀螺儀的區別

    MEMS加速度計與MEMS陀螺儀是現代慣性導航系統中最常用的傳感器。
    的頭像 發表于 02-17 14:05 ?3433次閱讀
    MEMS<b class='flag-5'>加速度計</b>與MEMS<b class='flag-5'>陀螺儀</b>的區別
    主站蜘蛛池模板: 亚洲国产午夜看片| 欧美一二区视频| 日美一级毛片| 日本一视频一区视频二区| 特黄特色大片免费播放路01| 色视频网站免费| 4338×亚洲全国最大色成网站| 福利视频免费观看| 狠狠干天天爽| 天天免费看片| 77米奇影院| 天天做天天爱天天爽综合网| 成年女人在线观看| 在线播放91灌醉迷j高跟美女| 久久精品男人的天堂| 日本三级全黄三级a| 女色专区| 日本精品三级| 玖玖在线精品| 免费黄色福利视频| 四虎库| 人人射人人插| 日本在线观看永久免费网站| 免费日韩一级片| 国产3p在线播放| 国产主播在线观看| 久久e| 在线播放免费视频| 九色国产在线| 黑色丝袜美女被网站| 欧美色网在线| 1024你懂的日韩| 日韩欧美印度一级毛片| 亚洲黄色官网| 推倒都市极品贵妇| 女人双腿搬开让男人桶| 成人在线亚洲| 80s国产成年女人毛片| 手机看片国产免费| 久久在草| 午夜男人的天堂|