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

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

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

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

CW32L012對MPU6050的數(shù)據(jù)進(jìn)行卡爾曼濾波

CW32生態(tài)社區(qū) ? 來源:CW32生態(tài)社區(qū) ? 2026-01-05 16:46 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

卡爾曼濾波(最優(yōu)估計)

一、什么是卡爾曼濾波

通俗理解卡爾曼濾波:一個「會自動調(diào)權(quán)重的裁判」

卡爾曼濾波解決的核心問題是:你有兩個途徑(測量和預(yù)估得到)知道同一個東西的狀態(tài),但這兩個途徑都不準(zhǔn),卡爾曼幫你算出最準(zhǔn)的結(jié)果

最優(yōu)估計公式:

wKgZO2lVGVaAZunKAAAFXuE3yBo715.jpg

wKgZPGlVGVeAHmvVAAAH-Pt_cAw085.jpg

wKgZO2lbeZeALD6iAABAm1T1aNY834.jpg

二、為什么這里要用卡爾曼

下面是MPU6050加速度計和陀螺儀的優(yōu)缺點:

wKgZPGlbeZeAShkAAAB-areXonM418.jpg

圖片

總的來說:

陀螺儀動態(tài)的時候輸出的值精準(zhǔn),但是靜止的時候會有漂移

而加速度計就反過來了,加速度計靜態(tài)的時候輸出的值準(zhǔn),但是動態(tài)特性差

MPU6050 的陀螺儀和加速度計是 “天生的互補(bǔ)搭檔”,但單靠其中一個或簡單濾波,要么漂移、要么動態(tài)失真;而卡爾曼濾波的核心是 “動態(tài)加權(quán)的最優(yōu)估計” —— 它能根據(jù) MPU6050 的工作狀態(tài)(靜態(tài) / 動態(tài)),自動判斷兩個傳感器的可靠性,把陀螺儀的 “動態(tài)精準(zhǔn)” 和加速度計的 “靜態(tài)穩(wěn)定” 結(jié)合起來,最終輸出既無漂移、又能快速響應(yīng)的 roll/pitch 角度,這是其他濾波方式無法實現(xiàn)的。

三、卡爾曼濾波實現(xiàn)

一、思路

根據(jù)之前的內(nèi)容,我們已經(jīng)得到了加速度計解算的roll和pitch,以及角速度計解算的roll、pitch、yaw,因為加速度計無法解算yaw,所以這里只對roll和pitch做數(shù)據(jù)融合

卡爾曼最優(yōu)估計的核心目標(biāo)是融合 “加速度計解算的角度” 和 “陀螺儀角速度積分的角度”,最終輸出最優(yōu)的角度估計。整體邏輯分為兩大階段:

預(yù)測階段:基于陀螺儀角速度(扣除偏置后)積分,預(yù)測當(dāng)前角度;同時更新狀態(tài)誤差協(xié)方差矩陣 P(反映估計的不確定性)。

更新階段:用加速度計的角度作為觀測值修正預(yù)測值,得到最優(yōu)角度;同時修正陀螺儀偏置(補(bǔ)償零漂),并更新協(xié)方差矩陣 P。

二、具體實現(xiàn)

2.1預(yù)測階段(先驗估計)

狀態(tài)預(yù)測:用陀螺儀積分預(yù)測角度

wKgZPGlVGViASHTNAAAguBgIavs169.jpg

對應(yīng)代碼:

// 預(yù)測階段:更新角度預(yù)測
    float rate = newRate - *kalmanBias;  // 真實角速度 = 測量角速度 - 偏置
    *kalmanAngle += dt * rate;           //角度預(yù)測:θ_k = θ_{k-1}+ dt*(ω - b)

協(xié)方差預(yù)測:更新估計的不確定性

wKgZO2lVGVmAO5TjAAAFqNBiQRw080.jpg

先計算:

wKgZPGlVGVmAJqgvAAAQ9julZF4275.jpg

再加上Q得到:

圖片

對應(yīng)代碼:

 kalmanP[0][0] += dt * (dt * kalmanP[1][1] - kalmanP[0][1] - kalmanP[1][0] + Q_ANGLE);
    kalmanP[0][1] -= dt * kalmanP[1][1];
    kalmanP[1][0] -= dt * kalmanP[1][1];
    kalmanP[1][1] += Q_BIAS * dt;

2.2更新階段(后驗修正)

殘差(創(chuàng)新項):觀測值與預(yù)測值的偏差

