卡曼濾波器
卡曼濾波器(英文:Kalman filter), 又叫卡曼濾波,亦都叫做線性二次估計(英文:linear quadratic estimation,LQE),係一種統計同控制理論算法,針對啲線性、理應係高斯誤差嘅系統嘅;而非線性系統就需要用到擴展卡曼濾波器嚟線性化過佢。卡曼濾波器跟住時間推移,攞到啲一系列嘅觀測值同埋好多時仲有系統斷估值、啲值包含有統計噪音同其他嘸准確性嘅,並根據每橛時間範圍內啲變數嘅聯合概率分佈嚟改善啲對未知變數嘅估計;好多時噉樣互相更新嘅估計值係準確過基於單個測量做嘅估計。個濾波器得名自Rudolf E. Kálmán,佢係個理論嘅主要開發者之一。
![](http://upload.wikimedia.org/wikipedia/commons/thumb/a/a5/Basic_concept_of_Kalman_filtering.svg/400px-Basic_concept_of_Kalman_filtering.svg.png)
概述
卡曼濾波算法分兩重工作。喺預測步驟裏便,卡曼濾波器產生啲對當前狀態變數及佢個嘸確定性嘅估計。一旦觀察到下一次測量嘅嗰個結果、個值梗會因一定量嘅誤差包括隨機噪音而有啲走趲嘅,就使用加權平均值(「卡曼增益」,英文:Kalman gain)嚟更新過呢啲估計值,並為具有確定性高啲嘅估計值畀多啲權重。呢個算法係遞歸嘅,佢可以實時運行得,僅使用到當前嘅輸入測量值同先前計算有嘅狀態,以及佢個嘸確定性矩陣,而嘸需要額外嘅過去信息。
卡曼濾波器嘅最佳性係假設個誤差係高斯類型。用 Rudolf E. Kálmán嘅話嚟講:「總而言之,以下假設係作畀啲隨機過程嘅:物理隨機現象可能可以認為係由於啲主要隨機源(primary random sources)激發咗啲動態系統。假設啲主要隨機源係有零平均值嘅獨立高斯隨機過程;噉啲動態系統就會係線性嘅。」 [1]即管戥高斯無關,若果個過程同埋啲測量協方差係已知嘅,噉個卡曼濾波器係喺最細均方誤差意義上最佳嘅線性估計器。[2]
過程
系統狀態方程
參睇線性系統嘅狀態空間方程,有:
其中啲關鍵嘅:
分別係過程噪音同埋測量噪音,服從到啲平均值零嘅高斯分佈,即
;
係輸出值,呢度係觀測模型個測量值。
係系統矩陣,亦即係狀態矩陣;
係輸入矩陣;
係觀測矩陣。
喺以下啲式當中,設卡曼濾波係一𨂾𨂾噉做,所以用 表示啲時間步;而卡曼濾波器當中個狀態轉移矩陣同埋觀測矩陣就分別爲
同
,而且係隔開個噪音,所以有:
(預測方程)
(觀測方程)
預測
設喺 嗰陣攞到最佳值即送去做預測,得到到一隻先驗斷估值同埋佢個協方差:
其中協方差表示個斷估值喺噪音影響下有幾大嘅範圍。
測量同更新
過唨一𨂾時間𨂾之後,卡曼濾波器攞到新嘅測量資訊 ,戥個「擬測量值」
求差、個由斷估值轉成嘅,可以求得到個新息值(英文:innovation,即測量值多出擬測量值嘅部分)同埋佢個協方差:
注意到由於卡曼濾波器嘸帶噪音,所以個觀測模型 夠勁嘅話
理應畀到似
噉嘅噪音。
係噉攞得到所謂嘅卡曼增益:
藉由呢個卡曼增益即更新得原本個斷估值成好啲嘅估計值,同埋更新埋個協方差:
,或者
係噉,又可以即刻返到預測嗰匹繼續做落去。
示意圖
下低係分𨂾總覽示意圖,橢圓啲係多變數高斯分佈,所有啲符號喺上高都得到解釋過。
![](http://upload.wikimedia.org/wikipedia/commons/thumb/a/a0/Kalman_filter_model_2.svg/800px-Kalman_filter_model_2.svg.png)
簡化場景
直接輸出預測值嘅話,相當於喺 場景下,係有返啲簡啲嘅式:
校參
參睇卡曼增益同埋估計更新:
通過校個卡曼增益大細可以校得到個比例(加權重),想倚賴模型嘅斷估值多啲定倚賴帶觀測嘅新息值多啲。
校卡曼增益大細
考慮卡曼增益嘅式:
捉啲 、
換齊成
,可以有一樸樚式:
注意到裏便有 ,可以考慮模型嘅過程噪音、傳感器嘅觀測噪音嚟設置。喺簡易場景下(
同
),可以有下式:
可以直觀噉睇得到 嘅設置係點影響返卡曼增益嘅大細。
拓展
卡曼濾波方法嘅擴展同廣義化都得到咗開發,譬如非線性系統適用嘅擴展卡曼濾波器同無跡卡曼濾波器。底層模型係一個隱馬可夫模型,其中啲潛在變數個狀態空間係連續嘅,而且所有啲潛在同觀察到嘅變數都具有高斯分佈。另外,卡曼濾波器都已成功噉用喺多傳感器融合[3]同分佈式傳感器網絡,嚟開發分佈式或者共識卡曼濾波器。[4]
應用
卡曼濾波器喺技術上有好多應用。一個常見嘅應用係攞嚟引導、導航同控制啲載具,特別係飛機、航天器同動態定位嘅船舶。[5]另外,卡曼濾波器係喺時間序列分析裏便廣泛應用開嘅概念,用喺訊號處理同計量經濟學等啲領域。卡曼濾波器亦都係喺機械人運動規劃同控制個領域嘅主要課題之一,用喺軌跡優化都得。[6]卡曼濾波器仲有用喺模擬中樞神經系統對運動嘅控制。由於發出運動命令同接收感官回輸之間存在有時間延遲,使用卡曼濾波器嘅話即支持返一種現實模型,可以估計得運動系統嘅當前狀態而且發出啲更新命令。[7]