QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2308|回复: 0
打印 上一主题 下一主题

ARMA 模型使用拟合的模型进行预测

[复制链接]
字体大小: 正常 放大

1186

主题

4

听众

2922

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 10:19 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
ARIMA(Autoregressive Integrated Moving Average)模型是一种常用的时间序列分析方法,用于对时间序列数据建模和预测。它通过结合自回归(AR)和滑动平均(MA)模型的特性,并对序列进行差分(Integration,即I)来建立模型。" e" u3 C  I3 G/ n+ m$ n; p0 a. h
ARIMA模型的三个主要参数是p、d和q,分别对应于自回归、差分和滑动平均的阶数。
* A4 i* V# Y: b6 v: V+ b
' t9 T4 ~0 G! A% _7 u1.自回归(AR):自回归部分使用先前时间点的观测值来预测当前值。p参数表示自回归的阶数,即使用多少个先前时间点的值作为预测输入。2 |9 T0 R6 U2 m6 C3 ^2 B
2.差分(I):差分是对时间序列进行一阶或多阶的差分操作,可以消除序列的非平稳性。d参数表示差分的阶数,默认为1阶差分。  [, i4 x! a/ \6 J1 [; R% Q) v) Q( n
3.滑动平均(MA):滑动平均部分使用先前的误差值来预测当前值。q参数表示滑动平均的阶数,即使用多少个先前的误差值作为预测输入。
  K  N) I$ s' K, H) N1 @9 l& h1 d) |, f, z6 {