wKgZO2lVGVqAS7btAAAMMLGvzbM509.jpg

卡爾曼增益:權(quán)衡 “預(yù)測” 和 “觀測” 的可信度

圖片

對應(yīng)代碼:

  // 計算卡爾曼增益K
    float S = kalmanP[0][0] + R_MEASURE;  // 角度方差+測量噪聲方差(R)
    float K[2];
    K[0] = kalmanP[0][0] / S;
    K[1] = kalmanP[1][0] / S;

狀態(tài)更新:修正預(yù)測值,得到最優(yōu)估計

wKgZPGlVGVuAcVJMAAAFDODsOJE204.jpg

對應(yīng)代碼:

  // 更新階段:利用加速度計測量值修正預(yù)測角度
    float y = newAngle - *kalmanAngle;  // 改用傳入的角度
    *kalmanAngle += K[0] * y;           // 修正角度
    *kalmanBias += K[1] * y;            // 修正偏置

協(xié)方差更新:修正估計的不確定性

wKgZO2lVGVuAew_dAAAJ6k7uIWY440.jpg

對應(yīng)代碼:

  // 更新協(xié)方差矩陣P
    float P00_temp = kalmanP[0][0];
    float P01_temp = kalmanP[0][1];
    kalmanP[0][0] -= K[0] * P00_temp;
    kalmanP[0][1] -= K[0] * P01_temp;
    kalmanP[1][0] -= K[1] * P00_temp;
    kalmanP[1][1] -= K[1] * P01_temp;

匿名上位機(jī)通信

一、為何用匿名上位機(jī)調(diào)試

匿名上位機(jī)是一款由國內(nèi)開發(fā)者打造、面向嵌入式開發(fā)場景的開源 / 低成本 PC 端調(diào)試工具,相比普通串口助手只能顯示一串冰冷的歐拉角數(shù)字,匿名上位機(jī)可將 Roll/Pitch/Yaw 以實時曲線、數(shù)值儀表盤、3D 模型姿態(tài)仿真等形式呈現(xiàn) —— 當(dāng)我們晃動搭載 MPU6050 的 CW32L012 開發(fā)板時,上位機(jī)的 3D 模型會同步傾斜、轉(zhuǎn)向,曲線會實時跟蹤歐拉角數(shù)值變化,你能快速判斷卡爾曼融合后的姿態(tài)解算是否準(zhǔn)確(如零漂是否被抑制、動態(tài)晃動時歐拉角是否無明顯跳變),無需逐行核對數(shù)字。

二、通信幀格式

wKgZPGlVGVyAWnwMAABk7NhSIRc628.jpg

初始化L012串口,并根據(jù)通信格式編寫匿名上位機(jī)的通信驅(qū)動:

程序?qū)嶋H現(xiàn)象

【CW32L012解算MPU6050的姿態(tài)數(shù)據(jù)并進(jìn)行卡爾曼濾波的方法-嗶哩嗶哩】

https://b23.tv/2GZqcIg

一、開發(fā)板現(xiàn)象:

圖片

OLED屏幕實時顯示解算的三軸角度

二、匿名上位機(jī)現(xiàn)象

