QQ登录

只需要一步,快速开始

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

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

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

1186

主题

4

听众

2922

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 10:19 |只看该作者 |正序浏览
|招呼Ta 关注Ta
ARIMA(Autoregressive Integrated Moving Average)模型是一种常用的时间序列分析方法,用于对时间序列数据建模和预测。它通过结合自回归(AR)和滑动平均(MA)模型的特性,并对序列进行差分(Integration,即I)来建立模型。- z* P0 x+ F7 P5 _( z3 `
ARIMA模型的三个主要参数是p、d和q,分别对应于自回归、差分和滑动平均的阶数。( ~( q5 s) C5 j

6 O+ S0 ^( [! n. ^% R, W, B1.自回归(AR):自回归部分使用先前时间点的观测值来预测当前值。p参数表示自回归的阶数,即使用多少个先前时间点的值作为预测输入。$ A+ H  |& a$ N# ?! x/ V7 w
2.差分(I):差分是对时间序列进行一阶或多阶的差分操作,可以消除序列的非平稳性。d参数表示差分的阶数,默认为1阶差分。, z3 }+ U$ |, F
3.滑动平均(MA):滑动平均部分使用先前的误差值来预测当前值。q参数表示滑动平均的阶数,即使用多少个先前的误差值作为预测输入。
) K5 b4 a. l: m2 ?% f
6 A, _1 p& {; ?* E7 S7 ?$ VARIMA模型的一般表示形式为ARIMA(p, d, q),其中p、d和q是非负整数。它可以很好地处理具有线性趋势和季节性的时间序列数据。
7 D5 a5 o% e" a2 iARIMA模型的建立包括以下步骤:: N) n' B. D% j, U9 F/ z+ Z" n
! D% j( c# l' p- a: _$ ]5 l2 A9 Q1 j
4.确定时间序列数据的平稳性,如平稳性检验、观察序列的趋势和季节性等。4 f8 ~7 M  s5 h0 e# ^/ S: ~
5.如果时间序列不平稳,进行差分操作以实现平稳性。
  g4 b2 l0 _/ w! L* T6.通过观察ACF和PACF图来确定p和q的合适取值范围。
# G( }; m3 c* z7.根据AIC等准则,以不同的p、d、q值建立多个ARIMA模型。
7 ~+ c* o# ]: f) _6 M8.对每个模型进行参数估计和模型拟合。
4 z1 C! m0 w( p7 r' d; }9.使用拟合的模型进行预测,并对模型的拟合效果进行评估。
: A5 j" C% T( S' j, J
4 y+ W2 x/ L, ~  C9 `* l0 W8 FARIMA模型是时间序列分析领域中常用的模型之一,它可以用于预测未来趋势、季节性和周期性等时间序列数据的变化。在实际应用中,ARIMA模型可以被用于经济预测、股票市场分析、天气预测等各种领域。) V- z# ~* W- c8 `