ARIMA模型的一般表示形式为ARIMA(p, d, q),其中p、d和q是非负整数。它可以很好地处理具有线性趋势和季节性的时间序列数据。
, H. j$ H( G8 V2 y' F* h( x# qARIMA模型的建立包括以下步骤:, w5 X+ d* _! {+ g) E7 ~
, y# B! H2 C$ o+ m% g& Y/ Z
4.确定时间序列数据的平稳性,如平稳性检验、观察序列的趋势和季节性等。
$ B( w$ z  y# i3 N1 E  [' k' d3 ~- c5.如果时间序列不平稳,进行差分操作以实现平稳性。
/ h" e' R8 W0 |1 K7 V6.通过观察ACF和PACF图来确定p和q的合适取值范围。; w# ?% `# s* h# H. X
7.根据AIC等准则,以不同的p、d、q值建立多个ARIMA模型。
/ V1 u" _) T. E5 F  U: ~' h8.对每个模型进行参数估计和模型拟合。
& c% C2 X5 H, z. I! b! x2 y9.使用拟合的模型进行预测,并对模型的拟合效果进行评估。
+ h. L1 u7 h6 Q& W5 T
5 @* D/ v1 _& CARIMA模型是时间序列分析领域中常用的模型之一,它可以用于预测未来趋势、季节性和周期性等时间序列数据的变化。在实际应用中,ARIMA模型可以被用于经济预测、股票市场分析、天气预测等各种领域。- I/ J5 Q/ s' p- H" H
9 F  H' C" I# |$ Q6 G( |
# 导入所需的库! A% b( L# r7 t" P
import numpy as np
& M1 p, E7 v! Z! G  {import pandas as pd
0 Y# T; g* S3 K  R6 S- Timport statsmodels.api as sm
/ T+ v! O+ E# Efrom statsmodels.graphics.tsaplots import plot_acf, plot_pacf
4 e/ Q6 t0 E) n, T! ]+ X. rimport matplotlib.pyplot as plt
9 V, Y# h" z, Q
8 j+ Q' `0 H5 w$ D8 P1 U: l这些是导入需要使用的库,包括NumPy、Pandas、statsmodels和matplotlib。5 o* x9 h5 j7 o/ f
# 源数据3 a5 H9 u. o, ^. K
df = pd.DataFrame({
$ X* U, V% {( E, \5 p; _& k    'year': [i for i in range(1971, 1991)],
/ V# ?+ [! I9 ^9 a    'num': [66.6, 68.9, 38, 34.5, 15.5,
9 x0 h5 L: a$ I3 b5 b) X5 y            12.6, 27.5, 92.5, 155.4, 154.6,: `1 g+ F( d& w1 P8 p. G7 n
            140.4, 115.9, 66.6, 45.9, 17.9,+ Y# I% a4 r. x  e) B2 m* ?
            3.4, 29.4, 100.2, 157.6, 142.6],7 V/ b2 {- p7 b7 U  w: g
})( `$ E0 C/ C7 J0 z; r( [) E8 f
6 O# P- T9 }; f* u/ T1 Z
这里创建了一个DataFrame df,包含年份和对应的数据值。这个数据将用于建立ARIMA模型。2 y7 Z" g# x+ @: Z, d. k5 x7 \
# 画 acf 图
6 |% W/ Q7 @& l% u: W% d4 Fplot_acf(df['num'])
+ M3 l% w: _' k* l4 q) k4 h5 }$ r, r( Y
这段代码用于画出序列的自相关函数(ACF)图。ACF图可以帮助我们分析时间序列数据的自相关性。/ Q+ S/ p% c" V, M0 s" e" P& j1 e* o
# 画 pacf 图, Z7 P) @6 A# ^- O" J3 h
plot_pacf(df['num'], lags=9)% @1 z9 U3 i- c: w, D* f" `! E  l7 s4 k
$ p8 ?$ ?* K9 ]4 U8 p# q
这段代码用于画出序列的偏自相关函数(PACF)图。PACF图可以帮助我们分析时间序列数据的偏自相关性。- O% S, v* t$ m8 Y' u; r. o0 f
# 建立模型,参考 acf、pacf 代入 p、q,观察 aic
4 M  y5 M# ?) C( y7 ^1 w5 `4 x* Vstr_list = []
, W& v* ], I; o5 I8 v; Zfor p in range(1, 6):
& Y/ V' R% o  w0 Y& U    for q in range(1, 3):
7 S& u) A) N' m; `" T6 M8 d9 u        model = sm.tsa.ARMA(df['num'], (p, q)).fit()
4 l, U0 P+ @* o- x* ^        str_list.append('p = {}, q = {}, aic = {}'.format(p, q, model.aic))
# s1 P* s+ u4 ?4 E9 J! Q" m' Q; xfor each in str_list:
! A6 V( I$ Q, |7 e. `3 X9 X) h    print(each): m, V$ J' e  ?. T

- J0 g, v! K4 i% o- D这段代码用于建立ARIMA模型并观察模型的AIC(赤池信息准则)值。通过对不同(p, q)值的组合进行模型拟合,并输出对应的AIC值,以便选择最优的(p, q)值。
  S/ `* p% T; _1 m/ G# 发现 p=2,q=2 时 aic 最小,取 p=2,q=2% y9 p! O! l( g1 ]
model = sm.tsa.ARMA(df['num'], (2, 2)).fit()
: v- E% J* y3 c, [8 }model.summary()* Z2 h5 V! C' p: |+ y  O& T2 e
" J$ J3 A$ O6 c7 U
根据观察AIC值的结果,选择最优(p, q)值为(2, 2),然后建立ARIMA模型并进行拟合。
) M* j. e- t8 g6 C3 Z* h# 预测和画图5 L4 x/ ~! u' G( E8 Z  n
plt.plot(df['year'], df['num'])  @2 P+ O; u5 S) O7 o# Q- w% N
plt.scatter(df['year'], df['num'], label='actual')
: L. T9 Z: r3 u; K  D6 N, ayear_list = [i for i in range(1971, 2001)]
. \; J5 f( V5 c; Y) h0 H0 y" O4 Tplt.plot(year_list, model.predict(0, len(year_list)-1))( W1 ~4 |; g7 N) c4 @' x9 L' a* L
plt.scatter(year_list, model.predict(0, len(year_list)-1), label='predict')
& x- ^4 S0 Q& B( Cplt.legend()
$ ~; U1 E2 I/ z- Z* G0 N# r
) @# o: W4 W$ A& D5 A8 S这段代码用于使用拟合的模型进行预测,并绘制实际值和预测值的图表。首先画出实际值的曲线,然后画出预测值的曲线,并将预测值的点标记在图上。/ p& t8 L' W* _- t& ]
希望以上解释对你有帮助。如果你还有任何问题,请随时提问。
0 u" N0 p( k) f; K
1 O* \0 h2 x+ Y- C" f
) G5 |$ |: ~0 n. ~; C

24.arma.py

1.31 KB, 下载次数: 0, 下载积分: 体力 -2 点

售价: 2 点体力  [记录]  [购买]

zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2026-4-17 04:36 , Processed in 0.431365 second(s), 55 queries .

回顶部