您好,登錄后才能下訂單哦!
小編給大家分享一下Python如何實現滑動平均,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
Python中滑動平均算法(Moving Average)方案:
#!/usr/bin/env python # -*- coding: utf-8 -*- import numpy as np # 等同于MATLAB中的smooth函數,但是平滑窗口必須為奇數。 # yy = smooth(y) smooths the data in the column vector y .. # The first few elements of yy are given by # yy(1) = y(1) # yy(2) = (y(1) + y(2) + y(3))/3 # yy(3) = (y(1) + y(2) + y(3) + y(4) + y(5))/5 # yy(4) = (y(2) + y(3) + y(4) + y(5) + y(6))/5 # ... def smooth(a,WSZ): # a:原始數據,NumPy 1-D array containing the data to be smoothed # 必須是1-D的,如果不是,請使用 np.ravel()或者np.squeeze()轉化 # WSZ: smoothing window size needs, which must be odd number, # as in the original MATLAB implementation out0 = np.convolve(a,np.ones(WSZ,dtype=int),'valid')/WSZ r = np.arange(1,WSZ-1,2) start = np.cumsum(a[:WSZ-1])[::2]/r stop = (np.cumsum(a[:-WSZ:-1])[::2]/r)[::-1] return np.concatenate(( start , out0, stop )) # another one,邊緣處理的不好 """ def movingaverage(data, window_size): window = np.ones(int(window_size))/float(window_size) return np.convolve(data, window, 'same') """ # another one,速度更快 # 輸出結果 不與原始數據等長,假設原數據為m,平滑步長為t,則輸出數據為m-t+1 """ def movingaverage(data, window_size): cumsum_vec = np.cumsum(np.insert(data, 0, 0)) ma_vec = (cumsum_vec[window_size:] - cumsum_vec[:-window_size]) / window_size return ma_vec """
以上是“Python如何實現滑動平均”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。