QQ登录

只需要一步,快速开始

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

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

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

1186

主题

4

听众

2922

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 10:19 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
ARIMA(Autoregressive Integrated Moving Average)模型是一种常用的时间序列分析方法,用于对时间序列数据建模和预测。它通过结合自回归(AR)和滑动平均(MA)模型的特性,并对序列进行差分(Integration,即I)来建立模型。4 W1 S0 F9 ]3 r$ Z7 b
ARIMA模型的三个主要参数是p、d和q,分别对应于自回归、差分和滑动平均的阶数。) j( a, }) n8 q' g, g
$ O  @+ I+ _, X; P: c
1.自回归(AR):自回归部分使用先前时间点的观测值来预测当前值。p参数表示自回归的阶数,即使用多少个先前时间点的值作为预测输入。# Y3 k$ n6 U# z
2.差分(I):差分是对时间序列进行一阶或多阶的差分操作,可以消除序列的非平稳性。d参数表示差分的阶数,默认为1阶差分。/ H4 P* R( p* `# C9 c% m; t  ^' B
3.滑动平均(MA):滑动平均部分使用先前的误差值来预测当前值。q参数表示滑动平均的阶数,即使用多少个先前的误差值作为预测输入。! p% O9 y  A# h* S- l) ]
& k- y9 m4 [1 R0 C$ H9 w! |# ~
ARIMA模型的一般表示形式为ARIMA(p, d, q),其中p、d和q是非负整数。它可以很好地处理具有线性趋势和季节性的时间序列数据。
) T" X! }( |! m3 I+ S2 hARIMA模型的建立包括以下步骤:% m) d8 Z% c* B; ~: |# v( C
1 ^; G( I7 E! z! G% I
4.确定时间序列数据的平稳性,如平稳性检验、观察序列的趋势和季节性等。
% v/ h, D  _1 {; {& Q5.如果时间序列不平稳,进行差分操作以实现平稳性。7 B) n: _) H- B0 k" w7 _8 [1 p8 m
6.通过观察ACF和PACF图来确定p和q的合适取值范围。5 W5 |6 d  q4 W( I
7.根据AIC等准则,以不同的p、d、q值建立多个ARIMA模型。4 S! c- Q+ N. Z% Y3 P7 f
8.对每个模型进行参数估计和模型拟合。
2 V4 N4 P* V! ^9.使用拟合的模型进行预测,并对模型的拟合效果进行评估。
6 l4 r+ v, d( o( a* P/ n! R
$ K  B, P3 s- C% RARIMA模型是时间序列分析领域中常用的模型之一,它可以用于预测未来趋势、季节性和周期性等时间序列数据的变化。在实际应用中,ARIMA模型可以被用于经济预测、股票市场分析、天气预测等各种领域。
4 q' H" H+ t- G: m+ }8 y) e6 f" ^" x1 h) t+ {) A
# 导入所需的库
+ Z* w! ]! |4 t! J3 L7 {+ |import numpy as np3 d/ E8 u' ^+ U0 I: |  z* ]
import pandas as pd' r8 d( Y$ m7 w9 h) j) t" M
import statsmodels.api as sm
6 d" p+ S1 [! Y- h4 H, dfrom statsmodels.graphics.tsaplots import plot_acf, plot_pacf
' J3 J1 B- O; M4 v# D" ]) yimport matplotlib.pyplot as plt% I6 T( U; J* V; o. z; K

5 K- q; e. a' r+ V2 J0 C这些是导入需要使用的库,包括NumPy、Pandas、statsmodels和matplotlib。
1 B( _; |- z5 m4 n+ s0 Z# 源数据
& b- L" |! U1 ]" _df = pd.DataFrame({
3 M! u( C7 k6 _2 D, m    'year': [i for i in range(1971, 1991)],
6 u$ N5 ~7 ^3 ^! S! G9 z  e! l) g    'num': [66.6, 68.9, 38, 34.5, 15.5,
$ W" I8 u) h7 A2 D) e- @            12.6, 27.5, 92.5, 155.4, 154.6,
# ^0 U7 M6 c; ^. t& w7 x) A# a            140.4, 115.9, 66.6, 45.9, 17.9,0 G" }& \1 B' K
            3.4, 29.4, 100.2, 157.6, 142.6],
. u. C2 e6 y7 m0 V})
5 o& {$ ^. Y, S! W5 P+ N* s. ~; I: R4 w  \' s
这里创建了一个DataFrame df,包含年份和对应的数据值。这个数据将用于建立ARIMA模型。
$ }: q0 F' x/ a# 画 acf 图3 V  _6 ^# K- @2 X3 E" ~6 Z1 Y
plot_acf(df['num'])
8 J& Y9 m# a7 R( m+ X: Y7 u2 c7 @% _1 g1 q3 Q' P
这段代码用于画出序列的自相关函数(ACF)图。ACF图可以帮助我们分析时间序列数据的自相关性。6 r) O+ e: H! z% F" `$ @$ g
# 画 pacf 图
, x& O6 J' F+ }! l4 v, s7 P, I6 iplot_pacf(df['num'], lags=9)  B: K& }1 g9 [8 B3 z

4 x, Q! j$ T5 @这段代码用于画出序列的偏自相关函数(PACF)图。PACF图可以帮助我们分析时间序列数据的偏自相关性。
: Q( r# z% l8 ~- h# 建立模型,参考 acf、pacf 代入 p、q,观察 aic; s$ Y! ^4 O/ q! X" T# D
str_list = []
) A8 y( V1 G5 s% C% O/ |7 hfor p in range(1, 6):
& x0 c0 W2 x/ b2 P' ]+ o. x6 t  n    for q in range(1, 3):
/ w1 I, m; T! ?- f' ^" x        model = sm.tsa.ARMA(df['num'], (p, q)).fit()2 _+ |/ U2 y# f7 Y; c/ u- {
        str_list.append('p = {}, q = {}, aic = {}'.format(p, q, model.aic)): v0 a; h* j' S+ m) w+ z  X
for each in str_list:
! w; v' Z# Z% z8 v- K    print(each)
' a5 M6 A/ b" \6 H, Z4 y* D2 ?, {+ S" G5 M7 A  J
这段代码用于建立ARIMA模型并观察模型的AIC(赤池信息准则)值。通过对不同(p, q)值的组合进行模型拟合,并输出对应的AIC值,以便选择最优的(p, q)值。" h# D7 O: d! o3 f
# 发现 p=2,q=2 时 aic 最小,取 p=2,q=2
& t6 f: y6 c# Y4 e4 H9 smodel = sm.tsa.ARMA(df['num'], (2, 2)).fit()1 T5 D  N* d8 O' d: h
model.summary()) Q" k' U5 R$ |6 E- }" ]

