91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

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

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

RT-Thread 互補濾波器 (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,從而給出更加準確的狀態(tài)預測。剛好手邊開發(fā)板有一個 6 軸的 IMU,本來打算試一下卡爾曼濾波器 (Kalman Filter),然而 Kalman Filter 更適合 9 軸的傳感器,也就是在 6 軸的基礎上(3-axis Accel + 3-axis Gyro)融合 3 軸的磁力計。對于一個只有 6 軸 IMU 的 MCU,輕量級的互補濾波器 (Complementary Filter)更加合適,利用 3 軸陀螺儀和 3 軸加速度計來估計開發(fā)板的姿態(tài) (Pitch, Roll, Yaw)。

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

Github - STM32 IMU 互補濾波器 (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

三個軸的加速度

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

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

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

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

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

,默認是

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.

互補濾波器 (Complementary Filter)

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

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

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

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

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

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

加速度計不需要積分,我們可以直接對當前加速度角度求 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ā)板靜止狀態(tài),我們無法利用重力加速度知道 z 軸的旋轉(zhuǎn)角度 (yaw),所以上面只計算 roll 和 pitch,最終 z 軸的旋轉(zhuǎn)角度 yaw 會出現(xiàn)累計積分誤差

互補濾波器

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

于是我們就可以取長補短,線性疊加2個測量值的估計,給出更準確的估計。

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

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

總結(jié)

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

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




點擊閱讀原文查看近期賽事


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

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


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

    關注

    32

    文章

    1614

    瀏覽量

    44901

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

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    恩智浦亮相RT-Thread 20周年開發(fā)者大會

    日前,“開源向?qū)崱どa(chǎn)力進化啟示錄”全球峰會暨RT-Thread 20周年開發(fā)者大會在上海成功舉辦,恩智浦作為RT-Thread的緊密合作伙伴,在活動中重磅亮相,展示雙方在共建RT-Thread OS開發(fā)生態(tài)方面的新成果、新方案
    的頭像 發(fā)表于 01-26 09:07 ?563次閱讀

    首搭RT-Thread程翧車控平臺| RT-Thread程翧 S32K344 快速原型開發(fā)平臺正式上市!| 產(chǎn)品動態(tài)

    在智能汽車邁向高集成與高安全的時代,VCU/ECU開發(fā)正面臨效率與可靠性的雙重考驗。依賴單一硬件或拼湊軟件方案的傳統(tǒng)模式,已成為制約創(chuàng)新的瓶頸。為此,RT-Thread帶來里程碑式的解決方案
    的頭像 發(fā)表于 10-31 11:53 ?1008次閱讀
    首搭<b class='flag-5'>RT-Thread</b>程翧車控平臺| <b class='flag-5'>RT-Thread</b>程翧 S32K344 快速原型開發(fā)平臺正式上市!| 產(chǎn)品動態(tài)

    請問RT-Threadstm32cubemx聯(lián)合開發(fā)的原理是什么?

    在使用RT-Threadstm32cubemx聯(lián)合開發(fā)的原理是什么,cubemx在其中主要起到了哪些功能呢?
    發(fā)表于 10-11 15:49

    2025年RT-Thread開發(fā)者巡回培訓報名正式啟動!

    親愛的RT-Thread社區(qū)成員們:新程再啟,共赴熱愛!2025年RT-Thread開發(fā)者巡回培訓正式啟動報名!今年,我們選擇了西安、武漢、北京、杭州、深圳、上海、成都這7座城市,為大家?guī)?/div>
    的頭像 發(fā)表于 09-27 10:39 ?1984次閱讀
    2025年<b class='flag-5'>RT-Thread</b>開發(fā)者巡回培訓報名正式啟動!

    rt-thread studio 2.2.9如何使用最新的RT-Thread v5.2.0 released?

    rt-thread studio2.2.9如何使用最新的RT-Thread v5.2.0 released? 原先以為修改index_all.json,發(fā)現(xiàn)聯(lián)網(wǎng)的時候,會自動覆蓋 另lastet版本
    發(fā)表于 09-16 06:06

    STM32cubeMX生成配置rt-thread引用問題求解

    如題,本人小白,剛接觸rt-threadSTM32F1/4簡便配置起見利用cubeMX自動生成,測試幾次后直接蒙了,不知道哪些文件是rt-thread項目必須的,網(wǎng)上說法也五花八門,說代碼屏蔽某些
    發(fā)表于 09-12 07:21

    【好書推薦】RT-Thread第20本相關書籍!《嵌入式實時操作系統(tǒng)RT-Thread原理與應用》| 技術集結(jié)

    01內(nèi)容簡介ContentSummary本書為讀者提供了一個全面、系統(tǒng)的RT-Thread學習指南,旨在幫助初學者及有經(jīng)驗的開發(fā)者掌握RT-Thread實時操作系統(tǒng)和STM32嵌入式微控制
    的頭像 發(fā)表于 08-24 10:05 ?1044次閱讀
    【好書推薦】<b class='flag-5'>RT-Thread</b>第20本相關書籍!《嵌入式實時操作系統(tǒng)<b class='flag-5'>RT-Thread</b>原理與應用》| 技術集結(jié)

    RT-Thread編譯太慢怎么解決?

    剛下載RT-Thread Studio之后創(chuàng)建了一個stm32L496VET6的工程,示例程序沒有任何改動之間編譯的,到了19%就幾乎不動了,然后10分鐘才增加1%,這是啥情況啊,請問大佬們這怎么解決?
    發(fā)表于 08-22 08:26

    RT-Thread 遇上 Rust:安全內(nèi)核 RusT-Thread 的誕生

    老師的推薦,很快我們就被其極高的安全特性,強大的包管理系統(tǒng)和編譯以及豐富的社區(qū)支持所折服。然后我們在調(diào)研時注意到了RT-Thread。它有著經(jīng)典的操作系統(tǒng)架構,
    的頭像 發(fā)表于 08-02 11:03 ?3543次閱讀
    <b class='flag-5'>RT-Thread</b> 遇上 Rust:安全內(nèi)核 RusT-<b class='flag-5'>Thread</b> 的誕生

    RT-Thread榮獲2025優(yōu)秀開源項目 | 新聞速遞

    6月底,RT-Thread睿賽德受邀參與由上海開源信息技術協(xié)會主辦的2025上海開源創(chuàng)新精英薈。上海市商委副主任張杰出席會議并致辭。RT-Thread嵌入式操作系統(tǒng)項目憑借其卓越的技術創(chuàng)新與開源生態(tài)
    的頭像 發(fā)表于 07-04 09:04 ?2657次閱讀
    <b class='flag-5'>RT-Thread</b>榮獲2025優(yōu)秀開源項目 | 新聞速遞

    深度剖析 RT-Thread 線程調(diào)度流程

    RT-Thread調(diào)度第一個線程的主要流程分如下:rtthread_startup:RTT的啟動函數(shù),主要負責板級驅(qū)動,調(diào)度,系統(tǒng)線程初始化,啟動調(diào)度的工作
    的頭像 發(fā)表于 06-25 18:24 ?1776次閱讀
    深度剖析 <b class='flag-5'>RT-Thread</b> 線程調(diào)度流程

    揭秘RT-Thread上的AUTOSAR CP系統(tǒng)

    本文探討了RT-Thread與AUTOSARCP的融合,解決車載ECU開發(fā)中實時性、安全性與靈活性的平衡問題。通過分層安全內(nèi)核(rt-safetyos/autoos)和工具鏈整合,兼容AUTOSAR
    的頭像 發(fā)表于 06-23 20:22 ?3227次閱讀
    揭秘<b class='flag-5'>RT-Thread</b>上的AUTOSAR CP系統(tǒng)

    如何在rt-thread studio上開發(fā)STM32H747IIT6

    如題,我希望在rt-thread studio上開發(fā)STM32H747IIT6這款雙核單片機,在keil里兩個核的代碼是完全隔離的,分別在兩個工程中編寫。 但是在rt-thread studio上生成的標準版工程只有一個工程,
    發(fā)表于 06-11 06:24

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

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

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

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