女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

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

完善資料讓更多小伙伴認(rèn)識你,還能領(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ù)測。剛好手邊開發(fā)板有一個 6 軸的 IMU,本來打算試一下卡爾曼濾波器 (Kalman Filter),然而 Kalman Filter 更適合 9 軸的傳感器,也就是在 6 軸的基礎(chǔ)上(3-axis Accel + 3-axis Gyro)融合 3 軸的磁力計(jì)。對于一個只有 6 軸 IMU 的 MCU,輕量級的互補(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) 融合兩個角度估計(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)角速度。一個六軸的 IMU 可以測量 x, y, z 三個方向的重力加速度,和繞三個軸的旋轉(zhuǎn)角速度。比如,開發(fā)板如果靜止放置在桌面上,會測量到 z 方向的重力加速度。

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

三個軸的加速度

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

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

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

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

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 芯片手冊的 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)速度 的測量值,得到更準(zhǔn)確的姿態(tài)預(yù)測。

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

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

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

陀螺儀測量的是瞬間的旋轉(zhuǎn)角速度,所以位置的估計(jì)其實(shí)就是時間的積分。例如,每過 100ms 測量一次旋轉(zhuǎn)速度,旋轉(zhuǎn)速度 x 時間 = 旋轉(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)境存在大量噪聲,陀螺儀測量數(shù)據(jù)會存在隨機(jī)的波動,這些噪聲經(jīng)過積分累積,最后會造成位置的漂移。比如下面這張圖,過了很長時間后,雖然開發(fā)板是靜止的,但是右邊的陀螺儀估計(jì)的位置,就無法回到原點(diǎn),這就是長時間的累計(jì)誤差造成的。a1e1d1ca-1fe4-11ee-962d-dac502259ad0.jpg

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

