QQ登录

只需要一步,快速开始

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

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

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

1189

主题

4

听众

2934

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 10:19 |只看该作者 |正序浏览
|招呼Ta 关注Ta
ARIMA(Autoregressive Integrated Moving Average)模型是一种常用的时间序列分析方法,用于对时间序列数据建模和预测。它通过结合自回归(AR)和滑动平均(MA)模型的特性,并对序列进行差分(Integration,即I)来建立模型。  j+ m0 z3 g- n7 T7 W: ^1 V2 B
ARIMA模型的三个主要参数是p、d和q,分别对应于自回归、差分和滑动平均的阶数。! f* N" J: z  z7 A( h
" j8 ?9 J4 }+ T0 m) k+ ?
1.自回归(AR):自回归部分使用先前时间点的观测值来预测当前值。p参数表示自回归的阶数,即使用多少个先前时间点的值作为预测输入。
0 e+ O8 R6 H, H2.差分(I):差分是对时间序列进行一阶或多阶的差分操作,可以消除序列的非平稳性。d参数表示差分的阶数,默认为1阶差分。
; H2 {' y! Q9 P) @' d. W3.滑动平均(MA):滑动平均部分使用先前的误差值来预测当前值。q参数表示滑动平均的阶数,即使用多少个先前的误差值作为预测输入。3 i" O3 _7 a& T; L' Q, j
; s0 M- [7 n6 h) T
ARIMA模型的一般表示形式为ARIMA(p, d, q),其中p、d和q是非负整数。它可以很好地处理具有线性趋势和季节性的时间序列数据。* H, }* {8 w5 y7 e% {: V3 K0 p
ARIMA模型的建立包括以下步骤:
1 }9 u5 ]$ \& C! G: r$ D9 u
) E" q: }+ Y: u  v, u: \4.确定时间序列数据的平稳性,如平稳性检验、观察序列的趋势和季节性等。$ S' _5 K0 I4 c! H6 {0 p
5.如果时间序列不平稳,进行差分操作以实现平稳性。
3 t  Z6 ]! h# T% Y7 d6 N6.通过观察ACF和PACF图来确定p和q的合适取值范围。! E% j/ g& P# e  [5 v/ ?- k9 ~
7.根据AIC等准则,以不同的p、d、q值建立多个ARIMA模型。9 @; s, r* R6 V, l+ }
8.对每个模型进行参数估计和模型拟合。; L& W. T* ]& {+ o
9.使用拟合的模型进行预测,并对模型的拟合效果进行评估。
" ~0 U1 b0 k- G/ @/ T$ g( u
$ e' {7 Y2 Z. q- K, OARIMA模型是时间序列分析领域中常用的模型之一,它可以用于预测未来趋势、季节性和周期性等时间序列数据的变化。在实际应用中,ARIMA模型可以被用于经济预测、股票市场分析、天气预测等各种领域。# I% V. @) e# Q& g

9 l# r% K' ?! g& Y2 j2 K: O# 导入所需的库
6 a3 q2 S0 M/ X% O- a$ T7 mimport numpy as np" ]* o( f0 @; {9 A* Q
import pandas as pd# j! Q! e7 f- \' j2 \4 _/ T
import statsmodels.api as sm
& P3 k. ]8 {1 r2 z& rfrom statsmodels.graphics.tsaplots import plot_acf, plot_pacf! m4 A- _; I. R& T( d, ]+ o
import matplotlib.pyplot as plt  T$ b7 r' S, I

4 l$ W) i+ q4 N2 H9 Q5 @* m这些是导入需要使用的库,包括NumPy、Pandas、statsmodels和matplotlib。3 @- {' D. y6 t6 l
# 源数据
4 @  e9 j+ h; `6 jdf = pd.DataFrame({2 V" E4 J7 ~, X
    'year': [i for i in range(1971, 1991)],  n2 b. j# \& k) ^9 n
    'num': [66.6, 68.9, 38, 34.5, 15.5,! F  {% Y* m  U" c
            12.6, 27.5, 92.5, 155.4, 154.6,
3 N' v- I& j( Z& V! u            140.4, 115.9, 66.6, 45.9, 17.9,- z6 p1 m; Q+ }% D
            3.4, 29.4, 100.2, 157.6, 142.6],9 G# l: z: l3 p' {# L6 G
})1 b' J5 v9 h1 V$ T3 Q

& U( Z% Z' g% ]# P- I* _这里创建了一个DataFrame df,包含年份和对应的数据值。这个数据将用于建立ARIMA模型。
7 j- F9 g, O0 m- R4 j  _2 u8 `# 画 acf 图9 f+ G. ]" [. h- o$ j
plot_acf(df['num'])( @) ~- ~! M! `- \5 A
' J6 n$ a3 q4 d; J3 c: K  i  j# Y- E5 N
这段代码用于画出序列的自相关函数(ACF)图。ACF图可以帮助我们分析时间序列数据的自相关性。- S9 O* y' b- R* D  R+ m' x
# 画 pacf 图; X  P. P% L2 j* n% }
plot_pacf(df['num'], lags=9)1 W% m7 p  |; S0 Z
3 ?. e; T: m  u2 n
这段代码用于画出序列的偏自相关函数(PACF)图。PACF图可以帮助我们分析时间序列数据的偏自相关性。
& D& H+ X/ p* ?" [# 建立模型,参考 acf、pacf 代入 p、q,观察 aic2 l+ e+ p& G( m8 }
str_list = []
  p3 y7 O, N# m) s; h, Qfor p in range(1, 6):5 D" N. p- f5 L  K# A
    for q in range(1, 3):
# K$ K' D1 P% T: S- p4 v% \6 ~( q        model = sm.tsa.ARMA(df['num'], (p, q)).fit()
% ?& F2 G" j; |0 H  z8 u        str_list.append('p = {}, q = {}, aic = {}'.format(p, q, model.aic))2 ?3 H7 f& B) L0 p2 d. j3 E% m
for each in str_list:! A( U6 R+ _+ p4 ], E. @
    print(each)2 y  }* y2 c7 D9 S+ ^

8 t) @3 M# Q# I% k这段代码用于建立ARIMA模型并观察模型的AIC(赤池信息准则)值。通过对不同(p, q)值的组合进行模型拟合,并输出对应的AIC值,以便选择最优的(p, q)值。
7 d5 N; _& u5 e& a' h# 发现 p=2,q=2 时 aic 最小,取 p=2,q=28 |" P4 V5 I( F. q. x5 p
model = sm.tsa.ARMA(df['num'], (2, 2)).fit()% a. D5 |! ~* C! E* f. S
model.summary()6 u. J3 ~: g. D  W# h4 r& f* ^0 y( o0 i, ~

  l! C) V5 C9 P  w0 ~- S- j根据观察AIC值的结果,选择最优(p, q)值为(2, 2),然后建立ARIMA模型并进行拟合。# |  S0 }& M. T4 V+ o: p; A% x
# 预测和画图
1 k, h5 K& y# d; A: f. P/ X  n! p2 yplt.plot(df['year'], df['num'])
( n; ~7 f9 M% c6 g) e; bplt.scatter(df['year'], df['num'], label='actual')
! |& N$ v7 q" F9 P, c8 X4 Pyear_list = [i for i in range(1971, 2001)]
  E! I! T1 `' W2 J/ ^6 B# Lplt.plot(year_list, model.predict(0, len(year_list)-1))) S( d% v7 \7 ~& M2 ?& k
plt.scatter(year_list, model.predict(0, len(year_list)-1), label='predict')
8 D; h' ]  V& R% B) {2 Mplt.legend()7 b$ w" Y  x* S( U9 y* L1 r

( u  @8 z- n8 s( d1 W4 W7 t这段代码用于使用拟合的模型进行预测,并绘制实际值和预测值的图表。首先画出实际值的曲线,然后画出预测值的曲线,并将预测值的点标记在图上。, [: i; O" U8 u) i* |) n$ a
希望以上解释对你有帮助。如果你还有任何问题,请随时提问。6 r* [! h- g) `5 g1 [$ Z0 ?7 X& v4 r
9 v& {6 U+ k, g; |% p
+ u6 H3 C, U; T. 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-6-15 00:51 , Processed in 0.403925 second(s), 56 queries .

回顶部