我試圖計算係數從一個n -degree多項式適用於一個時間序列的日期窗口t。但是,我收到一個例外TypeError: only length-1 arrays can be converted to Python scalars
。滾動窗口多項式擬合熊貓
我的版本是:
- 的Python 3.6
- 大熊貓版本0.22.0
- numpy的版本1.13.3
代碼:
import pandas as pd
import numpy as np
my_ts = pd.Series(data = np.random.normal(size = 365 * 2), index = pd.date_range(start = '2013-01-01', periods = 365 * 2))
coefs = pd.rolling_apply(my_ts, 21, lambda x: np.polyfit(range(len(x)), x, 3))
然而,當我包裝np.polyfit
時如此它只返回一個係數,rolling_apply
沒有問題。
def pf_wrapper(x):
coef_lst = np.polyfit(range(len(x)), x, 3)
return coef_lst[0]
coefs = pd.rolling_apply(my_ts, 21, pf_wrapper)
UPDATE:
由於pd.rolling_apply()
無法返回一個非標,我目前的解決方案是:
def get_beta(ts, deg):
coefs = polyfit(range(len(ts)), ts, deg = 3)[::-1]
return coefs[deg]
b0 = pd.rolling_apply(my_ts, 21, lambda x: get_beta(x, 0))
...
b3 = pd.rolling_apply(my_ts, 21, lambda x: get_beta(x, 3))