【CW32L012使用MPU6050介紹-嗶哩嗶哩】 https://b23.tv/fi7hCnw

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

    關(guān)注

    6

    文章

    812

    瀏覽量

    48172
  • 卡爾曼濾波
    +關(guān)注

    關(guān)注

    3

    文章

    167

    瀏覽量

    25436
  • MPU6050
    +關(guān)注

    關(guān)注

    39

    文章

    313

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

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

    MPU6050模塊自己寫 卡爾濾波和姿態(tài)解算 難嗎?

    MPU6050模塊自己寫 卡爾濾波和姿態(tài)解算 難嗎? 大概多久能搞出來?
    發(fā)表于 12-22 17:35

    如何去實現(xiàn)一種基于MPU6050卡爾濾波的平衡小車呢

    如何去實現(xiàn)一種基于MPU6050卡爾濾波的平衡小車呢?有哪些資料呢?
    發(fā)表于 11-19 06:48

    MPU6050卡爾濾波互補(bǔ)濾波的比較分析

    這是總體的濾波效果這是放大的版的可以看出,卡爾和二階基本在重合在一起,一階也還好,也沒有差得太遠(yuǎn)。這里是從一放在桌子上一段時間后再進(jìn)行測試的,可以看出一階的跟隨性上面要比其他二個都要
    發(fā)表于 02-10 07:06

    卡爾濾波簡介

    在這里我就不介紹卡爾的數(shù)學(xué)推算了,網(wǎng)上的數(shù)學(xué)推導(dǎo)一抓一大把,如果想了解推導(dǎo)過程的小伙伴可以去大佬的博客。如果你是想直接簡單運(yùn)用卡爾濾波
    發(fā)表于 02-28 14:24

    基于MPU6050卡爾濾波的角度測量

    MPU6050使用卡爾濾波的方法介紹,使用卡爾濾波
    發(fā)表于 06-01 11:29 ?0次下載

    MPU6050_卡爾濾波

    MPU6050 卡爾濾波器設(shè)計
    發(fā)表于 06-23 10:51 ?41次下載

    卡爾濾波(以stm32f103rct6的MPU6050為例測試串口通信數(shù)據(jù)

    STM32F1的MPU6050相關(guān)卡爾濾波
    發(fā)表于 11-13 14:51 ?105次下載

    STM32F1的MPU6050模塊軟件卡爾濾波資料

    STM32F1的MPU6050模塊軟件卡爾濾波資料
    發(fā)表于 11-13 14:54 ?25次下載

    一文看懂mpu6050卡爾濾波程序

    本文開始闡述了卡爾濾波的概念,其次闡述了卡爾濾波的性質(zhì)與
    發(fā)表于 03-09 08:57 ?7.6w次閱讀
    一文看懂<b class='flag-5'>mpu6050</b><b class='flag-5'>卡爾</b><b class='flag-5'>曼</b><b class='flag-5'>濾波</b>程序

    使用51單片機(jī)實現(xiàn)MPU6050卡爾濾波算法代碼免費下載

    本文檔的主要內(nèi)容詳細(xì)介紹的是使用51單片機(jī)實現(xiàn)MPU6050卡爾濾波算法代碼免費下載 。
    發(fā)表于 08-20 17:31 ?61次下載
    使用51單片機(jī)實現(xiàn)<b class='flag-5'>MPU6050</b>的<b class='flag-5'>卡爾</b><b class='flag-5'>曼</b><b class='flag-5'>濾波</b>算法代碼免費下載

    串口MPU6050卡爾濾波6軸9軸資料合集免費下載

    本文檔的主要內(nèi)容詳細(xì)介紹的是串口MPU6050卡爾濾波6軸9軸資料合集免費下載包括了:MPU-6050寄存器映射,
    發(fā)表于 05-20 08:00 ?53次下載
    串口<b class='flag-5'>MPU6050</b><b class='flag-5'>卡爾</b><b class='flag-5'>曼</b><b class='flag-5'>濾波</b>6軸9軸資料合集免費下載

    畢業(yè)論文 | 基于MPU6050卡爾濾波的平衡小車設(shè)計(源代碼與設(shè)計文檔)

    畢業(yè)論文 | 基于MPU6050卡爾濾波的平衡小車設(shè)計(源代碼與設(shè)計文檔)
    發(fā)表于 11-21 20:06 ?23次下載
    畢業(yè)論文 | 基于<b class='flag-5'>MPU6050</b>及<b class='flag-5'>卡爾</b><b class='flag-5'>曼</b><b class='flag-5'>濾波</b>的平衡小車設(shè)計(源代碼與設(shè)計文檔)

    畢業(yè)論文 | 基于STM32的MPU6050程序設(shè)計(源碼)——卡爾濾波

    畢業(yè)論文 | 基于STM32的MPU6050程序設(shè)計(源碼)——卡爾濾波
    發(fā)表于 12-06 12:06 ?44次下載
    畢業(yè)論文 | 基于STM32的<b class='flag-5'>MPU6050</b>程序設(shè)計(源碼)——<b class='flag-5'>卡爾</b><b class='flag-5'>曼</b><b class='flag-5'>濾波</b>

    C語言 | 基于卡爾濾波器的角度測量儀(MPU6050

    C語言 | 基于卡爾濾波器的角度測量儀(MPU6050
    發(fā)表于 12-06 14:06 ?66次下載
    C語言 | 基于<b class='flag-5'>卡爾</b><b class='flag-5'>曼</b><b class='flag-5'>濾波</b>器的角度測量儀(<b class='flag-5'>MPU6050</b>)

    MPU6050使用互補(bǔ)濾波卡爾濾波算法進(jìn)行姿態(tài)解算

    MPU6050使用互補(bǔ)濾波卡爾濾波算法進(jìn)行姿態(tài)解算
    發(fā)表于 08-07 15:46 ?17次下載