QQ登录

只需要一步,快速开始

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

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

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

1188

主题

4

听众

2931

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 10:19 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
ARIMA(Autoregressive Integrated Moving Average)模型是一种常用的时间序列分析方法,用于对时间序列数据建模和预测。它通过结合自回归(AR)和滑动平均(MA)模型的特性,并对序列进行差分(Integration,即I)来建立模型。
" v2 q4 s# `- }. |' \ARIMA模型的三个主要参数是p、d和q,分别对应于自回归、差分和滑动平均的阶数。: h) E% `8 F" c" K: f$ P8 ~( z
) j, G5 |6 o5 r! ?" e& _' v
1.自回归(AR):自回归部分使用先前时间点的观测值来预测当前值。p参数表示自回归的阶数,即使用多少个先前时间点的值作为预测输入。
' ?( N% k* w5 v( q3 V: s2.差分(I):差分是对时间序列进行一阶或多阶的差分操作,可以消除序列的非平稳性。d参数表示差分的阶数,默认为1阶差分。2 ^+ K5 ^- n* T, d  ^
3.滑动平均(MA):滑动平均部分使用先前的误差值来预测当前值。q参数表示滑动平均的阶数,即使用多少个先前的误差值作为预测输入。
2 b  m* X, O) z, k3 E' D& T0 z% v% D/ @
ARIMA模型的一般表示形式为ARIMA(p, d, q),其中p、d和q是非负整数。它可以很好地处理具有线性趋势和季节性的时间序列数据。
3 i' g3 D6 \: iARIMA模型的建立包括以下步骤:: [& l- N! m0 G4 [: V* B" T/ O
1 z$ c. J- \1 L% D: C
4.确定时间序列数据的平稳性,如平稳性检验、观察序列的趋势和季节性等。. y9 ^* E& O- i. f) d
5.如果时间序列不平稳,进行差分操作以实现平稳性。
9 A& `# P4 w; v) b0 l6 H6.通过观察ACF和PACF图来确定p和q的合适取值范围。6 k; _$ l( }" L6 h2 D8 ?, T
7.根据AIC等准则,以不同的p、d、q值建立多个ARIMA模型。
5 l0 l' T' U2 u9 R7 l, }8.对每个模型进行参数估计和模型拟合。" k+ S8 R$ y3 H) {- R( B
9.使用拟合的模型进行预测,并对模型的拟合效果进行评估。
" {7 y5 n* ?$ G9 ~  g% _2 t. ~  [# x2 t# M4 S- ?; m
ARIMA模型是时间序列分析领域中常用的模型之一,它可以用于预测未来趋势、季节性和周期性等时间序列数据的变化。在实际应用中,ARIMA模型可以被用于经济预测、股票市场分析、天气预测等各种领域。
/ ^; m1 w% N/ W3 v/ K# O/ z# l4 [8 Y3 @
# 导入所需的库- e4 H+ v' M. j, B
import numpy as np
& ]- I$ p  Q9 ]9 g6 ]import pandas as pd; j- o% `' o- I; B) h
import statsmodels.api as sm
, f  w+ c. c, s1 U( Efrom statsmodels.graphics.tsaplots import plot_acf, plot_pacf
1 r% a" a. E* _7 \+ n6 cimport matplotlib.pyplot as plt% ~1 r' D6 b2 {( D

9 x1 _% c8 m9 e% ^7 Y5 [这些是导入需要使用的库,包括NumPy、Pandas、statsmodels和matplotlib。
: R0 i6 d& K( @" G# 源数据' R) s2 V4 m( o, N3 u( C
df = pd.DataFrame({
, q# d: v5 V6 s+ G, L2 A+ h7 T    'year': [i for i in range(1971, 1991)],' B9 c$ Z: _1 L( r" K
    'num': [66.6, 68.9, 38, 34.5, 15.5,
/ D. B- R! [% p  U6 K8 \            12.6, 27.5, 92.5, 155.4, 154.6,0 p" g9 {, V, f4 `( E! [- d6 k* m
            140.4, 115.9, 66.6, 45.9, 17.9,! V. L# ]# i* D+ p4 ]( z$ y' N
            3.4, 29.4, 100.2, 157.6, 142.6],* V- V" g5 W/ P9 z( {8 F
}), P; V4 g+ Q, H% V" \

* z% H, e3 L7 h# l, E- ~9 ]这里创建了一个DataFrame df,包含年份和对应的数据值。这个数据将用于建立ARIMA模型。5 ]5 f' I  z$ Z' D3 k( \& x
# 画 acf 图8 n( G1 |! v2 X3 Y: u! C
plot_acf(df['num'])/ b9 a) j% F) _  c* n8 g2 w/ j  ^
! I! k6 P6 O, e+ Z$ _. }7 b) w
这段代码用于画出序列的自相关函数(ACF)图。ACF图可以帮助我们分析时间序列数据的自相关性。8 a( s1 L$ F& w  T; R
# 画 pacf 图# z. ~# e, r5 \0 x0 ~
plot_pacf(df['num'], lags=9)% u/ V9 x3 _4 N# S5 X# |2 ?. y  d

4 Y4 z7 R1 L3 H) j$ f4 t这段代码用于画出序列的偏自相关函数(PACF)图。PACF图可以帮助我们分析时间序列数据的偏自相关性。
1 a8 ]" f3 \& @7 s1 |9 c# 建立模型,参考 acf、pacf 代入 p、q,观察 aic) p" C$ g9 i4 j; d* l, [: @% J
str_list = []7 l5 _% ~* O/ V7 h3 A6 a
for p in range(1, 6):. H- X) F2 f5 M& R* h
    for q in range(1, 3):) U; _9 r( F3 g: `' I
        model = sm.tsa.ARMA(df['num'], (p, q)).fit()
1 ~( _+ B% S8 e, N$ s9 k; p, e        str_list.append('p = {}, q = {}, aic = {}'.format(p, q, model.aic))! f- ~) a* B, \, q
for each in str_list:* U  p, |- B4 K. |
    print(each)
6 q* T% B. L  ?0 k" E/ S2 F8 ]6 B  D* d, f! E% ^
这段代码用于建立ARIMA模型并观察模型的AIC(赤池信息准则)值。通过对不同(p, q)值的组合进行模型拟合,并输出对应的AIC值,以便选择最优的(p, q)值。
6 k' H$ A" w. d8 c# 发现 p=2,q=2 时 aic 最小,取 p=2,q=26 e/ k, ]/ f* ^& ]
model = sm.tsa.ARMA(df['num'], (2, 2)).fit()
6 ~# ~% {0 @7 m4 Omodel.summary(); A( j7 F0 E! [7 K7 n9 c% _( y

& @. N8 ~- h* b% v根据观察AIC值的结果,选择最优(p, q)值为(2, 2),然后建立ARIMA模型并进行拟合。* u) Y  @5 j, H) B
# 预测和画图
. Y3 W. v( Y, t, V6 u% |, C* dplt.plot(df['year'], df['num'])+ a: \  f  D% b- g9 H
plt.scatter(df['year'], df['num'], label='actual'), q7 R0 d9 ]* ^+ ~: `
year_list = [i for i in range(1971, 2001)]
0 O  r) t/ O9 L2 Bplt.plot(year_list, model.predict(0, len(year_list)-1))) j* C. t' b; s
plt.scatter(year_list, model.predict(0, len(year_list)-1), label='predict'); _4 O/ x$ A, `7 s# k* Q
plt.legend()
# [0 k6 W( b) A& R$ h7 y1 E; {) w
* M  O3 W: v8 l0 [7 t5 @这段代码用于使用拟合的模型进行预测,并绘制实际值和预测值的图表。首先画出实际值的曲线,然后画出预测值的曲线,并将预测值的点标记在图上。
& @( I# u) }6 |( B& x希望以上解释对你有帮助。如果你还有任何问题,请随时提问。
7 o2 z( `; ^  Z8 h% h. z6 A- p2 U. P
7 i( i* [! E' w* o2 z$ P

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-5-26 05:14 , Processed in 0.481634 second(s), 55 queries .

回顶部