QQ登录

只需要一步,快速开始

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

[国赛经验] python时间序列预测(ARIMA模型案例代码)

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

326

主题

32

听众

1万

积分

  • TA的每日心情
    慵懒
    2020-7-12 09:52
  • 签到天数: 116 天

    [LV.6]常住居民II

    管理员

    群组2018教师培训(呼和浩

    群组2017-05-04 量化投资实

    群组2017“草原杯”夏令营

    群组2018美赛冲刺培训

    群组2017 田老师国赛冲刺课

    跳转到指定楼层
    1#
    发表于 2020-5-23 14:43 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    1、模型识别
    2 s- G. }; Q1 [% t4 f, M01 主要的模型
    ; \3 h$ Y/ q+ p  \' a. b2 J8 yAR(P)模型(Autoregressive Model). t4 E& G2 {* _* W3 P- X
    + l/ q  @5 F) w# {5 Y' w) F" n
        自回归模型描述的是当前值与历史值之间的关系) s8 p4 E; Q1 C7 c% m! s7 V. j. q: o

    ( i' {& C; J# v6 lMA(q)模型(Moving Average Model)
    8 t- `% a; w) A0 J6 D0 C0 U) S1 a     移动平均模型描述的是自回归部分的误差累计9 K/ n/ f7 M. _  l) |. I. l% @
    % i. A. d9 M" A8 l; ?& [
    ARIMA模型(Autoregressive Integrated Moving Average Model)! Y. u% h: a9 N( O

    - [! Y* }1 @: e& J' d5 t' |    所谓ARIMA模型,是指将非平稳时间序列转化为平稳时间序列,然后将因变量仅对它的之后值以及随机误差项的现值和滞后值进行回归所建立的模型' C% O0 P, [. b% c/ a: o# X6 e
    : t% C- H- m8 Y! b$ j# X
        Xt=自回归AR+移动平均MA模型3 ^1 c& J9 L% Q' B* u2 `: Y1 B* y
    4.png
    * k% ^3 b) [4 e0 I7 r6 m02 截尾和拖尾
    ! ~" h* D' c) p: P! [, d, @! n+ B(1)p阶自回归模型 AR(P)   \! K4 n9 H  g9 P
    AR(p)模型的偏自相关函数PACF在p阶之后应为零,称其具有截尾性; 6 H, u( c8 `$ ]+ L6 A) q3 g
    AR(p)模型的自相关函数ACF不能在某一步之后为零(截尾),而是按指数衰减(或成正弦波形式),称其具有拖尾性。
    . ~! R; T' N2 ~( F8 U( U2 V% E& S- P- E7 \$ A2 O1 _" n
    (2)q阶移动平均模型 MA(q) 6 f# k$ s6 Q- [/ g3 m( A
    MA(q)模型的自相关函数ACF在q阶之后应为零,称其具有截尾性;
    4 b8 U- u8 T* r% ~- f; nMA(q)模型的偏自相关函数PACF不能在某一步之后为零(截尾),而是按指数衰减(或成正弦波形式),称其具有拖尾性。/ G; }' W0 C# ?7 l

    ) \1 D* P6 V: n# B03 如何判断拖尾和截尾
    8 x  l* [9 u5 V) k' o1 t$ `0 [6 ]4 R
    (1)如果样本自相关系数(或偏自相关系数)在最初的d阶明显大于2倍标准差范围,而后几乎95%的样本自相关(偏自相关)系数都落在2倍标准差范围以内,而且由非零自相关(偏自相关)系数衰减为小值波动的过程非常突然,这时,通常视为自相关(偏自相关)系数截尾。, {& ]% t) n7 X; x2 K$ h

    $ E/ x& s( D1 F) F, F(2)如果有超过5%的样本相关系数落在2倍标准差范围以外,或者是由显著非零的相关函数衰减为小值波动的过程比较缓慢或者非常连续,这时,通常视为相关系数不截尾。# m3 Z0 c! |6 v* o  K: b* r) y/ Z
    5 @" j* I+ r8 }7 g& D, n  C
    2、时间序列算法公式: Y5 Z! i# j  K% Z0 \$ y5 _" W
    重要的几种为:AR、MA、ARMA、ARIMA模型,具体公式见下图:
    3 G# @0 l5 n+ A( s/ T* a& C: y5 B9 h8 X, R( ^, J1 ?/ ]

    ' e6 t' Z$ {6 I+ b1 w1 w1 M. `
    : a& E+ Q: k! \8 Y3 u$ [3、详细步骤4 t' G% u" t/ M
    01 平稳性检验(adf检验); C$ K. g: ~+ g
    4 Y" w8 L# x3 v$ x
    #  a  时序图检验
    + A. g8 W& o5 M- t7 s* o. k( R# ?/ z/ Y
    根据平稳时间序列的均值和方差都为常数的性质,平稳序列的时序图显示该序列值始终在一个常熟附近随机波动,而且波动的范围有界;如果有明显的趋势性或者周期性,那他通常不是平稳序列" {! w. q5 I9 b7 T

    5 V. U' U4 L9 }# p* T6 D#  b 自相关图检验。0 }- F4 x2 `  q0 G. g* w7 V: }" }

    % e$ _7 O: H" Q5 a! K平稳序列具有短期相关性民政性质对平稳序列而言通常只有近期的序列值对现时值的影响比较明显,间隔越远的过去只对现时值得影响越小。随着延迟期数K的增加,平稳序列的自相关系数Pk(延迟K期)会比较快的衰减趋向于零,并在零附近随机波动,而非平稳序列的自相关系数衰减的速度比较慢,这就是利用自相关图进行平稳性检验的标准% x- {5 R" V. w* B4 G9 b$ n
    + x7 s8 k8 I: j8 h

    4 M$ B) p0 ]( }. C) b3 W  ?#c 单位根检验  
    / t. A# z* v8 P
    7 L4 Z+ I! D. A, G; r4 T! w单位根检验是指检验序列中是否存在单位根,如果存在单位根就是非平稳时间序列了
    * c0 H  W# W1 }; {8 Q/ ?
    # ?5 l! A! L+ t' ^& S! I3 C, ^
    ( A6 E5 \; n( w3 q+ n; H# ADF单位根检验  o$ g2 l8 ?0 ~
    ; H2 p1 C! ?; C4 M
    其中第二中的ADF检验中,如果p值显著大于0.05,统计量化大于三个或者两个水平值,差距越大,越不平稳。
    / X; w1 }: A( n- r. C# B3 ?* G5 u' v: L  ?% d4 g
    若统计量显著小于三个置信度且p值接近0,为平稳序列
    , {: Z+ y4 @( j- x8 i' h$ b4 B2 Z5 ]
    其他情况,可能是数据量不够的原因没有展现趋势0 _$ x3 R! m, X2 z& R: V, `# F

    / }2 X$ `2 }. U( J& z% {* w02 对数据进行差分构造平稳序列
    $ i, n, h$ N  H- a/ ?  O差分运算:9 a) g- R  d6 ?$ D' |

    0 V/ D9 w; i. g# t; E$ sp阶差分
    ; d/ w% t' m3 q  d2 w& I1 Y6 W: p
    / u1 L9 |! l0 a& i相聚一期的两个序列值之间的减法运算称为I阶差分运算' Y3 V$ d. {& L4 T
    3 X) }) o7 D* ^2 L& y  V. P
    k步差分4 |& h, `4 s* z4 K+ O. C# B
    ! ]0 J  X' [! h5 E! @5 @% h$ o
    相聚k期的两个序列值之间的减法运算称为k步chafenyunsuan& [) s. X2 ]- P  ~1 `
    - f4 Z( o; r) k. u
    #差分后的结果
    ' o0 A" P0 U" G( |$ ]D_data = data.diff(k).dropna()
    + r& @8 w0 W1 ^  W6 t/ }) e8 h/ c  C. D
    k 相距k时间3 z1 @4 n6 j, d$ R4 j; {  t* t

    ! z* l8 J/ N( G0 H2 P  @一般在一阶差分后就是比较平稳的序列' ~# [1 ^/ x/ G" z. s, ^+ j5 F) K
    1 t1 S. x1 Q9 A+ \+ k" N/ q
    03 平稳性监测
    6 r% p$ L3 q: W4 M04 白噪声检验/ Q" d/ q& ?% {  i7 G+ v
    #白噪声检验
    + Q, |& T  ~" w# Ufrom statsmodels.stats.diagnostic import acorr_ljungbox. X: T. t) ]8 Y/ s* x
    8 }( r+ d! M( \5 i) V
    #返回统计量和p值
    1 i. _+ S6 ?# t) A' Z% a& O/ r$ E
    ! d& g( C0 I5 K5 b1 D  Kprint(u'差分序列的白噪声检验结果为:', acorr_ljungbox(D_data, lags=1))  # 分别为stat值(统计量)和P值9 Z& n* I( M% i# B- P, T

    7 ?0 c5 f$ Q: U3 }# P值小于0.05,所以一阶差分后的序列为平稳非白噪声序列。
    ; p9 a) i: o4 k0 y0 Z7 v5 w: o3 l: t6 l! L& B4 ~+ r2 {
    05 定阶7 }2 h1 W3 a& G4 k+ \! x- U! p/ n6 |
    第一种方法人为识别5 I( Q9 B+ x; D
    & l. `+ Y0 T) P% }6 v+ u4 }2 e
    一阶差分后自相关图显示1阶截尾,
    & a9 x. ~" C$ h" ]7 U' Z8 h$ H$ j6 M; L% I
    偏自相关显示托尾性,所以建立ARIMA(0,1,1)/ b: U- f5 k: x! [7 W/ W

    7 @9 z# d! u; w( k2 c$ `! P: V第二种:相对最优模型识别
    7 k% T# p, T9 E# c9 G0 w4 i, ]! i+ \! G+ P' c6 c* A! ?
    计算ARMA(p,q)。当p,q均小于所组合BIC信息量,取其中BIC信息量达到最小的模型阶数
    6 K$ i  X1 E$ i: t9 a9 ]( c$ r9 V3 E9 ]/ @
    4 S" `" Q5 ^+ w9 `$ K) Y7 Y" ~1 \确定pq值  S5 {- `) `8 Y6 I' D
    & Y, o7 t; [4 S- e' J4 J
    from statsmodels.tsa.arima_model import ARIMA
    4 B' F" H7 t) n. ^: {6 F# \9 f#定阶" u7 A6 _: y/ P& {
    9 p5 H, Z  J* H
    #一般阶数不超过length/10
    9 K& P% `3 {2 T1 f; \1 @3 N
    3 L! u, ~9 h  U& @- l/ ^/ Mpmax = int(len(D_data)/10)
    0 Q" w0 Y! O7 Z. z  [: f& p" @1 y. G( P" [7 D0 E6 C, t
    #一般阶数不超过length/10
    " j# L# W% O/ P* Y
    - W6 [2 L3 {8 B7 f$ Lqmax = int(len(D_data)/10) ) G. M* t( K4 T8 n- W7 h

    $ D/ b: v2 M7 L2 k+ w+ u) C! I4 _. o
    #bic矩阵
    4 R! {. U6 Y$ t( n
    * p8 F$ J: F$ \" }& M$ Ebic_matrix = []
    6 A, N" F4 x. C! `for p in range(pmax+1):
    ' J+ U, @; \* m0 [" J  tmp = []: G1 s3 R0 f% e, m7 n8 @( M# X
      for q in range(qmax+1):6 {3 l' H; w& O$ M
    #存在部分报错,所以用try来跳过报错。
    , p: X; a$ ?; y. {    try: 3 t3 ?& c% c( @* w5 F
          tmp.append(ARIMA(data, (p,1,q)).fit().bic)
    * |+ r8 D& a# a! k/ k/ p    except:
    : _6 d/ G1 p8 ^      tmp.append(None)6 H# C5 u3 k! S, n* O6 s  q+ d
      bic_matrix.append(tmp)4 r6 {0 F1 e* {! `1 D! s6 ]2 i8 t' E7 S
    : D1 ^5 d5 ^" _/ R
    #从中可以找出最小值1 {5 y6 y2 q1 N0 `; v1 {% u$ c

      z$ K* p  [% \8 q  Xbic_matrix = pandas.DataFrame(bic_matrix) + K5 }( v# F3 r# @5 T
    0 k; W2 i0 y1 K' F6 Z
    #先用stack展平,然后用idxmin找出最小值位置。
    ' ^) Z( M/ d; d9 k# H8 W/ D, L$ ?, }) y
    p,q = bic_matrix.stack().idxmin() ! N, ~& y5 ?/ T

    + W( x% _, U/ l; iprint(u'BIC最小的p值和q值为:%s、%s' %(p,q))
    $ x0 r  _% c2 s- q! k
    4 n! v+ k0 k& i- B& O8 w# r# 取BIC信息量达到最小的模型阶数,结果p为0,q为1,定阶完成。$ g  L- ^( H  l

    0 ]4 `' ]. F, e' t$ e5 B4 b06 模型预测
    ; W( B( h- s' X5 G4 t; I1 ~6 D" u2 t+ u' }; f* |" q
    #建立ARIMA(0, 1, 1)模型5 ?& ]" B2 L% L8 U0 t8 F

    ; g6 r3 L3 [* K% C% T5 Smodel = ARIMA(data, (p,1,q)).fit() 5 Q2 m- D* d0 z+ j* i
    ! i! A# D) O9 M" A
    #给出一份模型报告
    ( W# m- k. C6 X8 g" h' E. \7 k8 _: _' F. E
    model.summary2()
    2 _- R5 ?& }" x5 I; y' W- j! K: p6 A; a7 y" E
    #作为期5天的预测,返回预测结果、标准误差、置信区间。/ ]' `; `  `1 y0 A! G8 s1 i
    ( a, T, F( a% g: v3 j& Q5 ]
    model.forecast(5)/ m, Y# f% }" H+ T$ o2 R0 @

    1 a* c- D; V3 D) M* K! J: v
    " @: A; j+ [# ?+ A9 e; D9 U% y4、案例代码
    3 g" @, c/ f" [% U7 @$ _4 N0 O, x, g$ F
    import pandas
    ( W, F4 [5 y) U7 e( F7 [1 o+ n
    9 N1 `* Z* k: S# 读取数据,指定日期为索引列/ K! i4 B" [' |. P( g" g. t3 l
    ' K" S3 ?2 f: @8 k$ q- A  r) b6 N+ X( h
    data = pandas.read_csv(( c: V" N+ X6 G# T" c9 P  ]
        'D:\\DATA\\pycase\\number2\\9.3\\Data.csv' ,, p: {1 B; N0 p0 F1 g5 S. o/ y, |
        index_col='日期'
    + m, N; D6 ^' w# ^5 ~5 l( V3 B* t)
    8 q6 n7 x3 x$ V( r; j6 V
    5 O* I& x# G) u# 绘图过程中1 c5 C+ L( n+ j
    : V% o1 |. v7 i
    import  matplotlib.pyplot as plt" q7 v2 H9 R" H. ?; x  {& q& y* o
    . T) d+ W: _1 G6 H" s0 _9 _
    # 用来正常显示中文标签) B; ?2 e1 d0 H- u- d- c7 G4 p
    / v4 ~* u' C7 x* q
    plt.rcParams['font.sans-serif']=['SimHei']2 i! T% R6 k* V- K8 R

    # i$ \) e. p/ C3 @# S6 R. \# 用来正常显示负号
    0 c9 ~8 P) F2 O! {3 c6 F: ]# O7 V+ n) j! |2 Y* U
    plt.rcParams['axes.unicode_minus'] = False ) I! Z& o4 h' t$ E+ ~2 {3 U/ U

    9 Z+ e/ L. f9 Q; S" g1 O# 查看趋势图) Z# v( b% A. h8 c% @2 C  [. ?2 R6 F- _
    data.plot() #有增长趋势,不平稳
    ' }* H4 |- m/ A/ Z) ]$ D2 p! r1 a) c

    ' w5 {$ P7 g/ h" c) g% g; J( f# 附加:查看自相关系数合片自相关系数(查分之后),可以用于平稳性的检测,也可用于定阶系数预估
    , m: {+ z$ N: G5 o4 H) X( s4 ]6 O* Z, I( u9 |
    #自相关图()4 ]: Y0 }# L* J& I

    # H0 M* v3 v/ \  k- l9 zfrom statsmodels.graphics.tsaplots import plot_acf
    ; R/ l+ ~* I2 q$ O6 \$ x+ F* |, e6 O, ]; P
    plot_acf(data).show() #自相关图既不是拖尾也不是截尾。以上的图的自相关是一个三角对称的形式,这种趋势是单调趋势的典型图形,说明这个序列不是平稳序列
    $ k% d2 }$ U0 y! v$ e" _8 K2 I. \# q. ]* L* ~% @/ ^

    $ p  z1 o  ]- |6 _' V# A% X3 ^0 u2 c& D" k

    - h7 z* E5 E0 C  F  S( T& c
    # E: Z: H7 N0 z' V. P1 {7 P$ Z1 g# 1 平稳性检测
    0 |/ Q& u3 V% L9 x, z
    8 p. Q0 ]& y1 g+ A6 Wfrom statsmodels.tsa.stattools import adfuller as ADF
    5 R  S& }$ I+ J, R5 |3 C
    2 i5 f) j9 G) `+ G+ R3 O, b6 M  Q+ l" U
    def tagADF(t):
    . d' P8 E* J, l: w4 X; x. c% L    result = pandas.DataFrame(index=[0 x4 ?3 L- Y# S. a5 T4 J
                "Test Statistic Value", "p-value", "Lags Used",
    % u) }& w8 U2 V% G% o1 X& o            "Number of Observations Used", , G! f: D, L7 S  U; D4 g% k8 T( e
                "Critical Value(1%)", "Critical Value(5%)", "Critical Value(10%)"
    5 P0 a, p$ V3 S) k# o% M/ x        ], columns=['销量']% {- y2 |% c9 l% J
        );
    5 o" C/ U9 a* S2 S' k0 v    result['销量']['Test Statistic Value'] = t[0]
    & [! V7 {; z( w, ]- o- }/ Q    result['销量']['p-value'] = t[1]
    : l% {2 r$ e- ]4 r. t+ |    result['销量']['Lags Used'] = t[2]
    & ?: `9 o1 m# j    result['销量']['Number of Observations Used'] = t[3]" C( F9 T4 M# _" t
        result['销量']['Critical Value(1%)'] = t[4]['1%']
    % R0 ]) _8 D9 f0 B    result['销量']['Critical Value(5%)'] = t[4]['5%']
    8 L3 K7 H0 W7 M4 {( G$ f. ]1 O4 Y    result['销量']['Critical Value(10%)'] = t[4]['10%']
    5 a: p' _/ W  c0 z; c9 Y: k/ Z; O    return result;
    . L, Q4 d% {' Y* c/ V! P2 g+ q, e
    5 R4 A+ S/ `6 o9 @
    print('原始序列的ADF检验结果为:',tagADF(ADF(data[u'销量'])))  # 添加标签后展现
    . c0 G' C2 I! x! u! _* `3 L2 P; `! L  p$ Y- T
    # 平稳判断:得到统计量大于三个置信度(1%,5%,10%)临界统计值,p值显著大于0.05,该序列为非平稳序列。
    ! }; w+ j+ G" {7 Y  ^# 备注:得到的统计量显著小于3个置信度(1%,5%,10%)的临界统计值时,为平稳 此时p值接近于0 此处不为0,尝试增加数据量,原数据太少% |% F9 r) k& Y  y

    $ d7 \$ B7 X( @4 Z7 e" J# 2 进行数据差分,一般一阶差分就可以3 |& u+ {; L' K; ~% Z; Y

    6 U+ }- A  A. H2 L5 fD_data = data.diff(1).dropna()
    , W" g6 L3 H+ j( _D_data.columns = [u'销量差分']- P" B, V) |) W1 I0 X

    ! ?$ x; ?6 ~4 @5 d) S2 Q- t7 s; v# F#差分图趋势查看! N* q. @+ \5 B  i" n
    4 B1 f9 u! l2 A0 r
    D_data.plot()
    0 f7 h& _" ~  f( jplt.show()
    0 v6 Y8 S1 {0 T3 L" i4 j9 p. @& J$ {, F
    # 附加:查看自相关系数合片自相关系数(查分之后),可以用于平稳性的检测,也可用于定阶系数预估
    ' e) C2 G) f% x
    ) v& ?3 f8 \, t' b( k#自相关图$ E  G  N. D. e4 I5 @

    6 l, C. Y3 I* e; I4 o4 J0 Splot_acf(D_data).show()# g3 Z* {8 v! O; \4 d& ~

      @6 ?6 |$ S/ `& Nplt.show()
      f& {; w. q: N
    ( n* O+ }$ ?9 |5 J4 i5 Q7 e2 h#偏自相关图- u- l( I! j. Q4 [' ~* h8 i
    & j1 }  c+ e' U0 P& x: X
    from statsmodels.graphics.tsaplots import plot_pacf) k: Z6 F% d5 [, H; F$ d, j

    1 i) q8 k, a2 s* R- J8 G/ Kplot_pacf(D_data).show()
    ( b8 o3 o( n$ o- l
    , s! R$ @- L7 p; U' }" e$ m# 3 平稳性检测3 c% s% L. b; v( |  q! z, n! h
    * w$ N. W5 q& ^' S# N) T# u
    print(u'差分序列的ADF检验结果为:', tagADF(ADF(D_data[u'销量差分'])))
    ( D0 z6 x. c9 O9 J( z  @0 N3 d* X) E5 Z/ u
    # 解释:Test Statistic Value值小于两个水平值,p值显著小于0.05,一阶差分后序列为平稳序列。
    ( o$ U7 f* p4 {/ g" {0 b  t. S6 l& v& R: M  L0 w
    # 4 白噪声检验& c' {7 K9 Z4 A9 Z4 {- y- [. ~
    from statsmodels.stats.diagnostic import acorr_ljungbox
    5 [) p7 Q8 e1 k& |1 y( U
    & f: {. j" n1 Z( Q; G#返回统计量和p值' Y/ D* r' D$ c& L* k! p4 B5 m
    ! W6 `4 R4 f8 o% A) U: v  r2 g
    print(u'差分序列的白噪声检验结果为:', acorr_ljungbox(D_data, lags=1))  # 分别为stat值(统计量)和P值
    * W) s' [& f. m0 I
    * A' j/ }, R% M# d# P值小于0.05,所以一阶差分后的序列为平稳非白噪声序列。
    ! q  E- u4 m7 x2 F2 I* H! _) \" ~) }7 k7 r( R- i

    5 F& ^' C+ C2 i3 E$ D/ l4 n# 5 p,q定阶- s9 l9 N4 w& [3 x( o* b3 Z( {( z
      v% R: m6 j7 _9 M0 O) ?9 ^
    from statsmodels.tsa.arima_model import ARIMA# d5 p9 W+ P4 z3 e
    ) [: Q1 u1 o6 h
    #一般阶数不超过length/10' N7 |! u3 ^. B" X5 B$ V1 j

    / g' k4 K6 G+ m; h0 j" M5 Xpmax = int(len(D_data)/10) 3 Y3 I# V$ H9 q4 H; E
    , R! v2 v, I2 z4 n7 u3 ]2 v
    4 L: _7 {& }1 b9 T- a  k
    #一般阶数不超过length/10" X5 p# Z% b1 k/ L

    ! a2 u& y( j; h2 Y* B! K( H, f8 Nqmax = int(len(D_data)/10)
    . E5 E0 ~5 ]5 n/ ~( B+ g1 e4 ^
    # w, O! |& `2 Y/ h5 b, {8 W#bic矩阵
    : {4 ^8 p; ~  C/ B# }* S
    9 y+ M- ?$ R9 obic_matrix = []
    ! Y0 I) \. T) @7 _* n& Jfor p in range(pmax+1):
    $ W4 O$ Y4 b, ~  tmp = []
    : j+ y% e- v1 F7 e3 m5 B/ u6 t: y  for q in range(qmax+1):
    : H4 r8 E1 M) Q( A, B' d- X0 }& p#存在部分报错,所以用try来跳过报错。
    . W$ o: Y9 C* {6 t1 D' Q0 n0 ~    try: + ]8 Y& ~1 o: h& ~* B, i
          tmp.append(ARIMA(data, (p,1,q)).fit().bic)
    9 i! e; {* i/ M2 }0 e, |( t    except:4 w7 ?' T2 w7 h4 ~
          tmp.append(None)4 \" v; Z9 h! e+ `' k$ [& U
      bic_matrix.append(tmp)
    8 w; Y( l( N! f1 n
    # G5 T9 _$ k1 {, l0 b. K+ z3 t#从中可以找出最小值
    , ]! b" }  U& d* N  g2 P3 A; B: w) `5 t) _+ H
    bic_matrix = pandas.DataFrame(bic_matrix) 5 ]$ R3 p9 c/ G

    7 Y$ V( \& l* ]: W6 a7 k  X#先用stack展平,然后用idxmin找出最小值位置。
    8 Z. U( f+ e+ T1 c
    , o  L- g; |- Kp,q = bic_matrix.stack().idxmin()   N; U; U, w& q/ y; [1 [

    3 x3 l7 E  i' r) S
    ' {$ u0 }3 p% I5 |- ^# j9 J# X( }8 ]9 o
    print(u'BIC最小的p值和q值为:%s、%s' %(p,q))7 M0 \' ^  N2 R1 H
    # 取BIC信息量达到最小的模型阶数,结果p为0,q为1,定阶完成。, i" x+ X) N2 J# _; }/ X' N
    ( ?+ e7 z- q9 e8 z) t
    # 6 建立模型和预测7 g9 E: |! v  n6 \- D& z* C

    , D/ e5 f! t! S; V4 n1 ~; ?8 smodel = ARIMA(data, (p,1,q)).fit()
    ) e& Y% n) v4 Z' E4 _
    " M2 `& W3 B9 s, h: T#给出一份模型报告
    & N  L% }4 {2 A) G8 q
    % f7 q; z2 l$ V) v  I% I2 P0 `model.summary2() & i) n) @' e& j, l4 M

    4 k4 u* E7 M' V3 I' V; h#作为期5天的预测,返回预测结果、标准误差、置信区间。
    ( {4 q9 j1 S9 D
    1 r; C; z6 i+ j4 `& I# Lmodel.forecast(5)
    1 G* Q( w# r, T: Q7 P8 {4 H# s% V, k/ M. N, x  l- i  |. Q) w" T. Z

    + Y) R" D0 Z' D0 o4 r————————————————  `* f( E& X3 q  E3 Q1 F
    版权声明:本文为CSDN博主「UP Lee」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    * C7 ]: H1 [0 v; N1 h原文链接:https://blog.csdn.net/qq_36327687/article/details/85696152
    2 S) f9 P& W  {) W, n; h5 A
    " @$ E1 p% q8 I9 [- `: e2 s5 m; f7 R* _0 U  G* o& L' w
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信

    0

    主题

    3

    听众

    92

    积分

    升级  91.58%

  • TA的每日心情
    慵懒
    2020-5-25 19:07
  • 签到天数: 2 天

    [LV.1]初来乍到

    群组2019美赛冲刺课程

    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-4-26 02:50 , Processed in 0.431997 second(s), 59 queries .

    回顶部