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

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

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

卡爾曼濾波器原理分析

新機(jī)器視覺 ? 來源:古月居 ? 2023-05-09 17:30 ? 次閱讀

原理

卡爾曼濾波器是一種基礎(chǔ)預(yù)測(cè)定位算法。原理非常簡單易懂。核心過程可以用一個(gè)圖說明:

c003a2c4-ec26-11ed-90ce-dac502259ad0.jpg

本質(zhì)上就是這兩個(gè)狀態(tài)過程的迭代,來逐步的準(zhǔn)確定位。

預(yù)測(cè):當(dāng)前狀態(tài)環(huán)境下,對(duì)下一個(gè)時(shí)間段t的位置估計(jì)計(jì)算的值。

更新:更具傳感器獲取到比較準(zhǔn)確的位置信息后來更新當(dāng)前的預(yù)測(cè)問位置,也就是糾正預(yù)測(cè)的錯(cuò)誤。

你可能要問為什么有傳感器的數(shù)據(jù)了還要進(jìn)行更新?因?yàn)樵诂F(xiàn)實(shí)世界中傳感器是存在很多噪聲干擾的,所以也不能完全相信傳感器數(shù)據(jù)??柭惴ㄒ蕾囉诰€性計(jì)算,高斯分布,我們以一維定位來介紹算法的實(shí)現(xiàn)。

c0099b2a-ec26-11ed-90ce-dac502259ad0.jpg

c012ebf8-ec26-11ed-90ce-dac502259ad0.png

接下來我們開更新,預(yù)測(cè)后我們獲取到傳感器數(shù)據(jù),表示目前傳感器發(fā)現(xiàn)小車的位置應(yīng)該是在26這個(gè)位置,在這種情況下,我們肯定是覺得傳感器的準(zhǔn)確度比我之前的預(yù)測(cè)瞎猜要來的準(zhǔn)確。

所以方差自然會(huì)比較小,最終我們覺得真是的小車位置應(yīng)該是更靠近傳感器數(shù)據(jù)的,而且方差會(huì)縮小,以至于,想想也很清楚,我猜了一個(gè)預(yù)測(cè)值,現(xiàn)在有個(gè)專家告訴了我相對(duì)比較靠譜的數(shù)據(jù),那我對(duì)小車的位置的自信度肯定會(huì)上升啊。

最終小車的位置經(jīng)過這個(gè)時(shí)間段t的更新就是下圖紅色的高斯圖:

c01e3116-ec26-11ed-90ce-dac502259ad0.jpg

就這樣不停的移動(dòng)更新,最終小車的位置就會(huì)越來越準(zhǔn)確。

一維模型下的Kalman公式:

預(yù)測(cè) c0291b6c-ec26-11ed-90ce-dac502259ad0.jpg

更新 c0313860-ec26-11ed-90ce-dac502259ad0.jpg

c03c455c-ec26-11ed-90ce-dac502259ad0.jpg

參考代碼:

#include 
#include 
#include 


using namespace std;


double new_mean, new_var;


tuple measurement_update(double mean1, double var1, double mean2, double var2)
{
  new_mean = (var2 * mean1 + var1 * mean2) / (var1 + var2);
  new_var = 1 / (1 / var1 + 1 / var2);
  return make_tuple(new_mean, new_var);
}


tuple state_prediction(double mean1, double var1, double mean2, double var2)
{
  new_mean = mean1 + mean2;
  new_var = var1 + var2;
  return make_tuple(new_mean, new_var);
}


