Роллинг окно для 1D массивов в Numpy? - PullRequest
32 голосов
/ 25 июля 2011

Есть ли способ эффективно реализовать скользящее окно для одномерных массивов в Numpy?

Например, у меня есть этот чистый фрагмент кода Python для вычисления скользящих стандартных отклонений для одномерного списка, где observationsэто 1D список значений, а n - это длина окна для стандартного отклонения:

stdev = []
for i, data in enumerate(observations[n-1:]):
    strip = observations[i:i+n]
    mean = sum(strip) / n
    stdev.append(sqrt(250*sum([(s-mean)**2 for s in strip])/(n-1)))

Есть ли способ сделать это полностью в Numpy, то есть без каких-либо петель Python?Стандартное отклонение тривиально с numpy.std, но часть с вращающимся окном меня совершенно ошарашивает.

Я нашел это сообщение в блоге о скользящем окне в Numpy, но, похоже, онобыть для 1D массивов.

Ответы [ 2 ]

50 голосов
/ 25 июля 2011

Просто используйте код блога, но примените свою функцию к результату.

т.е.

numpy.std(rolling_window(observations, n), 1)

где у вас есть (из блога):

def rolling_window(a, window):
    shape = a.shape[:-1] + (a.shape[-1] - window + 1, window)
    strides = a.strides + (a.strides[-1],)
    return np.lib.stride_tricks.as_strided(a, shape=shape, strides=strides)
1 голос
/ 14 марта 2019
def moving_avg(x,n):
    mv =  np.convolve(x,np.ones(n)/n,mode='valid')
    return np.concatenate(([np.NaN for k in range(n-1)],mv))
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...