Python曲線平滑的實現(xiàn)示例
在編寫測試程序的時候,由于數(shù)據(jù)幀數(shù)多的原因,導致生成的曲線圖比較難看,如下圖:
由于高頻某些點的波動導致高頻曲線非常難看,因此需要對曲線做平滑處理,讓曲線過渡更平滑。對曲線進行平滑處理,這里推薦使用Savitzky-Golay
濾波器,可以在scipy
庫里直接調用,不需要再定義函數(shù)。
Python中 Savitzky-Golay 濾波器調用如下:
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是窗口長度,該值需為正奇整數(shù)。polyorder為對窗口內的數(shù)據(jù)點進行k階多項式擬合,k的值需要小于window_length。
現(xiàn)在看一下window_length和k這兩個值對曲線的影響。
(1) 首先是window_length
對曲線的平滑作用,代碼如下:
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的值越小,曲線越貼近真實曲線;window_length值越大,平滑效果越厲害。
(2) 再看k
值對曲線的影響,代碼如下:
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值越大,曲線越貼近真實曲線;k值越小,曲線平滑越厲害。另外,當k值較大時,受窗口長度限制,擬合會出現(xiàn)問題,高頻曲線會變成直線,如下圖所示:
參考資源
[1] python 平滑_Python 生成曲線進行快速平滑處理
[2] Savitzky-Golay平滑濾波的python實現(xiàn)
到此這篇關于Python曲線平滑的實現(xiàn)示例的文章就介紹到這了,更多相關Python曲線平滑內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Python批量添加水印的優(yōu)雅實現(xiàn)與進階
在日常圖像處理中,為圖片添加水印是一項常見任務,有多種方法和工具可供選擇,本文將專注于使用Python語言結合PIL庫批量添加水印,感興趣的可以了解下2023-12-12Python如何操作office實現(xiàn)自動化及win32com.client的運用
這篇文章主要介紹了Python如何操作office實現(xiàn)自動化及win32com.client的運用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-04-04在python中使用pyspark讀寫Hive數(shù)據(jù)操作
這篇文章主要介紹了在python中使用pyspark讀寫Hive數(shù)據(jù)操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06