int main()
{
  //Measurements and measurement variance
  double measurements[5] = { 5, 6, 7, 9, 10 };
  double measurement_sig = 4;
  
  //Motions and motion variance
  double motion[5] = { 1, 1, 2, 1, 1 };
  double motion_sig = 2;
  
  //Initial state
  double mu = 0;
  double sig = 1000;


  for (int i = 0; i < sizeof(measurements) / sizeof(measurements[0]); i++) {
 ? ? ? ?tie(mu, sig) = measurement_update(mu, sig, measurements[i], measurement_sig);
 ? ? ? ?printf("update: ?[%f, %f]
", mu, sig);
 ? ? ? ?tie(mu, sig) = state_prediction(mu, sig, motion[i], motion_sig);
 ? ? ? ?printf("predict: [%f, %f]
", mu, sig);
 ? ?}


 ? ?return 0;
}

審核編輯:湯梓紅

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

    關(guān)注

    2552

    文章

    51292

    瀏覽量

    755195
  • 濾波器
    +關(guān)注

    關(guān)注

    161

    文章

    7853

    瀏覽量

    178510
  • 定位算法
    +關(guān)注

    關(guān)注

    0

    文章

    61

    瀏覽量

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

    關(guān)注

    0

    文章

    54

    瀏覽量

    12197

原文標(biāo)題:基礎(chǔ)卡爾曼濾波

文章出處:【微信號(hào):vision263com,微信公眾號(hào):新機(jī)器視覺】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    卡爾濾波器介紹

    卡爾濾波器介紹卡爾濾波器介紹Greg Welch1and Gary Bishop2TR 95
    發(fā)表于 07-14 13:06

    卡爾濾波器通俗講解

    卡爾濾波器通俗講解
    發(fā)表于 08-17 12:06

    卡爾濾波器的使用原理

    [開發(fā)工具] STM32算法的翅膀之MATLAB基于加速度計(jì)與氣壓計(jì)的三階卡爾濾波計(jì)算加速度、速度及高度主要介紹了卡爾
    發(fā)表于 08-17 07:02

    卡爾濾波器是什么

    一、前言卡爾濾波器是一種最優(yōu)線性狀態(tài)估計(jì)方法(等價(jià)于“在最小均方誤差準(zhǔn)則下的最佳線性濾波器”),所謂狀態(tài)估計(jì)就是通過數(shù)學(xué)方法尋求與觀測(cè)數(shù)據(jù)最佳擬合的狀態(tài)向量。在移動(dòng)機(jī)器人導(dǎo)航方面,
    發(fā)表于 11-16 09:10

    卡爾濾波器原理

    離散卡爾濾波器1960年,卡爾發(fā)表了他著名的用遞歸方法解決離散數(shù)據(jù)線性濾波問題的論文[Kal
    發(fā)表于 07-14 13:03 ?0次下載

    卡爾濾波器參數(shù)分析與應(yīng)用方法研究

    介紹卡爾濾波器及其各種衍生方法。首先給出卡爾濾波器的算法流程以及所有參數(shù)的含義,并對(duì)影響
    發(fā)表于 06-21 17:56 ?6次下載

    圖解卡爾濾波器

     卡爾濾波器是一種由卡爾(Kalman)提出的用于時(shí)變線性系統(tǒng)的遞歸濾波器。這個(gè)系統(tǒng)可用包含
    發(fā)表于 02-07 18:06 ?4902次閱讀
    圖解<b class='flag-5'>卡爾</b><b class='flag-5'>曼</b><b class='flag-5'>濾波器</b>

    基于卡爾濾波器的PID設(shè)計(jì)教程

    基于卡爾濾波器的PID設(shè)計(jì)教程
    發(fā)表于 06-03 10:27 ?37次下載

    卡爾濾波器及其應(yīng)用基礎(chǔ).敬喜編

    卡爾濾波器及其應(yīng)用基礎(chǔ).敬喜編
    發(fā)表于 10-18 10:14 ?0次下載

    卡爾濾波器的基本原理

    卡爾濾波器是一種基礎(chǔ)預(yù)測(cè)定位算法。原理非常簡單易懂。
    的頭像 發(fā)表于 03-21 13:47 ?6082次閱讀

    如何理解卡爾濾波器?卡爾濾波器狀態(tài)方程及測(cè)量方程

    卡爾濾波的最終輸出是,真實(shí)的狀態(tài)為,令 對(duì)誤差的平方求最小值,同樣可以推導(dǎo)出公式(1-5)到公式(1-7)。因此卡爾
    發(fā)表于 12-15 10:45 ?2973次閱讀

    卡爾濾波器介紹與理論分析(上)

    卡爾濾波常用于動(dòng)態(tài)多變化系統(tǒng)中的狀態(tài)估計(jì),是一種通用性強(qiáng)的自回歸濾波器。它的由來和NASA登月有關(guān)。其發(fā)明者魯?shù)婪?E.卡爾
    發(fā)表于 02-10 14:31 ?1272次閱讀
    <b class='flag-5'>卡爾</b><b class='flag-5'>曼</b><b class='flag-5'>濾波器</b>介紹與理論<b class='flag-5'>分析</b>(上)

    卡爾濾波器介紹與理論分析(下)

    卡爾濾波常用于動(dòng)態(tài)多變化系統(tǒng)中的狀態(tài)估計(jì),是一種通用性強(qiáng)的自回歸濾波器。它的由來和NASA登月有關(guān)。其發(fā)明者魯?shù)婪?E.卡爾
    發(fā)表于 02-10 14:31 ?365次閱讀
    <b class='flag-5'>卡爾</b><b class='flag-5'>曼</b><b class='flag-5'>濾波器</b>介紹與理論<b class='flag-5'>分析</b>(下)

    用于定位的實(shí)用卡爾濾波器

    電子發(fā)燒友網(wǎng)站提供《用于定位的實(shí)用卡爾濾波器.zip》資料免費(fèi)下載
    發(fā)表于 06-16 10:07 ?0次下載
    用于定位的實(shí)用<b class='flag-5'>卡爾</b><b class='flag-5'>曼</b><b class='flag-5'>濾波器</b>

    卡爾濾波器的特性及仿真

    我們前一篇關(guān)于人物識(shí)別跟蹤的文章《視頻連續(xù)目標(biāo)跟蹤實(shí)現(xiàn)的兩種方法和示例(更新)》里講到,視頻圖像中物體的識(shí)別和跟蹤用到了卡爾濾波器(KF)。這里對(duì)這個(gè)話題我們稍微對(duì)這個(gè)卡爾
    的頭像 發(fā)表于 11-04 11:36 ?438次閱讀
    <b class='flag-5'>卡爾</b><b class='flag-5'>曼</b><b class='flag-5'>濾波器</b>的特性及仿真