0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

RT-Thread 互補(bǔ)濾波器 (STM32 + 6 軸 IMU)

RTThread物聯(lián)網(wǎng)操作系統(tǒng) ? 來源:未知 ? 2023-07-11 20:20 ? 次閱讀
作者:wuhanstudio 原文鏈接:https://zhuanlan.zhihu.com/p/611568999最近在看無人駕駛的 Prediction 部分,可以利用EKF (Extended Kalman Filter)融合不同傳感器的數(shù)據(jù),例如 IMU, Lidar 和 GNSS,從而給出更加準(zhǔn)確的狀態(tài)預(yù)測(cè)。剛好手邊開發(fā)板有一個(gè) 6 軸的 IMU,本來打算試一下卡爾曼濾波器 (Kalman Filter),然而 Kalman Filter 更適合 9 軸的傳感器,也就是在 6 軸的基礎(chǔ)上(3-axis Accel + 3-axis Gyro)融合 3 軸的磁力計(jì)。對(duì)于一個(gè)只有 6 軸 IMU 的 MCU,輕量級(jí)的互補(bǔ)濾波器 (Complementary Filter)更加合適,利用 3 軸陀螺儀和 3 軸加速度計(jì)來估計(jì)開發(fā)板的姿態(tài) (Pitch, Roll, Yaw)。

大致流程:首先用 RT-Thread 的 icm20608 軟件包讀取 陀螺儀 (Gyroscope) 和 加速度計(jì) (Accelerometer) 的數(shù)據(jù),分別計(jì)算出估計(jì)的角度,再用互補(bǔ)濾波器 (Complementary Filter) 融合兩個(gè)角度估計(jì)、進(jìn)行校正,其實(shí)核心算法的代碼就 7 行。最后串口把數(shù)據(jù)發(fā)到電腦上,用 Python + OpenGL 可視化。

Github - STM32 IMU 互補(bǔ)濾波器 (RT-Thread):https://github.com/wuhanstudio/stm32-imu-filter

IMU 傳感器 (Inertial Measurement Unit)

我們先介紹下從 I2C 總線讀取出傳感器原始數(shù)值后,如何處理得到加速度和旋轉(zhuǎn)角速度。一個(gè)六軸的 IMU 可以測(cè)量 x, y, z 三個(gè)方向的重力加速度,和繞三個(gè)軸的旋轉(zhuǎn)角速度。比如,開發(fā)板如果靜止放置在桌面上,會(huì)測(cè)量到 z 方向的重力加速度。

a0b23718-1fe4-11ee-962d-dac502259ad0.png

三個(gè)軸的加速度

當(dāng)然,如果開發(fā)板靜止不動(dòng),繞三個(gè)軸的旋轉(zhuǎn)速度都是 0。

a0caa618-1fe4-11ee-962d-dac502259ad0.png

三個(gè)軸的旋轉(zhuǎn)角速度

由于傳感器的輸出實(shí)際上是來自 ADC 的 16 位數(shù)字信號(hào),我們需要把它的單位轉(zhuǎn)換成重力加速度 g。例如,我們可以選擇測(cè)量范圍

a0f4ea4a-1fe4-11ee-962d-dac502259ad0.png

,默認(rèn)是

a10d4112-1fe4-11ee-962d-dac502259ad0.png

,也就是把傳感器的 16 位輸出

a12c7dca-1fe4-11ee-962d-dac502259ad0.png

映射到 [-2g, 2g),于是

a1435c34-1fe4-11ee-962d-dac502259ad0.png

也就是下面 icm20608 芯片手冊(cè)的 Sensitivity Scale Factor。

a1591268-1fe4-11ee-962d-dac502259ad0.jpg

于是在代碼里面,將原始的 int16 加速度數(shù)據(jù)除以 16384。

double aSensitivity = 16384;

accel_x = accel_x / aSensitivity;
accel_y = accel_y / aSensitivity;
accel_z = accel_z / aSensitivity;

同樣,我們可以換算出角速度

a17897fa-1fe4-11ee-962d-dac502259ad0.png

a18eef6e-1fe4-11ee-962d-dac502259ad0.png

于是在代碼里面,將原始的 int16 角速度數(shù)據(jù)除以 131。

double gSensitivity = 131;

gyrX = gyro_x / gSensitivity;
gyrY = gyro_y / gSensitivity;
gyrZ = gyro_z / gSensitivity;

