亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

卡爾曼濾波數(shù)據(jù)處理技巧通俗理解及python實(shí)現(xiàn)

 更新時(shí)間:2022年05月04日 09:21:45   作者:Bubbliiiing  
這篇文章主要為大家介紹了卡爾曼濾波數(shù)據(jù)處理技巧的通俗理解及python實(shí)現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

學(xué)習(xí)前言

好久沒用過arduino了,接下去要用arduino和超聲波做個(gè)小實(shí)驗(yàn),對(duì)于讀取的模擬量肯定要進(jìn)行濾波呀,不然這模擬量咋咋呼呼的怎么用

什么是卡爾曼濾波

先看看百度百科解釋哈:卡爾曼濾波(Kalman filtering)是一種利用線性系統(tǒng)狀態(tài)方程,通過系統(tǒng)輸入輸出觀測(cè)數(shù)據(jù),對(duì)系統(tǒng)狀態(tài)進(jìn)行最優(yōu)估計(jì)的算法。由于觀測(cè)數(shù)據(jù)中包括系統(tǒng)中的噪聲和干擾的影響,所以最優(yōu)估計(jì)也可看作是濾波過程。

重要的事說(shuō)三遍:

還不如不看!

還不如不看??!

還不如不看!??!

其實(shí)大家并不需要把卡爾曼濾波當(dāng)作一種很復(fù)雜的東西,用通俗的話來(lái)講,卡爾曼濾波算法只是一種 濾波算法,它的功能就是 濾波,濾波的作用就是減少噪聲與干擾對(duì)數(shù)據(jù)測(cè)量的影響。

卡爾曼濾波是怎么濾波的

接下來(lái)我會(huì)用一句話概括卡爾曼濾波的操作過程:

卡爾曼濾波是一種通過 歷史數(shù)據(jù)、歷史積累誤差、當(dāng)前測(cè)量數(shù)據(jù)與當(dāng)前誤差 聯(lián)合計(jì)算出的當(dāng)前被測(cè)量的最優(yōu)預(yù)測(cè)值。

首先大家要先理解什么是當(dāng)前被測(cè)量的最優(yōu)預(yù)測(cè)值:

里面有兩個(gè)重要的概念,分別是 最優(yōu) 和 預(yù)測(cè)值 :

這意味著:

1、卡爾曼濾波的結(jié)果不是確確實(shí)實(shí)被測(cè)量出來(lái)的,而是利用公式計(jì)算出來(lái)的預(yù)測(cè)結(jié)果(并不是說(shuō)預(yù)測(cè)結(jié)果就不好,測(cè)量還存在誤差呢?。?;

2、最優(yōu)是因?yàn)榭柭鼮V波考慮的非常多,它結(jié)合了四個(gè)參數(shù)對(duì)當(dāng)前的被測(cè)量進(jìn)行預(yù)測(cè),所以效果比較好。

接下里大家要理解 歷史數(shù)據(jù)、歷史積累誤差、當(dāng)前測(cè)量數(shù)據(jù)與當(dāng)前誤差 的概念。

我會(huì)通過實(shí)例給大家講講這四個(gè)東西的概念。

卡爾曼濾波實(shí)例

假設(shè)我們現(xiàn)在在用超聲波測(cè)距離!現(xiàn)在是t時(shí)間,我們需要用t-1時(shí)間的距離來(lái)估計(jì)t時(shí)間的距離。

設(shè)在t-1時(shí)刻,超聲波的被測(cè)量的最優(yōu)預(yù)測(cè)值為50cm,而到t-1時(shí)刻的積累誤差3cm,你自己對(duì)預(yù)測(cè)的不確定誤差為4cm,那么在t-1時(shí)刻,其總誤差為(32+42)1/2=5cm。

在t時(shí)刻,超聲波測(cè)得的實(shí)際值53cm,測(cè)量誤差為2cm,那我們要怎么去相信上一時(shí)刻的預(yù)測(cè)值和這一時(shí)刻的實(shí)際值呢?因?yàn)槎叨疾皇菧?zhǔn)的,我們可以利用誤差來(lái)計(jì)算。

因此,我們結(jié)合 歷史數(shù)據(jù)、歷史積累誤差、當(dāng)前測(cè)量數(shù)據(jù)與當(dāng)前誤差 來(lái)計(jì)算:

所以當(dāng)前的最優(yōu)預(yù)測(cè)值為52.59。

卡爾曼濾波的python代碼實(shí)現(xiàn)

