- 在线时间
- 478 小时
- 最后登录
- 2026-4-9
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7788 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2922
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1171
- 主题
- 1186
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
ARIMA(Autoregressive Integrated Moving Average)模型是一种常用的时间序列分析方法,用于对时间序列数据建模和预测。它通过结合自回归(AR)和滑动平均(MA)模型的特性,并对序列进行差分(Integration,即I)来建立模型。4 W1 S0 F9 ]3 r$ Z7 b
ARIMA模型的三个主要参数是p、d和q,分别对应于自回归、差分和滑动平均的阶数。) j( a, }) n8 q' g, g
$ O @+ I+ _, X; P: c
1.自回归(AR):自回归部分使用先前时间点的观测值来预测当前值。p参数表示自回归的阶数,即使用多少个先前时间点的值作为预测输入。# Y3 k$ n6 U# z
2.差分(I):差分是对时间序列进行一阶或多阶的差分操作,可以消除序列的非平稳性。d参数表示差分的阶数,默认为1阶差分。/ H4 P* R( p* `# C9 c% m; t ^' B
3.滑动平均(MA):滑动平均部分使用先前的误差值来预测当前值。q参数表示滑动平均的阶数,即使用多少个先前的误差值作为预测输入。! p% O9 y A# h* S- l) ]
& k- y9 m4 [1 R0 C$ H9 w! |# ~
ARIMA模型的一般表示形式为ARIMA(p, d, q),其中p、d和q是非负整数。它可以很好地处理具有线性趋势和季节性的时间序列数据。
) T" X! }( |! m3 I+ S2 hARIMA模型的建立包括以下步骤:% m) d8 Z% c* B; ~: |# v( C
1 ^; G( I7 E! z! G% I
4.确定时间序列数据的平稳性,如平稳性检验、观察序列的趋势和季节性等。
% v/ h, D _1 {; {& Q5.如果时间序列不平稳,进行差分操作以实现平稳性。7 B) n: _) H- B0 k" w7 _8 [1 p8 m
6.通过观察ACF和PACF图来确定p和q的合适取值范围。5 W5 |6 d q4 W( I
7.根据AIC等准则,以不同的p、d、q值建立多个ARIMA模型。4 S! c- Q+ N. Z% Y3 P7 f
8.对每个模型进行参数估计和模型拟合。
2 V4 N4 P* V! ^9.使用拟合的模型进行预测,并对模型的拟合效果进行评估。
6 l4 r+ v, d( o( a* P/ n! R
$ K B, P3 s- C% RARIMA模型是时间序列分析领域中常用的模型之一,它可以用于预测未来趋势、季节性和周期性等时间序列数据的变化。在实际应用中,ARIMA模型可以被用于经济预测、股票市场分析、天气预测等各种领域。
4 q' H" H+ t- G: m+ }8 y) e6 f" ^" x1 h) t+ {) A
# 导入所需的库
+ Z* w! ]! |4 t! J3 L7 {+ |import numpy as np3 d/ E8 u' ^+ U0 I: | z* ]
import pandas as pd' r8 d( Y$ m7 w9 h) j) t" M
import statsmodels.api as sm
6 d" p+ S1 [! Y- h4 H, dfrom statsmodels.graphics.tsaplots import plot_acf, plot_pacf
' J3 J1 B- O; M4 v# D" ]) yimport matplotlib.pyplot as plt% I6 T( U; J* V; o. z; K
5 K- q; e. a' r+ V2 J0 C这些是导入需要使用的库,包括NumPy、Pandas、statsmodels和matplotlib。
1 B( _; |- z5 m4 n+ s0 Z# 源数据
& b- L" |! U1 ]" _df = pd.DataFrame({
3 M! u( C7 k6 _2 D, m 'year': [i for i in range(1971, 1991)],
6 u$ N5 ~7 ^3 ^! S! G9 z e! l) g 'num': [66.6, 68.9, 38, 34.5, 15.5,
$ W" I8 u) h7 A2 D) e- @ 12.6, 27.5, 92.5, 155.4, 154.6,
# ^0 U7 M6 c; ^. t& w7 x) A# a 140.4, 115.9, 66.6, 45.9, 17.9,0 G" }& \1 B' K
3.4, 29.4, 100.2, 157.6, 142.6],
. u. C2 e6 y7 m0 V})
5 o& {$ ^. Y, S! W5 P+ N* s. ~; I: R4 w \' s
这里创建了一个DataFrame df,包含年份和对应的数据值。这个数据将用于建立ARIMA模型。
$ }: q0 F' x/ a# 画 acf 图3 V _6 ^# K- @2 X3 E" ~6 Z1 Y
plot_acf(df['num'])
8 J& Y9 m# a7 R( m+ X: Y7 u2 c7 @% _1 g1 q3 Q' P
这段代码用于画出序列的自相关函数(ACF)图。ACF图可以帮助我们分析时间序列数据的自相关性。6 r) O+ e: H! z% F" `$ @$ g
# 画 pacf 图
, x& O6 J' F+ }! l4 v, s7 P, I6 iplot_pacf(df['num'], lags=9) B: K& }1 g9 [8 B3 z
4 x, Q! j$ T5 @这段代码用于画出序列的偏自相关函数(PACF)图。PACF图可以帮助我们分析时间序列数据的偏自相关性。
: Q( r# z% l8 ~- h# 建立模型,参考 acf、pacf 代入 p、q,观察 aic; s$ Y! ^4 O/ q! X" T# D
str_list = []
) A8 y( V1 G5 s% C% O/ |7 hfor p in range(1, 6):
& x0 c0 W2 x/ b2 P' ]+ o. x6 t n for q in range(1, 3):
/ w1 I, m; T! ?- f' ^" x model = sm.tsa.ARMA(df['num'], (p, q)).fit()2 _+ |/ U2 y# f7 Y; c/ u- {
str_list.append('p = {}, q = {}, aic = {}'.format(p, q, model.aic)): v0 a; h* j' S+ m) w+ z X
for each in str_list:
! w; v' Z# Z% z8 v- K print(each)
' a5 M6 A/ b" \6 H, Z4 y* D2 ?, {+ S" G5 M7 A J
这段代码用于建立ARIMA模型并观察模型的AIC(赤池信息准则)值。通过对不同(p, q)值的组合进行模型拟合,并输出对应的AIC值,以便选择最优的(p, q)值。" h# D7 O: d! o3 f
# 发现 p=2,q=2 时 aic 最小,取 p=2,q=2
& t6 f: y6 c# Y4 e4 H9 smodel = sm.tsa.ARMA(df['num'], (2, 2)).fit()1 T5 D N* d8 O' d: h
model.summary()) Q" k' U5 R$ |6 E- }" ]
# }' v7 A" Y5 _. F6 H根据观察AIC值的结果,选择最优(p, q)值为(2, 2),然后建立ARIMA模型并进行拟合。. s( _! p& a2 G) x
# 预测和画图
- Y1 [ V9 R7 p* ~5 P/ O# ~2 qplt.plot(df['year'], df['num'])
1 L$ D! l' z. W$ v+ G/ y7 P/ r( Oplt.scatter(df['year'], df['num'], label='actual')
5 P6 s/ W$ z$ P0 R4 L( Byear_list = [i for i in range(1971, 2001)]
$ q% S' i0 Z# }* Q1 P5 m( T$ o. e2 lplt.plot(year_list, model.predict(0, len(year_list)-1))3 n4 r. d- Q) V
plt.scatter(year_list, model.predict(0, len(year_list)-1), label='predict')
# `, G8 R6 O3 m- `, ~- b8 |9 J" jplt.legend()
9 D, J; Y* c6 C3 Z6 x
; G* e! f9 P1 G: a# i0 T( C这段代码用于使用拟合的模型进行预测,并绘制实际值和预测值的图表。首先画出实际值的曲线,然后画出预测值的曲线,并将预测值的点标记在图上。
% F( J7 n' \3 H3 ]9 S; M8 K: s8 I& v希望以上解释对你有帮助。如果你还有任何问题,请随时提问。
9 }# X, U: t4 w9 h+ x2 M5 w) P/ C7 _, n5 S
4 L" @ ` R# t, A# n$ r* q1 I
|
zan
|