7 S! ?- J) G/ N0 [3 a' s# 导入所需的库) E8 _9 U. P+ J5 f. Y1 o0 L
import numpy as np; i1 v7 i% i  ^& U& y: g
import pandas as pd
. h9 m2 ^, b* Q6 M5 ^1 H& ]import statsmodels.api as sm
" I! Y8 |4 S" T3 V" `. Bfrom statsmodels.graphics.tsaplots import plot_acf, plot_pacf
1 ]3 q: w. X7 F8 u! O  K/ Mimport matplotlib.pyplot as plt
0 _9 f9 t; f$ m! `' l# P3 s' f5 u# m2 F% a4 L6 r, [
这些是导入需要使用的库,包括NumPy、Pandas、statsmodels和matplotlib。/ g! k3 I$ ^( W* X: K3 D- ?
# 源数据" M4 W9 M/ n0 i' N7 p8 f# h- ?
df = pd.DataFrame({
2 [* H& ~1 J% f# m    'year': [i for i in range(1971, 1991)],
  K  Q' p; ]- a4 E% Q* }    'num': [66.6, 68.9, 38, 34.5, 15.5,) @# v9 `$ i6 s, s
            12.6, 27.5, 92.5, 155.4, 154.6,' I  S, O/ B- f( I+ Z! G
            140.4, 115.9, 66.6, 45.9, 17.9,4 Q, ?  B# K; e% n+ R0 u: B+ A
            3.4, 29.4, 100.2, 157.6, 142.6],2 ~) T0 o1 T2 i1 Q: ]
}): g2 j4 J; b' g9 k; e  J6 Y  z
( M5 @+ t& `7 m) r" X+ O& _
这里创建了一个DataFrame df,包含年份和对应的数据值。这个数据将用于建立ARIMA模型。
' D, f0 V5 V7 E% m# 画 acf 图
) p9 V7 ^2 o( w( I/ {plot_acf(df['num'])% O" [  F( A; W- O
+ x0 Q1 `& f: D( p. s' n
这段代码用于画出序列的自相关函数(ACF)图。ACF图可以帮助我们分析时间序列数据的自相关性。& b, u9 z) K* d. G) i# _. D* T2 z
# 画 pacf 图
5 W& m; f6 @# m0 H1 `plot_pacf(df['num'], lags=9)
/ z$ N; Q8 }' ?! H. G$ |; L
1 V: E* F/ z8 m1 y; S这段代码用于画出序列的偏自相关函数(PACF)图。PACF图可以帮助我们分析时间序列数据的偏自相关性。- S9 {4 r! {& E1 U1 z( w+ u
# 建立模型,参考 acf、pacf 代入 p、q,观察 aic
/ a& q9 E1 g- ~$ F: y! s2 s$ K  istr_list = []
) k" e/ e* B% S) n# nfor p in range(1, 6):
5 g0 o! G9 r1 T- c    for q in range(1, 3):
2 q( y2 z6 f' G( i        model = sm.tsa.ARMA(df['num'], (p, q)).fit()
& U7 J0 n( p3 {) k' e# z2 w        str_list.append('p = {}, q = {}, aic = {}'.format(p, q, model.aic))
; w' R' ~. V/ Ofor each in str_list:
( P% i/ E6 r- \8 x: M" ~& z    print(each)  }2 H( e; b1 h/ P/ X

4 d6 I- d6 A" n" R& F- h7 d, p这段代码用于建立ARIMA模型并观察模型的AIC(赤池信息准则)值。通过对不同(p, q)值的组合进行模型拟合,并输出对应的AIC值,以便选择最优的(p, q)值。( o$ w9 W8 a% y% W1 D/ F
# 发现 p=2,q=2 时 aic 最小,取 p=2,q=2% ?; f. f6 {, u( z
model = sm.tsa.ARMA(df['num'], (2, 2)).fit()( L1 d% w* R4 C2 {7 d( w- T* P
model.summary()
7 o3 D2 ^) ]' j  @5 N* Y" L" P  i! D
根据观察AIC值的结果,选择最优(p, q)值为(2, 2),然后建立ARIMA模型并进行拟合。) Z3 P. Y$ ^3 ^% q' y* Z: P, \
# 预测和画图5 g( |& i6 a# v0 y
plt.plot(df['year'], df['num'])5 d. f5 ^3 f5 t( u9 X" S
plt.scatter(df['year'], df['num'], label='actual')
, [4 e' E4 l$ u) g" vyear_list = [i for i in range(1971, 2001)]
; E: T- |* Z8 Oplt.plot(year_list, model.predict(0, len(year_list)-1))8 `! K6 n5 z$ w7 }9 @& t
plt.scatter(year_list, model.predict(0, len(year_list)-1), label='predict')4 D( t1 y0 O/ X( M9 B2 M( V  W7 x0 c
plt.legend()
& E' K" R  Y: x+ f
3 p' h% h* }5 s) @: i1 z$ V这段代码用于使用拟合的模型进行预测,并绘制实际值和预测值的图表。首先画出实际值的曲线,然后画出预测值的曲线,并将预测值的点标记在图上。3 \6 G' M) I) h% f2 D, \! _
希望以上解释对你有帮助。如果你还有任何问题,请随时提问。. o7 ?" [1 C7 U+ C! C) S: o
3 w) ^/ z; D( b- \6 z# l0 M

0 K. I; _9 o8 w$ b

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 08:25 , Processed in 0.409204 second(s), 55 queries .

回顶部