# }' v7 A" Y5 _. F6 H根据观察AIC值的结果,选择最优(p, q)值为(2, 2),然后建立ARIMA模型并进行拟合。. s( _! p& a2 G) x
# 预测和画图
- Y1 [  V9 R7 p* ~5 P/ O# ~2 qplt.plot(df['year'], df['num'])
1 L$ D! l' z. W$ v+ G/ y7 P/ r( Oplt.scatter(df['year'], df['num'], label='actual')
5 P6 s/ W$ z$ P0 R4 L( Byear_list = [i for i in range(1971, 2001)]
$ q% S' i0 Z# }* Q1 P5 m( T$ o. e2 lplt.plot(year_list, model.predict(0, len(year_list)-1))3 n4 r. d- Q) V
plt.scatter(year_list, model.predict(0, len(year_list)-1), label='predict')
# `, G8 R6 O3 m- `, ~- b8 |9 J" jplt.legend()
9 D, J; Y* c6 C3 Z6 x
; G* e! f9 P1 G: a# i0 T( C这段代码用于使用拟合的模型进行预测,并绘制实际值和预测值的图表。首先画出实际值的曲线,然后画出预测值的曲线,并将预测值的点标记在图上。
% F( J7 n' \3 H3 ]9 S; M8 K: s8 I& v希望以上解释对你有帮助。如果你还有任何问题,请随时提问。
9 }# X, U: t4 w9 h+ x2 M5 w) P/ C7 _, n5 S
4 L" @  `  R# t, A# n$ r* q1 I

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-12 10:09 , Processed in 0.399860 second(s), 55 queries .

回顶部