QQ登录

只需要一步,快速开始

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

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

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

1189

主题

4

听众

2934

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 10:19 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
ARIMA(Autoregressive Integrated Moving Average)模型是一种常用的时间序列分析方法,用于对时间序列数据建模和预测。它通过结合自回归(AR)和滑动平均(MA)模型的特性,并对序列进行差分(Integration,即I)来建立模型。
4 q, \" f7 C0 }ARIMA模型的三个主要参数是p、d和q,分别对应于自回归、差分和滑动平均的阶数。
: }! g2 v8 e; i- h% P. Y$ D: j8 B) ^6 J4 u8 O- s9 _6 E
1.自回归(AR):自回归部分使用先前时间点的观测值来预测当前值。p参数表示自回归的阶数,即使用多少个先前时间点的值作为预测输入。0 N6 [, o9 y: v2 G; R6 }0 u
2.差分(I):差分是对时间序列进行一阶或多阶的差分操作,可以消除序列的非平稳性。d参数表示差分的阶数,默认为1阶差分。6 c! _# B( Y% Z! C
3.滑动平均(MA):滑动平均部分使用先前的误差值来预测当前值。q参数表示滑动平均的阶数,即使用多少个先前的误差值作为预测输入。% `3 A: d# V2 d/ T' U
7 R8 O. o$ T1 z9 n8 }' v- F
ARIMA模型的一般表示形式为ARIMA(p, d, q),其中p、d和q是非负整数。它可以很好地处理具有线性趋势和季节性的时间序列数据。. l4 f8 N( t$ v) a+ N  h
ARIMA模型的建立包括以下步骤:
6 S1 s0 I& S2 P- S0 Q* g6 Y/ {/ W) Z' X  |
4.确定时间序列数据的平稳性,如平稳性检验、观察序列的趋势和季节性等。/ C+ `; z/ Q9 [
5.如果时间序列不平稳,进行差分操作以实现平稳性。
3 o/ q3 o$ ?2 I9 U6.通过观察ACF和PACF图来确定p和q的合适取值范围。6 f3 h2 ?; L8 h7 `3 @
7.根据AIC等准则,以不同的p、d、q值建立多个ARIMA模型。
$ H" |. V; Z1 y; t0 D8.对每个模型进行参数估计和模型拟合。
; N3 R  _& i, {1 u/ v9.使用拟合的模型进行预测,并对模型的拟合效果进行评估。# S+ `( r- K, S4 v3 [9 O- A0 T4 F
$ ^3 |6 i5 `7 v; T' m4 J
ARIMA模型是时间序列分析领域中常用的模型之一,它可以用于预测未来趋势、季节性和周期性等时间序列数据的变化。在实际应用中,ARIMA模型可以被用于经济预测、股票市场分析、天气预测等各种领域。2 k- r; J0 a; M/ Q; t. G

1 A* r$ F) h# B" a# 导入所需的库0 {9 i% d' C) ~+ N0 s
import numpy as np# c# ^5 w( ^" Z+ Z; J
import pandas as pd
( V+ j. W5 S. q( p  q2 t/ Yimport statsmodels.api as sm% K+ x& w, s! w# O
from statsmodels.graphics.tsaplots import plot_acf, plot_pacf% }, m. i" q$ U. E" V4 n
import matplotlib.pyplot as plt& ]6 k2 H' m" P% t

- b" m5 i3 S: b* Z  }5 P( ^+ T5 f7 q这些是导入需要使用的库,包括NumPy、Pandas、statsmodels和matplotlib。
* P: S; O" U  _# p# 源数据0 V. R3 Y1 g6 H  S
df = pd.DataFrame({
/ O0 X& G, p; D3 V    'year': [i for i in range(1971, 1991)],
5 h' K% t/ X. D1 n; s. L    'num': [66.6, 68.9, 38, 34.5, 15.5,+ U3 J+ h% K# c# o' a
            12.6, 27.5, 92.5, 155.4, 154.6,8 ]" V: z* o  h- [+ E) f, A
            140.4, 115.9, 66.6, 45.9, 17.9,! C* \6 m) Y; M* i* _$ X/ ?2 ~2 L
            3.4, 29.4, 100.2, 157.6, 142.6],6 k& w2 w4 `; [6 h7 p& ^! o; M1 R. d
})% d) N1 [6 W' m  F

/ v5 V- K- y0 X$ f1 Y8 X这里创建了一个DataFrame df,包含年份和对应的数据值。这个数据将用于建立ARIMA模型。2 z7 B; H* [8 N8 v: |3 h0 n* m6 N
# 画 acf 图
; u" p, a# t/ J8 O! Jplot_acf(df['num'])" W0 T8 G( K! e7 l' K% t. L3 ^( X

; r, @2 `6 x1 R这段代码用于画出序列的自相关函数(ACF)图。ACF图可以帮助我们分析时间序列数据的自相关性。6 u1 x3 m7 j' t1 z) g, x0 q5 p
# 画 pacf 图
+ I- {4 p8 G2 Qplot_pacf(df['num'], lags=9)
; m, S! [0 `& l( m7 x+ ?# t: k& M: e" P' W: x+ C0 j$ C
这段代码用于画出序列的偏自相关函数(PACF)图。PACF图可以帮助我们分析时间序列数据的偏自相关性。
! x$ m" w4 J$ ], Y# 建立模型,参考 acf、pacf 代入 p、q,观察 aic* C% D4 O) q) h. U1 Q" P+ Q
str_list = []% @* r' Z! U. @- G/ u, Z
for p in range(1, 6):2 F0 y+ W* v- {! D
    for q in range(1, 3):
8 V8 ?- ]9 |. F7 y        model = sm.tsa.ARMA(df['num'], (p, q)).fit()- b% S0 x3 k( {$ x* ?4 V
        str_list.append('p = {}, q = {}, aic = {}'.format(p, q, model.aic))
$ f9 d% g# N6 U0 P) \) Z. }for each in str_list:
; k: b  e- s/ j1 k7 k    print(each); Z- }5 o9 S1 n+ W

9 G5 f( X" f. @' g) R0 A! C# S这段代码用于建立ARIMA模型并观察模型的AIC(赤池信息准则)值。通过对不同(p, q)值的组合进行模型拟合,并输出对应的AIC值,以便选择最优的(p, q)值。. O5 H6 |' J, e1 E" d
# 发现 p=2,q=2 时 aic 最小,取 p=2,q=22 k2 H( p0 ~$ X2 N% {+ N; q
model = sm.tsa.ARMA(df['num'], (2, 2)).fit()4 d9 Q/ c7 a- I5 ^4 Q
model.summary()4 O$ z: Z5 O3 p) d

* l, Q- N$ {% O: Z根据观察AIC值的结果,选择最优(p, q)值为(2, 2),然后建立ARIMA模型并进行拟合。
; p7 D4 m- b& Q$ n( _/ g# 预测和画图& G; Z2 ~) P! J. i( P
plt.plot(df['year'], df['num'])% E' P8 C8 E( T; p$ \' l2 Y2 D
plt.scatter(df['year'], df['num'], label='actual')2 G9 C7 J- V* Y3 I
year_list = [i for i in range(1971, 2001)]4 h) I* N9 G+ @8 x1 i' o4 z
plt.plot(year_list, model.predict(0, len(year_list)-1))
: }4 Z) C- W8 ?plt.scatter(year_list, model.predict(0, len(year_list)-1), label='predict')' ^% o. p- j5 Y
plt.legend()5 {5 J) H, S/ o* O7 p
7 U* s! {. I- @) o$ k5 s: J% q. a
这段代码用于使用拟合的模型进行预测,并绘制实际值和预测值的图表。首先画出实际值的曲线,然后画出预测值的曲线,并将预测值的点标记在图上。# O2 p2 X* m6 [3 d* e% |) z( X
希望以上解释对你有帮助。如果你还有任何问题,请随时提问。
; i; I" E$ o0 _& j7 U
) ~6 u' j. ~7 q6 `; p! i; R& B1 b+ D. x; _4 [. g1 U  t8 E! A5 w- z* 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-6-14 16:55 , Processed in 0.498237 second(s), 55 queries .

回顶部