這樣我們就把 ADC 輸出的 int16 原始數(shù)據(jù)分布轉(zhuǎn)換成了加速度單位 g,和旋轉(zhuǎn)角速度單位 °/s.

互補(bǔ)濾波器 (Complementary Filter)

我們可以用 互補(bǔ)濾波器 結(jié)合 加速度 和 旋轉(zhuǎn)速度 的測(cè)量值,得到更準(zhǔn)確的姿態(tài)預(yù)測(cè)。

我們使用下面的圖中的坐標(biāo)系,繞 x 軸旋轉(zhuǎn)的角度為 roll,繞 y 軸的旋轉(zhuǎn)方向?yàn)?pitch,繞 z 軸旋轉(zhuǎn)方向?yàn)?yaw。逆時(shí)針旋轉(zhuǎn)為正,順時(shí)針旋轉(zhuǎn)為負(fù)。

a1c9396c-1fe4-11ee-962d-dac502259ad0.png

陀螺儀估計(jì)姿態(tài)

陀螺儀測(cè)量的是瞬間的旋轉(zhuǎn)角速度,所以位置的估計(jì)其實(shí)就是時(shí)間的積分。例如,每過 100ms 測(cè)量一次旋轉(zhuǎn)速度,旋轉(zhuǎn)速度 x 時(shí)間 = 旋轉(zhuǎn)角度。
// angles based on gyro (deg/s)
gx = gx + gyrX * TIME_STEP_MS / 1000;
gy = gy + gyrY * TIME_STEP_MS / 1000;
gz = gz + gyrZ * TIME_STEP_MS / 1000;
當(dāng)然,由于環(huán)境存在大量噪聲,陀螺儀測(cè)量數(shù)據(jù)會(huì)存在隨機(jī)的波動(dòng),這些噪聲經(jīng)過積分累積,最后會(huì)造成位置的漂移。比如下面這張圖,過了很長時(shí)間后,雖然開發(fā)板是靜止的,但是右邊的陀螺儀估計(jì)的位置,就無法回到原點(diǎn),這就是長時(shí)間的累計(jì)誤差造成的。a1e1d1ca-1fe4-11ee-962d-dac502259ad0.jpg

加速度計(jì)估計(jì)姿態(tài)

加速度計(jì)不需要積分,我們可以直接對(duì)當(dāng)前加速度角度求 arctan 得到角度:

a203908a-1fe4-11ee-962d-dac502259ad0.jpg
// angles based on accelerometer
ax = atan2(accelY, accelZ) * 180 / M_PI;                                     // roll
ay = atan2(-accelX, sqrt( pow(accelY, 2) + pow(accelZ, 2))) * 180 / M_PI;    // pitch

不管我們的開發(fā)板繞 z 軸旋轉(zhuǎn)多少度,重力加速度始終朝向地面。因此開發(fā)板靜止?fàn)顟B(tài),我們無法利用重力加速度知道 z 軸的旋轉(zhuǎn)角度 (yaw),所以上面只計(jì)算 roll 和 pitch,最終 z 軸的旋轉(zhuǎn)角度 yaw 會(huì)出現(xiàn)累計(jì)積分誤差

互補(bǔ)濾波器

我們需要結(jié)合2個(gè)測(cè)量值是因?yàn)椋盒D(zhuǎn)速度短時(shí)間內(nèi)比較準(zhǔn)確,但是由于環(huán)境的噪聲會(huì)產(chǎn)生一些隨機(jī)運(yùn)動(dòng),時(shí)間長了就會(huì)漂移,而加速度短時(shí)間內(nèi)不一定準(zhǔn)確,但是最終會(huì)維持穩(wěn)定。

于是我們就可以取長補(bǔ)短,線性疊加2個(gè)測(cè)量值的估計(jì),給出更準(zhǔn)確的估計(jì)。

// complementary filter
gx = gx * 0.96 + ax * 0.04;
gy = gy * 0.96 + ay * 0.04;

短時(shí)間內(nèi),我們相信陀螺儀測(cè)量的旋轉(zhuǎn)角速度 (權(quán)值: 0.96);長時(shí)間內(nèi),環(huán)境噪聲逐漸造成的漂移,由加速度計(jì)慢慢進(jìn)行矯正 (權(quán)值: 0.04)。

總結(jié)

最后總結(jié)一下,其實(shí)核心代碼一共就 7 行。我們先利用加速度求解姿態(tài),再利用旋轉(zhuǎn)角速度求解姿態(tài),最后用互補(bǔ)濾波器進(jìn)行一個(gè)線性疊加。