import numpy as np
import matplotlib.pyplot as plt
# Q為這一輪的心里的預(yù)估誤差
Q = 0.00001
# R為下一輪的測(cè)量誤差
R = 0.1
# Accumulated_Error為上一輪的估計(jì)誤差,具體呈現(xiàn)為所有誤差的累計(jì)
Accumulated_Error = 1
# 初始舊值
kalman_adc_old = 0
SCOPE = 50
def kalman(ADC_Value):
    global kalman_adc_old
    global Accumulated_Error
    # 新的值相比舊的值差太大時(shí)進(jìn)行跟蹤
    if (abs(ADC_Value-kalman_adc_old)/SCOPE > 0.25):
        Old_Input = ADC_Value*0.382 + kalman_adc_old*0.618
    else:
        Old_Input = kalman_adc_old
    # 上一輪的 總誤差=累計(jì)誤差^2+預(yù)估誤差^2
    Old_Error_All = (Accumulated_Error**2 + Q**2)**(1/2)
    # R為這一輪的預(yù)估誤差
    # H為利用均方差計(jì)算出來(lái)的雙方的相信度
    H = Old_Error_All**2/(Old_Error_All**2 + R**2)
    # 舊值 + 1.00001/(1.00001+0.1) * (新值-舊值)
    kalman_adc = Old_Input + H * (ADC_Value - Old_Input)
    # 計(jì)算新的累計(jì)誤差
    Accumulated_Error = ((1 - H)*Old_Error_All**2)**(1/2)
    # 新值變?yōu)榕f值
    kalman_adc_old = kalman_adc
    return kalman_adc
array = np.array([50]*200)
s = np.random.normal(0, 5, 200)
test_array = array + s
plt.plot(test_array)
adc=[]
for i in range(200):
    adc.append(kalman(test_array[i]))
plt.plot(adc)   
plt.plot(array)   
plt.show()

實(shí)驗(yàn)結(jié)果為:

以上就是卡爾曼濾波數(shù)據(jù)處理技巧通俗理解及python實(shí)現(xiàn)的詳細(xì)內(nèi)容,更多關(guān)于python卡爾曼濾波數(shù)據(jù)處理的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • python統(tǒng)計(jì)日志ip訪問數(shù)的方法

    python統(tǒng)計(jì)日志ip訪問數(shù)的方法

    這篇文章主要介紹了python統(tǒng)計(jì)日志ip訪問數(shù)的方法,涉及Python操作日志文件及正則匹配的相關(guān)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-07-07
  • 解決安裝tensorflow遇到無(wú)法卸載numpy 1.8.0rc1的問題

    解決安裝tensorflow遇到無(wú)法卸載numpy 1.8.0rc1的問題

    今天小編就為大家分享一篇解決安裝tensorflow遇到無(wú)法卸載numpy 1.8.0rc1的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧
    2018-06-06
  • 關(guān)于pandas中的.update()方法解析

    關(guān)于pandas中的.update()方法解析

    這篇文章主要介紹了關(guān)于pandas中的.update()方法解析,在Pandas中,update()方法用于將一個(gè)DataFrame或Series對(duì)象中的值更新為另一個(gè)DataFrame或Series對(duì)象中的對(duì)應(yīng)值,需要的朋友可以參考下
    2023-07-07
  • 如何在PyCharm中配置使用Anaconda環(huán)境

    如何在PyCharm中配置使用Anaconda環(huán)境

    這篇文章主要介紹了如何在PyCharm中配置使用Anaconda環(huán)境,圖文講解寫的非常詳細(xì)簡(jiǎn)單易懂,還不會(huì)的小伙伴快來(lái)看看吧
    2023-03-03
  • Django admin組件的使用

    Django admin組件的使用

    這篇文章主要介紹了Django admin組件的使用,幫助大家更好的理解和學(xué)習(xí)Django框架,感興趣的朋友可以了解下
    2020-10-10
  • Jupyter中markdown的操作方法

    Jupyter中markdown的操作方法

    Jupyter Notebook是基于網(wǎng)頁(yè)的用于交互計(jì)算的應(yīng)用程序,Jupyter notebook,作為Python廣受歡迎的一款I(lǐng)DLE,其直觀性、簡(jiǎn)易性、易于閱讀等優(yōu)點(diǎn)廣受許多Python用戶所推薦,這篇文章介紹Jupyter中markdown的操作,感興趣的朋友一起看看吧
    2024-01-01
  • 使用Python對(duì)零售商品進(jìn)行數(shù)據(jù)分析

    使用Python對(duì)零售商品進(jìn)行數(shù)據(jù)分析

    這篇文章主要為大家介紹了使用Python對(duì)零售商品進(jìn)行數(shù)據(jù)分析詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • python中的字典及嵌套遍歷

    python中的字典及嵌套遍歷

    這篇文章主要介紹了python中的字典及嵌套遍歷,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Python線程下使用鎖的技巧分享

    Python線程下使用鎖的技巧分享

    本篇文章給大家分享了Python線程下使用鎖需要注意的地方,有興趣的朋友們可以學(xué)習(xí)參考下。
    2018-09-09
  • Python之lambda匿名函數(shù)及map和filter的用法

    Python之lambda匿名函數(shù)及map和filter的用法

    今天小編就為大家分享一篇關(guān)于Python之lambda匿名函數(shù)及map和filter的用法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-03-03

最新評(píng)論