QQ登录

只需要一步,快速开始

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

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

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

1186

主题

4

听众

2922

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 10:19 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
ARIMA(Autoregressive Integrated Moving Average)模型是一种常用的时间序列分析方法,用于对时间序列数据建模和预测。它通过结合自回归(AR)和滑动平均(MA)模型的特性,并对序列进行差分(Integration,即I)来建立模型。" W; N" t' p6 A# m
ARIMA模型的三个主要参数是p、d和q,分别对应于自回归、差分和滑动平均的阶数。6 I7 T6 v  l. n- J

- N; u- B7 j! L! R& |5 S1.自回归(AR):自回归部分使用先前时间点的观测值来预测当前值。p参数表示自回归的阶数,即使用多少个先前时间点的值作为预测输入。
; P. F& Q& {; A2.差分(I):差分是对时间序列进行一阶或多阶的差分操作,可以消除序列的非平稳性。d参数表示差分的阶数,默认为1阶差分。
2 b, M" X# n+ L1 ]* Z; l6 Q3.滑动平均(MA):滑动平均部分使用先前的误差值来预测当前值。q参数表示滑动平均的阶数,即使用多少个先前的误差值作为预测输入。. U) A% m5 R& o4 w( L
9 t0 _: ~& Z. u3 |/ J' R. ^: n; l
ARIMA模型的一般表示形式为ARIMA(p, d, q),其中p、d和q是非负整数。它可以很好地处理具有线性趋势和季节性的时间序列数据。( O3 k" G4 t- W
ARIMA模型的建立包括以下步骤:! g) |# r3 y, T/ S

  I5 r! _" F; v' X1 T* T4.确定时间序列数据的平稳性,如平稳性检验、观察序列的趋势和季节性等。5 r- z! _. `  ^5 M. a
5.如果时间序列不平稳,进行差分操作以实现平稳性。1 O( a3 P' ~! H+ L
6.通过观察ACF和PACF图来确定p和q的合适取值范围。
% Q( w& e& m2 ?4 s1 p  E4 j7.根据AIC等准则,以不同的p、d、q值建立多个ARIMA模型。
6 r/ {, d4 e* J; p8.对每个模型进行参数估计和模型拟合。! _* {! G% U: x* _. O0 \; s7 d
9.使用拟合的模型进行预测,并对模型的拟合效果进行评估。
! y2 G: r* ~% h3 R! s9 N+ S- N+ D0 e) I0 N& X
ARIMA模型是时间序列分析领域中常用的模型之一,它可以用于预测未来趋势、季节性和周期性等时间序列数据的变化。在实际应用中,ARIMA模型可以被用于经济预测、股票市场分析、天气预测等各种领域。
! P, p& P/ B3 \) B# }& F) k
; p) m! d2 I1 O/ b1 l4 X# 导入所需的库
: x% X  U9 b6 y. a0 s2 q4 y1 ^( U0 D/ Yimport numpy as np
7 {' A) g, A8 _( U) X, U, o2 ?, m. v0 simport pandas as pd
7 [( f. `& S$ Aimport statsmodels.api as sm2 e, h+ [& }* R
from statsmodels.graphics.tsaplots import plot_acf, plot_pacf5 U$ S3 f9 D' f
import matplotlib.pyplot as plt7 I0 W! }& e. r9 P) |  e; |
0 L; o6 {4 U' f; I
这些是导入需要使用的库,包括NumPy、Pandas、statsmodels和matplotlib。
' G  o5 R3 r0 h+ z" Q6 Y# 源数据
4 n. r8 I6 n7 A- k5 v) |2 Kdf = pd.DataFrame({# O' ?# Y; S- @# D
    'year': [i for i in range(1971, 1991)],+ K7 \8 p% C. M  D$ q
    'num': [66.6, 68.9, 38, 34.5, 15.5,
6 Q) K, l- B- s# N1 m% A            12.6, 27.5, 92.5, 155.4, 154.6,! G9 V. Q* V8 c! \, m
            140.4, 115.9, 66.6, 45.9, 17.9,' t; Y6 S! @( J( F
            3.4, 29.4, 100.2, 157.6, 142.6],& T+ u3 n' i, n
})+ [  W+ S( O* [" E" x& e. ]
" o. G, h0 v  Z. j0 J$ R" Q
这里创建了一个DataFrame df,包含年份和对应的数据值。这个数据将用于建立ARIMA模型。
  u" j8 L9 g5 e+ j- O# 画 acf 图
" Y3 ~6 h, o! m( n$ B: O+ y6 wplot_acf(df['num'])
& [5 e4 H4 {/ B+ _5 ~, `
% K! k: i" T( A9 x5 Z2 d' N这段代码用于画出序列的自相关函数(ACF)图。ACF图可以帮助我们分析时间序列数据的自相关性。5 Z5 C- Q7 U& [' \2 W
# 画 pacf 图# `. ^5 B$ p6 ]! z: G) ^/ B' E
plot_pacf(df['num'], lags=9)
# ^* a" i* K% C5 z: y( {  i$ ]+ x" o  [9 Y( n, Y
这段代码用于画出序列的偏自相关函数(PACF)图。PACF图可以帮助我们分析时间序列数据的偏自相关性。7 A. i* f9 ~: h) E7 w
# 建立模型,参考 acf、pacf 代入 p、q,观察 aic$ g0 w8 A" A* }6 ?
str_list = []
* s( a  V3 }" p! }0 G  u/ Kfor p in range(1, 6):
! q! D2 D1 n: h6 b) F0 q! U  o" a    for q in range(1, 3):$ f7 g+ k! v1 S1 G7 j0 P) F
        model = sm.tsa.ARMA(df['num'], (p, q)).fit()0 B( N7 n. t6 z# K/ l
        str_list.append('p = {}, q = {}, aic = {}'.format(p, q, model.aic))# v( _& E% s! |1 V. ~
for each in str_list:7 ~% s+ B! V4 }( Q0 W2 }) Z% u6 q/ N
    print(each)5 |, H; |- ?7 Z: x7 _9 A, \
0 j' B) v' J) X) ~  I8 T. u- H  _
这段代码用于建立ARIMA模型并观察模型的AIC(赤池信息准则)值。通过对不同(p, q)值的组合进行模型拟合,并输出对应的AIC值,以便选择最优的(p, q)值。5 c  I' l/ P4 d7 K- E: c7 G
# 发现 p=2,q=2 时 aic 最小,取 p=2,q=2; @! u8 }- E8 |7 I: x
model = sm.tsa.ARMA(df['num'], (2, 2)).fit()
/ F3 H% U% h% ~model.summary()
- I' N3 b0 I; t. L' a
, n0 ^, }% p7 B- |根据观察AIC值的结果,选择最优(p, q)值为(2, 2),然后建立ARIMA模型并进行拟合。# B4 E3 k3 H3 f& n9 W3 Y! I0 ?% Q
# 预测和画图
( C" C" E0 ^4 b4 `5 E4 ]* r: jplt.plot(df['year'], df['num'])
2 U3 `7 ~7 @' R% O! {: Eplt.scatter(df['year'], df['num'], label='actual')/ ~) [9 @2 E2 {' d
year_list = [i for i in range(1971, 2001)]
1 J8 X* C$ [; r9 X$ tplt.plot(year_list, model.predict(0, len(year_list)-1))9 f8 T: ~  }. v. e
plt.scatter(year_list, model.predict(0, len(year_list)-1), label='predict')
1 X0 R5 E' P% x7 nplt.legend()0 S* D, E$ Z* o% `

( T/ q; }: [9 e6 C这段代码用于使用拟合的模型进行预测,并绘制实际值和预测值的图表。首先画出实际值的曲线,然后画出预测值的曲线,并将预测值的点标记在图上。: }: |6 F* K6 |; }" c. V
希望以上解释对你有帮助。如果你还有任何问题,请随时提问。9 O- B5 e$ t& E7 f+ X5 x" q
2 N% p1 I, q. K, D$ T0 o! g
  j$ C% R  w* I+ y3 g* ^

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-14 19:58 , Processed in 0.423232 second(s), 55 queries .

回顶部