// angles based on gyro (deg/s)
gx = gx + gyrX * TIME_STEP_MS / 1000;
gy = gy + gyrY * TIME_STEP_MS / 1000;
gz = gz + gyrZ * TIME_STEP_MS / 1000;

// angles based on accelerometer
ax = atan2(accelY, accelZ) * 180 / M_PI;                                     // roll
ay = atan2(-accelX, sqrt( pow(accelY, 2) + pow(accelZ, 2))) * 180 / M_PI;    // pitch

// complementary filter
gx = gx * 0.96 + ax * 0.04;
gy = gy * 0.96 + ay * 0.04;

References

  • https://github.com/mattzzw/Arduino-mpu6050

  • https://github.com/RT-Thread-pa




點(diǎn)擊閱讀原文查看近期賽事


原文標(biāo)題:RT-Thread 互補(bǔ)濾波器 (STM32 + 6 軸 IMU)

文章出處:【微信公眾號(hào):RTThread物聯(lián)網(wǎng)操作系統(tǒng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • RT-Thread
    +關(guān)注

    關(guān)注

    31

    文章

    1239

    瀏覽量

    39437

原文標(biāo)題:RT-Thread 互補(bǔ)濾波器 (STM32 + 6 軸 IMU)

文章出處:【微信號(hào):RTThread,微信公眾號(hào):RTThread物聯(lián)網(wǎng)操作系統(tǒng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    66日杭州站RT-Thread線下workshop,探索RT-Thread混合部署新模式!

    66日下午我們將在杭州舉辦RT-Thread混合部署線下workshop,在瑞芯微RK3568平臺(tái)上實(shí)現(xiàn)同時(shí)運(yùn)行RT-Thread和linux,本次workshop邀請(qǐng)到
    的頭像 發(fā)表于 05-28 08:35 ?313次閱讀
    <b class='flag-5'>6</b>月<b class='flag-5'>6</b>日杭州站<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    4月25日北京站RT-Thread線下workshop,探索RT-Thread混合部署新模式

    4月25日,下午我們將在北京舉辦RT-Thread混合部署線下workshop,在瑞芯微RK3568平臺(tái)上實(shí)現(xiàn)同時(shí)運(yùn)行RT-Thread和linux,本次workshop邀請(qǐng)到RT-Thread資深
    的頭像 發(fā)表于 04-16 08:35 ?321次閱讀
    4月25日北京站<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式

    4月10日深圳場(chǎng)RT-Thread線下workshop,探索RT-Thread混合部署新模式!

    4月10日我們將在深圳福田舉辦RT-Thread混合部署線下workshop,在瑞芯微RK3568平臺(tái)上實(shí)現(xiàn)同時(shí)運(yùn)行RT-Thread和linux,本次workshop邀請(qǐng)到RT-Thread資深嵌入式軟件工程師農(nóng)曉明老師為您講
    的頭像 發(fā)表于 03-27 11:36 ?661次閱讀
    4月10日深圳場(chǎng)<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    4月10日深圳場(chǎng)RT-Thread線下workshop,探索RT-Thread混合部署新模式!

    4月10日我們將在深圳福田舉辦RT-Thread混合部署線下workshop,在瑞芯微RK3568平臺(tái)上實(shí)現(xiàn)同時(shí)運(yùn)行RT-Thread和linux,本次workshop邀請(qǐng)到RT-Thread資深
    的頭像 發(fā)表于 03-27 08:34 ?390次閱讀
    4月10日深圳場(chǎng)<b class='flag-5'>RT-Thread</b>線下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    RT-thread源碼移植到STM32F10x和STM32F4xx

    RT-thread源碼移植到STM32F10x和STM32F4xx: 一、源碼下載 點(diǎn)擊入門->下載 ? 在歷史版本里邊隨便選取一個(gè) ? 會(huì)進(jìn)入百度云盤的下載地址,里邊有全部版本的源碼。這里下載
    的頭像 發(fā)表于 11-15 09:38 ?2059次閱讀
    <b class='flag-5'>RT-thread</b>源碼移植到<b class='flag-5'>STM32</b>F10x和<b class='flag-5'>STM32</b>F4xx

    基于rt-thread的socket通信設(shè)計(jì)

    最近再研究 rt-thread 的通信 ,想設(shè)計(jì)出 eps8266(多個(gè)) rt-thread(作為中控) 服務(wù)的通信框架,使用的開發(fā)板是 潘多拉
    的頭像 發(fā)表于 10-13 15:02 ?1067次閱讀
    基于<b class='flag-5'>rt-thread</b>的socket通信設(shè)計(jì)

    rt-thread studio新建stm32f407工程

    rt-thread studio新建stm32f407工程,使用的版本是:2.2.6,stm32f4的支持包版本為0.2.2。先不用0.2.3,因?yàn)槭褂?.2.3建立的模板編譯會(huì)報(bào)錯(cuò)。
    的頭像 發(fā)表于 10-12 17:42 ?1047次閱讀

    RT-Thread使用Soft RTC(軟件模擬RTC)

    開發(fā)環(huán)境:野火的stm32f407,rt-thread studio版本是版本: 2.2.6,rt-thread 使用版本為4.0.3,stm32f4的資源包為0.2.2。
    的頭像 發(fā)表于 10-12 17:39 ?581次閱讀
    <b class='flag-5'>RT-Thread</b>使用Soft RTC(軟件模擬RTC)

    RT-Thread在Lan8720a和 lwip基礎(chǔ)上移植ntp流程

    開發(fā)環(huán)境:野火的stm32f407,rt-thread studio版本是版本: 2.2.6,stm32f4的資源包為0.2.2。以RT-Thread中Lan8720和lwip協(xié)議棧的
    的頭像 發(fā)表于 10-12 16:59 ?1480次閱讀
    <b class='flag-5'>RT-Thread</b>在Lan8720a和 lwip基礎(chǔ)上移植ntp流程

    RT-Thread移植使用webserver (lwip+httpd)

    開發(fā)環(huán)境:野火的stm32f407,rt-thread studio版本是版本: 2.2.6,stm32f4的資源包為0.2.2,rt-thread版本為4.0.3。
    的頭像 發(fā)表于 10-12 12:49 ?1073次閱讀
    <b class='flag-5'>RT-Thread</b>移植使用webserver (lwip+httpd)

    試用RT-Thread Studio(VSCode)

    想嘗試RT-Thread studio (VSCode),先下載安裝VSCode,再搜索RT-Thread
    的頭像 發(fā)表于 10-12 10:58 ?880次閱讀
    試用<b class='flag-5'>RT-Thread</b> Studio(VSCode)

    RT-Thread使用cjson軟件包發(fā)送64位長整型數(shù)據(jù)

    開發(fā)環(huán)境:野火的stm32f407,rt-thread studio版本是版本: 2.2.6,stm32f4的資源包為0.2.2,rt-thread版本為4.1.1,cjson軟件包使
    的頭像 發(fā)表于 10-11 15:09 ?717次閱讀
    <b class='flag-5'>RT-Thread</b>使用cjson軟件包發(fā)送64位長整型數(shù)據(jù)

    RT-Thread v5.0.2 發(fā)布

    RT-Thread 代碼倉庫地址: ●? https://github.com/RT-Thread/rt-thread RT-Thread 5.0.2 版本發(fā)布日志詳情: ●? htt
    的頭像 發(fā)表于 10-10 18:45 ?1202次閱讀
    <b class='flag-5'>RT-Thread</b> v5.0.2 發(fā)布

    利用RT-Thread與MQTT實(shí)現(xiàn)智慧班車管理系統(tǒng)的設(shè)計(jì)

    項(xiàng)目采用的IoT架構(gòu),底層是STM32L475VET6潘多拉開發(fā)板+RT-Thread,對(duì)于RT-Thread的資源使用情況在論文中也有提到,這里直接截個(gè)圖
    的頭像 發(fā)表于 10-09 10:55 ?1284次閱讀
    利用<b class='flag-5'>RT-Thread</b>與MQTT實(shí)現(xiàn)智慧班車管理系統(tǒng)的設(shè)計(jì)

    新書上架|嵌入式系統(tǒng)原理及應(yīng)用——基于STM32RT-Thread

    教程書籍編撰過程中的第一選擇! 本次上新的書籍為胡永濤主編的《嵌入式系統(tǒng)原理及應(yīng)用——基于STM32RT-Thread》。 本書以意法半導(dǎo)體(ST)的STM32L431系列微控制
    的頭像 發(fā)表于 09-25 18:25 ?815次閱讀
    新書上架|嵌入式系統(tǒng)原理及應(yīng)用——基于<b class='flag-5'>STM32</b>和<b class='flag-5'>RT-Thread</b>