【发布时间】:2016-01-09 02:39:29
【问题描述】:
我想对其进行粗略的 ARMA 预测,即了解更多关于如何使用 stats 模型库的知识并了解它是如何工作的。因此,首先我启动了网络中某处的示例,但 ARMA 拟合和预测不起作用,因为 MLE 不收敛。我决定这个系列不是静止的,所以首先我想消除趋势,这对我来说是一个挑战。代码如下:
import pandas.io.data as web
import statsmodels.api as sm
import statsmodels.tsa.api as tsa
import datetime
import statsmodels.formula.api as smf
start = datetime.datetime(2010, 1, 1)
end = datetime.datetime(2010, 1, 27)
f = web.DataReader("F", 'yahoo', start, end)
print f
#+++++++++++++++TREND+++++++++++++++
atrend = tsa.add_trend(f['Close'].values,trend='ctt')
print atrend
#+++++++++++++++fitting ARMA++++++++
arma =tsa.ARMA(f['Close'].values, order =(2,2))
results= arma.fit()
所以,打印“趋势”给了我:
[[ 10.28 1. 1. 1. ]
[ 10.96 1. 2. 4. ]
[ 11.37 1. 3. 9. ]
[ 11.66 1. 4. 16. ]
[ 11.69 1. 5. 25. ]
[ 12.11 1. 6. 36. ]
[ 11.87 1. 7. 49. ]
[ 11.68 1. 8. 64. ]
[ 11.76 1. 9. 81. ]
[ 11.6 1. 10. 100. ]
[ 11.75 1. 11. 121. ]
[ 11.51 1. 12. 144. ]
[ 11.18 1. 13. 169. ]
[ 10.52 1. 14. 196. ]
[ 11.03 1. 15. 225. ]
[ 11.19 1. 16. 256. ]
[ 11.55 1. 17. 289. ]]
我完全不明白。 我要求有一个 ctt 趋势,即:at^2+bt+c 为了比较,我在excel中计算了at^2+bt+c,at^3+bt^2+ct+d,得到了以下值。
10,494523
10,780752
11,031687
11,247328
11,427675
11,572728
11,682487
11,756952
11,796123
11,8
11,768583
11,701872
11,599867
11,462568
11,289975
11,082088
10,838907
对于抛物线,y = -1.7647x2 + 33.917x + 1017.3 ,并且:
10,00432
10,65848
11,1547
11,5105
11,7434
11,87092
11,91058
11,8799
11,7964
11,6776
11,54102
11,40418
11,2846
11,1998
11,1673
11,20462
11,32928
对于三次方程 y = 0.292x3 - 9.649x2 + 92.319x + 917.47。 即使是现在,我也不知道如何将这些值插入 arma =tsa.ARMA(f['Close'].values, order =(2,2)) 以检查我是否可以执行下一个任务。
总而言之,我的想法是简要介绍如何轻松地在 python 中使用 ARMA 预测,但对我来说并非如此。
【问题讨论】:
标签: python statistics time-series statsmodels