跳到主要內容

[python] 史上最強移動平均法!!

移動平均法!


今天為了幫我的 IMU 做點低通濾波,跑去查了一下資料。

由於有人推薦使用 移動平均法去計算,我就稍微查了一下,發現了這個 code ...


import numpy as np



def moving_average(a, n=3) :

    ret = np.cumsum(a, dtype=float)

    ret[n:] = ret[n:] - ret[:-n]

    return ret[n - 1:] / n




然後駑鈍如我,完全是百思不得其解啊!!

我了解 np.cumsum 是累加數值,也了解 ret[n:] 是代表選取 n 到 list 最後一個數值

但是合起來我就是一個 "你是安怎!?" 的狀況。



代入值實際算了一下:


data = [1,2,3,4,5]

ans = moving_average(data)

print ans  #get [2,3,4]



竟然是正確答案啊!!!



後來用代數寫了一遍他的步驟我才了解....哇靠! 這個寫法真的是太神了XDD
data = [a, b, c, d, e]
ans =  [(a+b+c)/3, (b+c+d)/3, (c+d+e)/3]


他用的步驟是...先加總     ret = [a, a+b, a+b+c, a+b+c+d, a+b+c+d+e]

然後選擇 後面項 減去 前面項!!(這傢伙開金手指啊!!),變成:

[a+b+c+d, a+b+c+d+e] - [a, a+b]  = [b+c+d, c+d+e]

帶入到原本的 list 裡面,讓

     ret =  [a, a+b, a+b+c, a+b+c+d, a+b+c+d+e]  被取代成  ret = [a, a+b, a+b+c, b+c+d, c+d+e]


然後只 return ret 的後三項除以三,得到答案   [(a+b+c)/3, (b+c+d)/3, (c+d+e)/3]


超神人的做法啊!!!!! 這招好杯壁!!!!!

大大我真的佩服你啊.....


留言

這個網誌中的熱門文章

[python] 使用 python 控制 docx 範例

因為同事的需求,無職 a 我就又再度幫忙同事寫一些小程式。 這些小程式雖然簡單,但是聽到如果不幫忙寫程式解決,以手工作業的"大量人天" 的後果真的是讓人吐血。 他們有一份工作,需要產出一份很多很多很多資料圖片的判釋報告,要把數百張圖片剪裁成特定大小,加上圖說之後放入 word 裡面。 聽到的做法是...一張一張插圖!! wooow! That's really shocking me! 所以為了前公司同事的幸福,我還是加減寫一下好了。

[電銲] 自己的 IMU 自己焊!笨蛋的焊接法!

工程師真的是被要求包山包海都要會... IMU的組件被要求不能只插麵包板,要 "穩固的固定在另外製作的盒子裡",反正就是搞得跟外面幾十萬上下的 IMU 一樣精緻就是了。 好好好都焊給你~ 呃 對了 怎麼焊哈哈哈哈 ^^" 電焊這種技術自從上過國中的生活科技後就再也沒再用了@@,好家在這是個網路就是你家的時代,立刻上網查一查,找到一些關於焊槍使用的相關資料。 被要求說GY-91不能只接麵包板一定焊死才穩固所以就這樣接了

[RaspberryPI] 一鍵啟動 .py 文件

先講總結: 樹莓派君你好討厭啊啊啊啊! 今天把程式整理完之後,心血來潮,想要把 程式弄得更 "一鍵啟動" 一點。 也就是我只要用我的觸控螢幕一點,就可以直接打開寫好的 QT 介面做 IMU 和 相機的紀錄 親手烘培(?) 的 QT 介面