Python曲線平滑的實(shí)現(xiàn)示例
在編寫測(cè)試程序的時(shí)候,由于數(shù)據(jù)幀數(shù)多的原因,導(dǎo)致生成的曲線圖比較難看,如下圖:

由于高頻某些點(diǎn)的波動(dòng)導(dǎo)致高頻曲線非常難看,因此需要對(duì)曲線做平滑處理,讓曲線過渡更平滑。對(duì)曲線進(jìn)行平滑處理,這里推薦使用Savitzky-Golay 濾波器,可以在scipy庫(kù)里直接調(diào)用,不需要再定義函數(shù)。
Python中 Savitzky-Golay 濾波器調(diào)用如下:
tmp_smooth = scipy.signal.savgol_filter(tmp,53,3)
scipy函數(shù)解釋:
scipy.signal.savgol_filter(x, window_length, polyorder, deriv=0, delta=1.0, axis=-1, mode=‘interp’, cval=0.0)[source]
Apply a Savitzky-Golay filter to an array.
This is a 1-d filter. If x has dimension greater than 1, axis determines the axis along which the filter is applied.
在scipy函數(shù)解釋中,x為原始數(shù)據(jù),即上面代碼中的tmp數(shù)據(jù)。window_length是窗口長(zhǎng)度,該值需為正奇整數(shù)。polyorder為對(duì)窗口內(nèi)的數(shù)據(jù)點(diǎn)進(jìn)行k階多項(xiàng)式擬合,k的值需要小于window_length。
現(xiàn)在看一下window_length和k這兩個(gè)值對(duì)曲線的影響。
(1) 首先是window_length對(duì)曲線的平滑作用,代碼如下:
tmp_smooth1 = scipy.signal.savgol_filter(tmp,21,3) tmp_smooth2 = scipy.signal.savgol_filter(tmp,53,3) plt.semilogx(f,tmp*0.5,label = 'mic'+str(num+1)) plt.semilogx(f,tmp_smooth1*0.5,label = 'mic'+str(num+1)+'擬合曲線-21',color = 'red') plt.semilogx(f,tmp_smooth2*0.5,label = 'mic'+str(num+1)+'擬合曲線-53',color = 'green')

可以看到,window_length的值越小,曲線越貼近真實(shí)曲線;window_length值越大,平滑效果越厲害。
(2) 再看k值對(duì)曲線的影響,代碼如下:
tmp_smooth1 = scipy.signal.savgol_filter(tmp,21,3) tmp_smooth2 = scipy.signal.savgol_filter(tmp,53,3) plt.semilogx(f,tmp*0.5,label = 'mic'+str(num+1)) plt.semilogx(f,tmp_smooth1*0.5,label = 'mic'+str(num+1)+'擬合曲線-21',color = 'red') plt.semilogx(f,tmp_smooth2*0.5,label = 'mic'+str(num+1)+'擬合曲線-53',color = 'green')
生成曲線圖如下:

可以看到,k值越大,曲線越貼近真實(shí)曲線;k值越小,曲線平滑越厲害。另外,當(dāng)k值較大時(shí),受窗口長(zhǎng)度限制,擬合會(huì)出現(xiàn)問題,高頻曲線會(huì)變成直線,如下圖所示:

參考資源
[1] python 平滑_Python 生成曲線進(jìn)行快速平滑處理
[2] Savitzky-Golay平滑濾波的python實(shí)現(xiàn)
到此這篇關(guān)于Python曲線平滑的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)Python曲線平滑內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python?使用ctypes調(diào)用C/C++?dll詳情
這篇文章主要介紹了python?使用ctypes調(diào)用C/C++?dll詳情,文章首先通過導(dǎo)入ctypes模塊,加載C/C++?dll到python進(jìn)程空間展開主題相關(guān)內(nèi)容,需要的小伙伴可以參考一下2022-04-04
Keras在訓(xùn)練期間可視化訓(xùn)練誤差和測(cè)試誤差實(shí)例
這篇文章主要介紹了Keras在訓(xùn)練期間可視化訓(xùn)練誤差和測(cè)試誤差實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-06-06
Python Flask自定義URL路由參數(shù)過濾器的方法詳解
Flask是一個(gè)輕量級(jí)的Python Web應(yīng)用框架,它允許開發(fā)者以一種簡(jiǎn)潔明了的方式來構(gòu)建Web應(yīng)用,Flask自定義URL的主要功能在于使得開發(fā)者能夠通過簡(jiǎn)單的路由規(guī)則來自定義應(yīng)用程序的URL結(jié)構(gòu),本文給大家介紹了Python Flask自定義URL路由參數(shù)過濾器的方法,需要的朋友可以參考下2024-07-07
ChatGPT 幫我自動(dòng)編寫 Python 爬蟲腳本的詳細(xì)過程
ChatGPT是一種基于大語(yǔ)言模型的生成式AI,換句話說它可以自動(dòng)生成類似人類語(yǔ)言的文本,把梳理好的有邏輯的答案呈現(xiàn)在你面前,這完全不同于傳統(tǒng)搜索工具,這篇文章主要介紹了ChatGPT 幫我自動(dòng)編寫 Python 爬蟲腳本,需要的朋友可以參考下2023-02-02