加速度計(jì)不需要積分,我們可以直接對當(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 會出現(xiàn)累計(jì)積分誤差

互補(bǔ)濾波器

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

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

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

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

總結(jié)

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

// 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)

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


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

    關(guān)注

    32

    文章

    1370

    瀏覽量

    41509

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

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

收藏 人收藏

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    2025 RT-Thread全球技術(shù)大會議程正式發(fā)布!

    RT-ThreadGlobalTechConference(RT-ThreadGTC,RT-Thread全球技術(shù)大會)是聚焦基礎(chǔ)軟件技術(shù)創(chuàng)新與實(shí)踐的嵌入式技術(shù)盛會,持續(xù)推動技術(shù)價值轉(zhuǎn)化
    的頭像 發(fā)表于 05-27 19:28 ?296次閱讀
    2025 <b class='flag-5'>RT-Thread</b>全球技術(shù)大會議程正式發(fā)布!

    RT-Thread 上如何實(shí)現(xiàn) SLAAC?

    大佬們,本菜鳥有一些網(wǎng)絡(luò)上的問題需要幫助: RT-Thread 上如何實(shí)現(xiàn) SLAAC(無狀態(tài)地址自動分配),給連接到我的板子的設(shè)備分配 IPv6 地址; RT-Thread 如何發(fā)送以太網(wǎng)報文,要求從報文頭開始都是我自己組,
    發(fā)表于 05-27 07:21

    RT-Thread審核團(tuán)招募: 深度參與開源RTOS社區(qū)治理與演進(jìn)

    全球開發(fā)者招募:RT-Thread審核團(tuán)(ReviewTeam)正式開放申請!在開源的世界里,代碼審查(CodeReview)是保證軟件質(zhì)量、促進(jìn)技術(shù)交流的關(guān)鍵環(huán)節(jié)。RT-Thread作為全球領(lǐng)先
    的頭像 發(fā)表于 05-21 18:02 ?454次閱讀
    <b class='flag-5'>RT-Thread</b>審核團(tuán)招募: 深度參與開源RTOS社區(qū)治理與演進(jìn)

    如何將RT-Thread移植到NXP MCUXPressoIDE上

    RT-Thread默認(rèn)支持的IDE只有IAR 和 Keil, 那如何將RT-Thread移植到NXP MCUXPressoIDE上呢?本文內(nèi)容比較簡單但稍有瑣碎,希望對有需要的小伙伴有所幫助。
    的頭像 發(fā)表于 02-13 10:37 ?1725次閱讀
    如何將<b class='flag-5'>RT-Thread</b>移植到NXP MCUXPressoIDE上

    從開源中來到開源中去-RT-Thread北京社區(qū)篇

    RT-Thread今年全域推行不同區(qū)域社區(qū)網(wǎng),通過建立區(qū)域社區(qū)網(wǎng),構(gòu)建更加緊密聯(lián)系的開源社區(qū),實(shí)現(xiàn)更廣泛的開源資源共享,讓更多的RT-Thread開發(fā)者受益。今年8月份RT-Thread正式啟動北京
    的頭像 發(fā)表于 11-29 01:05 ?396次閱讀
    從開源中來到開源中去-<b class='flag-5'>RT-Thread</b>北京社區(qū)篇

    RT-Thread上CAN實(shí)踐

    開箱測試RT-Thread官方已完成了對英飛凌XMC7200EVK的移植,通過shell可以看到做好了uart3的console。本文將介紹如何進(jìn)行RT-ThreadCan移植。接下來我們要完成CAN_FD的驅(qū)動移植,并正常啟動RT-T
    的頭像 發(fā)表于 11-13 01:03 ?1899次閱讀
    <b class='flag-5'>RT-Thread</b>上CAN實(shí)踐

    開源共生 商業(yè)共贏 | RT-Thread 2024開發(fā)者大會報名啟動!

    親愛的RT-Thread開發(fā)者我們很高興地宣布,一年一度的RDC(RT-ThreadDeveloperConference,RT-Thread開發(fā)者大會)正式啟動報名!2024RT-Threa
    的頭像 發(fā)表于 10-29 08:06 ?856次閱讀
    開源共生 商業(yè)共贏 | <b class='flag-5'>RT-Thread</b> 2024開發(fā)者大會報名啟動!

    【成都】9月21日RT-Thread巡回線下培訓(xùn)-OpenMV機(jī)器視覺

    親愛的RT-Thread社區(qū)成員們:RT-Thread24年全球巡回培訓(xùn)將覆蓋超10座城市及國家,為開發(fā)者提供一個深入學(xué)習(xí)RT-Thread嵌入式開發(fā),以及和工程師們線下交流的絕佳機(jī)會。2024年
    的頭像 發(fā)表于 09-13 08:09 ?1424次閱讀
    【成都】9月21日<b class='flag-5'>RT-Thread</b>巡回線下培訓(xùn)-OpenMV機(jī)器視覺

    【大連】9月7日RT-Thread巡回線下培訓(xùn)-OpenMV機(jī)器視覺

    親愛的RT-Thread社區(qū)成員們:2024年RT-Thread全球開發(fā)者線下培訓(xùn)拉開帷幕啦!24年全球巡回培訓(xùn)將覆蓋超10座城市及國家,為開發(fā)者提供一個深入學(xué)習(xí)RT-Thread嵌入式開發(fā)的絕佳
    的頭像 發(fā)表于 09-01 08:02 ?3009次閱讀
    【大連】9月7日<b class='flag-5'>RT-Thread</b>巡回線下培訓(xùn)-OpenMV機(jī)器視覺

    2024 RT-Thread全球巡回 線下培訓(xùn)火熱來襲!

    親愛的RT-Thread社區(qū)成員們:我們非常高興地宣布,2024年RT-Thread全球開發(fā)者線下培訓(xùn)即將拉開帷幕!24年全球巡回培訓(xùn)將覆蓋超10座城市及國家,為開發(fā)者提供一個深入學(xué)習(xí)RT-Thread嵌入式開發(fā)的絕佳機(jī)會。
    的頭像 發(fā)表于 08-07 08:35 ?2414次閱讀
    2024 <b class='flag-5'>RT-Thread</b>全球巡回 線下培訓(xùn)火熱來襲!

    【好書推薦】RT-Thread設(shè)備驅(qū)動開發(fā)指南

    近年來國內(nèi)芯片產(chǎn)業(yè)和物聯(lián)網(wǎng)產(chǎn)業(yè)的快速崛起,行業(yè)發(fā)展迫切需要更多人才,尤其需要掌握嵌入式操作系統(tǒng)等底層技術(shù)的人才。隨著RT-Thread被更廣泛地應(yīng)用于行業(yè)中,開發(fā)者對嵌入式驅(qū)動開發(fā)的需求越來越
    的頭像 發(fā)表于 08-01 08:35 ?1160次閱讀
    【好書推薦】<b class='flag-5'>RT-Thread</b>設(shè)備驅(qū)動開發(fā)指南

    RT-Thread 新里程碑達(dá)成——GitHub Star 破萬!

    RT-Thread實(shí)時操作系統(tǒng)開源項(xiàng)目在GitHub上的star數(shù)量突破一萬!截止發(fā)文,RT-Thread作為實(shí)時操作系統(tǒng)在業(yè)界Star數(shù)量排名第一!倉庫地址:https://github.com
    的頭像 發(fā)表于 07-04 08:35 ?699次閱讀
    <b class='flag-5'>RT-Thread</b> 新里程碑達(dá)成——GitHub Star 破萬!

    基于 RT-Thread專業(yè)版的EtherCAT主站方案

    (一)方案介紹本方案基于RT-Thread專業(yè)版,在RT-Thread端集成EtherCAT主站協(xié)議,通過EtherCAT對伺服電機(jī)或遠(yuǎn)程IO進(jìn)行實(shí)時控制,具備傳輸速度快,實(shí)時性高,擴(kuò)展設(shè)備靈活等
    的頭像 發(fā)表于 06-19 08:35 ?1688次閱讀
    基于 <b class='flag-5'>RT-Thread</b>專業(yè)版的EtherCAT主站方案

    杭州站RT-Thread混合部署Workshop圓滿落幕!

    2024年66日,杭州順利舉辦了RT-Thread混合部署線下Workshop,活動圓滿的結(jié)束。這次Workshop由睿賽德科技團(tuán)隊(duì)精心策劃并成功執(zhí)行,吸引了大量嵌入式系統(tǒng)開發(fā)者和技術(shù)愛好者的熱情
    的頭像 發(fā)表于 06-08 08:35 ?637次閱讀
    杭州站<b class='flag-5'>RT-Thread</b>混合部署Workshop圓滿落幕!

    開發(fā)者分享 | 基于先楫RT-Thread BSP,使用CLion開發(fā)應(yīng)用

    本期開發(fā)者:朱彥祖RT-Thread資深工程師,HPM6700/6400元老級開發(fā)者及骨灰級用戶,先輯生態(tài)社區(qū)常駐優(yōu)秀開發(fā)者,江湖人稱杭州吳彥祖。背景最近在使用先輯HPM6750開發(fā)一款運(yùn)動控制
    的頭像 發(fā)表于 06-07 08:17 ?3605次閱讀
    開發(fā)者分享 | 基于先楫<b class='flag-5'>RT-Thread</b> BSP,使用CLion開發(fā)應(yīng)用