- 在线时间
- 661 小时
- 最后登录
- 2023-8-1
- 注册时间
- 2017-5-2
- 听众数
- 32
- 收听数
- 1
- 能力
- 10 分
- 体力
- 55544 点
- 威望
- 51 点
- 阅读权限
- 255
- 积分
- 17615
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 447
- 主题
- 326
- 精华
- 1
- 分享
- 0
- 好友
- 79
TA的每日心情 | 慵懒 2020-7-12 09:52 |
|---|
签到天数: 116 天 [LV.6]常住居民II 管理员
 群组: 2018教师培训(呼和浩 群组: 2017-05-04 量化投资实 群组: 2017“草原杯”夏令营 群组: 2018美赛冲刺培训 群组: 2017 田老师国赛冲刺课 |
00引言# j! E4 q. O( C' R. g: |8 r3 E
在毕业实用统计模型(一)——时间序列1中介绍了时间序列的模型的基本建模思路,在毕业设计实用模型(二)——时间序列之SARIMA2中说明了ARMA、ARIMA、SARIMA三大模型的关系与参数调整。但是在实际建模中往往会遇到更加实际的需求:模型的评估、参数检验、预测图的展示、模型参数的调整。对于很对不喜欢编程的人来说很是痛苦。本文将会重点从上述几个方面讲述forecast包里的主要的函数,并给出实例。从本文中你将会学会:8 z3 V, S" J, E: C2 M
1 o0 s, _ N; R
更加高效的的模型预测图。
: v9 M% n9 L: `模型的参数检验6 P; Q# s% Y' Q+ d
模型定阶的函数3 [0 c1 b1 J& J [' i$ n
模型的评估函数$ k( l" m+ ^1 g7 }+ \" t
拟合线性的模型函数- I" e! S0 s E* K
相关图绘画,以及误差的标注3 i, G7 _ v) j% M4 y( z$ c
输出模型的预测误差
7 ~" R0 n2 D7 Q: x2 H注:本文部分代码案例来自forecast包,大家有疑问可以自行去查找3.如果进不去可以运行下面代码会找到。
5 @# M) m! a7 |3 y! Y; f# ~library(forecast)
% H" M5 {2 b4 \+ _" M% X+ {0 shelp(package = forecast) J5 L# q; C5 q
$ ?/ C* m! x3 [8 y1、accuracy函数 l& T3 E: L d* ?% S( J; ?2 ^
描述:输入参数是模型,输出下面的结果:, W, \) E C! V! v' E+ D9 s' _
" }7 S7 _) U4 G: Q7 ^, N6 G, F9 f
5 }" ?: d/ `7 r! X5 z+ ^7 p( W7 r7 X
函数示例:
& t# T p5 e# L. B- {, S+ Q9 k# G4 ^# r2 v
, z8 z8 W1 {$ ^) \( {' v6 N1 O3 o; H- M5 k w( E4 j! d4 H
最后的图片:! v+ B4 ^. h6 B; l' }0 e
![]()
* L" B, K2 Q; A' G4 D1 w1 I* N* c' ^6 k9 C" t' i
2、Acf、Pacf、taperedacf、taperedpacf2 A" p, e Z) V5 O! i
这四个函数分别是自相关函数、偏自相关函数、带有误差的自相关函数、带有误差的偏自相关函数。前两个很熟悉和内置的acf、pacf一样,下面只给出后两个的示例:6 }5 T3 M% W2 _" S: h4 I
" l: u* }' j% A1 k; f6 o
. B) S3 x: C: e1 @3 k R4 W( W/ M8 E
3、arfima
6 n; |2 n& S9 j. n& x0 h可以建立长期记忆的时间序列模型。
! z: R) y2 K7 N直接给例子了哦:
' d$ r+ G5 s/ i* O) X+ W5 L
" J. t8 z8 w* _1 K
# W, A2 [ G* t9 S
输出模型效果: d" P! v- P+ M" O9 N: Z
. a5 [) ~* C5 N/ N- ]; X& ?+ {8 S) H2 |0 h5 h" ~
画出残差信息:) H; d$ c* k: X$ q
tsdisplay(residuals(fit))0 V% X; z2 v2 }) {3 u" w$ s
V8 W; V0 z+ e, |9 ?
, O7 T, Z- s- K- c" I/ O4、Arima函数
% u" U/ h% F" B- @; Y1 B* w! T函数介绍:这个函数可以拟合平稳或者非平稳的且已经知道参数的时间序列模型。也可以带有季节因素。
`# ]7 u$ W& S* s1 C4 v- A
+ V& `2 v- i- dn = 50set.seed(0)x = rnorm(n, 1,3) # 生成数据library(ggplot2) # 载入画图包x %>% Arima(order=c(3,1,1)) %>% forecast(h=5) %>% autoplot4 z, x6 [" y/ w/ p" K) I
8 K# T6 }* R: G 上述代码用了管道函数,ggplot2包。对模型从数据到预测到建模一部到位。给大家看看Arima的参数。1 m/ ?1 V3 f, j+ v
! X" z+ f. ]3 t# `" [% O: ]function (y, order = c(0, 0, 0), seasonal = c(0, 0, 0), xreg = NULL, - t! w9 F7 ]5 O: t, i ~
include.mean = TRUE, include.drift = FALSE, include.constant,
; I4 m4 Z: L! k/ s3 _- k }8 u7 d lambda = model$lambda, biasadj = FALSE, method = c("CSS-ML", $ H$ r5 S* q: {& G
"ML", "CSS"), model = NULL, x = y, ...)
% M; A" _1 b# A 2 K; K4 F8 M# U+ A) q* d
5、arima.errors函数 ?- q, D. Y2 \7 f8 ^$ m
该函数使用简单,用于输出模型预测每一期的误差。注意和residuals函数进行区分。
* b3 Y- t, U( j" {& _5 r+ B0 |# 生成数据建模n = 50set.seed(0)x = rnorm(n, 1,3)fit <- arfima(x)0 E! O; e. @- d5 J3 U9 I
# 计算结果" p |. v2 X8 V. M/ d
> arima.errors(fit) # 预测误差" f0 o0 n! M& P! D2 |
Deprecated, use residuals.Arima(object, type='regression') instead
2 v$ e4 g) D; _+ STime Series:
' M; s: c9 S. P# x1 w% V% C" ?Start = 1
8 _6 s7 @0 R: B5 w0 ?$ jEnd = 50 1 `9 z( g2 ?0 [. ?" |0 v
Frequency = 1 9 M# }& |# R: M8 y' @- D2 \
[1] 4.78886285 0.02129992 4.98939779 4.81728796 2.24392430 -3.61985013: @# h- ]6 r3 H: g* w
[7] -1.78570110 0.11583866 0.98269848 8.21396017 3.29078038 -1.39702775
5 x5 n9 e. K* ^" m3 c[13] -2.44297103 0.13161528 0.10235465 -0.23453250 1.75667034 -1.67576338" L& @' h. j# E6 L' j
[19] 2.30704990 -2.71261527 0.32719634 2.13218694 1.40000908 3.41256853: x; h/ v: [0 v8 r% h& f O
[25] 0.82867968 2.51082392 4.25730809 -1.07286152 -2.85379806 1.14017852$ t, }7 |* r& q8 ?: W
[31] 0.29288033 -0.62866477 -0.29993095 -0.94841494 3.18025224 4.455735262 F% f' H) M. {4 X j" Q; p
[37] 3.97648110 -0.28853933 4.71491230 0.16196115 6.27370927 2.68223827: Q1 ~, s, z1 v) O$ n5 s6 N. y
[43] -0.35835192 -1.49612989 -2.49971164 -2.19677174 -3.69134615 4.46961099" k- E2 B) O! g L
[49] 3.49614139 0.318013939 Z6 o4 f& _5 ~1 `8 f! g& @
> residuals(fit) # 残差
5 h: U$ L; P4 x7 Y DTime Series:8 {2 h! X$ B" _" {
Start = 1
1 j8 W* T( C( L+ b* l( yEnd = 50 - u7 H l: M- K! n
Frequency = 1 ' @% A( @/ I. v3 i+ }
[1] 3.71706994 -1.28784846 3.87358515 3.45503095 0.78349981 -4.980567753 \3 x+ p6 f: f0 f0 r( O3 T
[7] -2.74303846 -0.77184435 0.03669199 7.20508533 1.79698739 -2.803776096 M1 G' S6 S2 N7 z4 N
[13] -3.54880551 -0.77827016 -0.86325716 -1.20139553 0.81773766 -2.72392791
$ z+ u B. q5 @[19] 1.43279254 -3.76501026 -0.47528735 1.24438107 0.37471968 2.37151650
6 T4 D' i& H. A[25] -0.35743144 1.41677218 3.08432283 -2.39421040 -3.91173996 0.30272726
' V3 E9 S2 U3 [' R: D, ~3 q[31] -0.68356344 -1.59285606 -1.19943417 -1.83611913 2.34677217 3.38917930
- h1 J3 l( \+ ?$ |& g5 a- t[37] 2.72730075 -1.60715574 3.61473632 -1.17228009 5.12889059 1.21871171
0 V6 D4 |% K- O- u[43] -1.73495615 -2.66242875 -3.50034594 -3.04300026 -4.46595111 3.84607121
4 D- n( R3 ]# I ]4 s/ T- ^[49] 2.44020165 -0.85475604
. q1 ?0 g5 K$ \4 g o0 c& |4 D+ f0 | ?2 d
6、arimaorder: ~3 c% @( H2 b$ o7 X
函数功能:输出函数的阶数,用于时间序列的自动定阶。下面用自动定阶函数auto.arima和管道函数结合输出参数。给出示例。
7 v# L: g" q! [, N% D1 B# f6 Z' o$ U$ L5 ?
n = 50set.seed(100)x = rnorm(n, 3, 5) + 1:50 # 生成数据x %>% auto.arima %>% arimaorderp d q 3 1 0
) \* a; i# q5 P1 p8 ^" N7 Z6 ~可以配合arima函数进行模型的参数的确定。6 u3 S3 L: J6 O1 {% |4 Z
- L; f) M* n& X2 s0 n7、auto.arima
6 p% i6 `% o8 ]0 C3 h$ F函数功能:可以使用函数进行自动定阶。下面时该函数的参数。这里会进行讲解并给出具体的实例:7 L" ]! }6 f w1 S. K8 O+ c! d; Q
auto.arima(, p8 Q( F0 x3 \7 P# S7 i
y, # 数据
0 n' U& c: x+ G" ]+ I# y @ d = NA, # 原始数据差分的阶数
; ~8 G) L* U7 h1 X D = NA, # 季节因素的差分阶数
2 \ F3 r4 d9 W3 U, L( S0 B# P& `7 C max.p = 5, # 遍历达到的最大的AR模型的阶数。% Y" e. a k7 p" q
max.q = 5, # 遍历达到的最大的MA模型的阶数。( n1 o4 @! E- {$ e: A5 |, J6 H
max.P = 2, # 季节因素遍历达到的最大的AR模型的阶数。% v! r- Y; y$ f4 o2 [' B
max.Q = 2, # 季节因素遍历达到的最大的MA模型的阶数。6 U( ^! F2 N! j( G
max.order = 5,
; o5 `$ f: B" y( ~! V7 U max.d = 2,* a/ X- d5 a6 l* l/ _4 z0 T
max.D = 1,9 d. N+ U( N' l" h- W! M
start.p = 2, # 开始遍历的AR模型的阶数。
$ O3 `4 j% W2 U. U J* q start.q = 2, # 开始遍历的MA模型的阶数。
/ k9 c- h5 ~1 W0 x* W* G( e& O% H start.P = 1,
" L- O! a+ U! e4 E start.Q = 1,
0 r+ B/ Z) g3 t9 D/ }8 w stationary = FALSE, # 7 \; ^: |) X2 Z+ T: i
seasonal = TRUE,
' L7 D: ^% v6 q6 e' r! ~/ R3 e, Y ic = c("aicc", "aic", "bic"), # 常用的选择模型的标准
* N" A$ \- C& w stepwise = TRUE,% \4 V% y* `( F6 E5 [( l
nmodels = 94,
0 W8 a4 d* ^+ n8 m trace = FALSE,# 是否跟踪模型的选择3 a% ]" d/ U5 `* _, U, U5 f: `
approximation = (length(x) > 150 | frequency(x) > 12),
5 S- T) n- [& O$ U5 A9 w5 X method = NULL,( r! p* ?+ ~. ^ B
truncate = NULL,3 w8 o& t7 M; D2 g S
xreg = NULL,0 a' o, D% S/ }( y
test = c("kpss", "adf", "pp"), # 平稳性检验的方式' _( a0 D/ ?* K7 U- u9 I2 P
test.args = list(),
# S" Z, }6 o9 E# o seasonal.test = c("seas", "ocsb", "hegy", "ch"), # 季节性分析
' |6 H! ?3 n. y seasonal.test.args = list(),
# ?" `+ o* g/ @$ t7 y: g* A allowdrift = TRUE, # 可以去掉漂移项
; l. e* B. M7 G& u2 ]# H6 g! \ allowmean = TRUE, # 可以去掉均值项
% c' w. U& H" d) w# c lambda = NULL,& J* @: S# t4 v. q5 l ?. W. g
biasadj = FALSE,
& B7 n- P: g# p5 [/ k parallel = FALSE,8 M- L2 ^- n8 X0 _/ @
num.cores = 2,+ A3 q6 a! o* E0 v: C7 ?, C
x = y,) x' R4 F( i! N! D0 u
...
+ m+ y( X" j* ]1 x, G, {5 u)
6 E3 I/ K: M; L
" ~: I( ^) m1 u0 y' @auto.arima函数的参数众多,我把上述函数的参数给了一定的备注。大家可以根据这个注释和数据的其他的检验依据自己去逐一的验证调试。最终得出一个比较满意的模型。
3 M( S/ b* }" A下面给出部分调参的实例:
: L- }% {* D4 U; T" C; ~5 J7 F# 画时序图plot(ts(x))* b T* V9 w7 L$ Q: P
![]()
, {5 w) X+ F5 ]+ K! ^. }- ~" R2 z- N9 l9 Y
下面展示追踪模型的参数:7 s8 ~/ f% K6 B0 x I. m
' j3 _5 q) c) Q, M
7 R4 h4 [- I' G: t8 N7 e2 L) x" X
更改准则AICc成AIC继续追踪模型的参数:, \6 H- r! L8 }
' t+ B# K+ p0 } ]! D4 x! c# f
+ P; b* }: ^" M7 |* H Q, [% \这个函数的参数就介绍到这里,大家用到自己继续探索。! x, O* D4 Z( `9 L
1 x4 z5 a- I1 {- ~
8、ggplot2中的时间序列相关系数" G- R6 u1 K0 U' h% I& |
这里把函数内置的实例给出来。
5 f1 U/ n% w V) A$ Q
* L) k7 a' b, ~. R9 a* d/ d- _( H# 载入画图的ggplot2包! W$ L2 j1 h u y
library(ggplot2)9 S/ r8 i, e. g- s, ^
) [& C. J1 @8 Z# u" W
下面的例子使用winneind数据。是个时间序列数据。
0 G6 k& i7 J' L! e" d- z- f# l& a8 G
1 ggAcf(wineind); n2 D6 ^# q& y6 c8 J1 |6 i# N; w& W
: y# P- U2 F8 z2 Z, T* K7 f" d
; d* S7 e- j# u Q6 o1 O- p
! U/ w% j/ P2 t* O7 t0 Z1 wineind %>% taperedacf(plot=FALSE) %>% autoplot
+ E. K& |* P; k, v" Y( x # @- ^) b3 y5 B0 a6 ?* H4 {8 e! J
, D/ A3 t6 _( V/ { W w* T$ Z; J
1 ggCcf(mdeaths, fdeaths)
4 W; n5 _2 C/ e8 W8 G( r/ k: \9 l
![]()
7 w* E e* _8 F! U0 p' Z8 o
: P; p) y# d5 h9、tslm4 J# a9 @* p1 a2 t7 N1 Y9 l m/ P
函数功能:用时间序列分量拟合线性模型. ^, x, ], n) T2 Y" x0 m
为了我方便第一次见到的同学学习,先贴出模型的参数:1 w, i& f8 R7 N0 c9 h8 W
Y, _! d+ q* B9 o4 n( @ O/ E
1 > tslm
: {- M# ~2 p, D2 Y8 m5 X2 function (formula, data, subset, lambda = NULL, biasadj = FALSE,
; y7 I8 Q# j3 B/ `; l( j3 ...)
# A0 B& o( T( {3 x$ S0 d5 p- P/ U. C0 M* S* y& I4 Y
formula参数是公式、data是数据。下面使用函数例子展示函数功能。
" u/ u x) f# e7 |7 K3 b
% l Z+ S3 L- |# B B1 > y <- ts(rnorm(120,0,3) + 20*sin(2*pi*(1:120)/12), frequency=12) # 构造数据7 S: S6 Q) L4 e$ D
2 > fit1 <- tslm(y ~ trend + season) # 趋势+季节! u, o/ s4 l3 Z8 a. k- J4 C
3 > fit1* Y' G5 x+ e- J/ g
4 Call:5 W' G G/ ^, {0 W9 N
5 tslm(formula = y ~ trend + season)
/ o1 l7 H, ?7 M/ ~8 \6 Coefficients:! _+ l, i; ^" c! H1 }% v: ~
7 (Intercept) trend season2 season3 season4
0 V. ]% w3 F- r" r. W; _: i0 B8 10.20906 0.01175 7.31274 8.82928 7.04245
& |/ x |8 y2 s; V& h( e, I9 season5 season6 season7 season8 season9
9 t+ ~) ?& q6 Q* b10 -2.04022 -10.24111 -20.57768 -27.61414 -30.16768
1 e0 s/ i5 `/ B11 season10 season11 season12
7 L; { ^4 o, X12 -27.56840 -21.53062 -10.35272
H- E5 P) V: v. x* P7 }. P# e5 J5 l: `- Q
1 plot(forecast(fit1, h=20)) # 画出模型1的预测图
( `# G2 @, ^$ v) P$ ?![]()
- ^- A" T' K. Q- T
* @. g! l; H5 i" M1 > fit2 <- tslm(y ~ season)
$ }: ^0 v# A1 v2 > fit2
$ X8 z/ _% W% }4 q! x3 Call:
( e8 X r- l' Q4 tslm(formula = y ~ season)* x: v; Y1 t. G
5 Coefficients:9 W: h# e8 i. ^2 a4 O: x! e$ {
6 (Intercept) season2 season3 season4 season5
7 w' i9 }2 H6 \1 `% J# S7 10.856 7.324 8.853 7.078 -1.993
. I* J! E6 } I* ?8 season6 season7 season8 season9 season10 9 m8 J& R2 [/ L+ O
9 -10.182 -20.507 -27.532 -30.074 -27.463
7 |4 H3 ^) q6 ]( y9 D" x10 season11 season12
& ^) Y) x% x; C11 -21.413 -10.223 / f* ~( I0 Z+ R w. o0 m
; O1 u/ B0 Q$ P# j& y
1 plot(forecast(fit2, h=20)) # 画出模型2的预测图
& Y" s" h- R2 t9 e) k& e# b8 f![]()
( }5 X: Y% z+ D# m! c- y. J+ ?, q% A r2 T
10、CV交叉验证
) C; U* U1 [2 z3 g" vCV函数显示模型的CV AIC AICc BIC AdjR2值,用上述模型直接给出例子。
8 B9 j, {3 K _5 ^, z. e) L, H7 z6 s8 e: o
1 > CV(fit1)4 y3 R: U- h3 j9 S0 C% N
2 CV AIC AICc BIC AdjR2
- y1 E; H' U3 X3 d* s3 12.851627 306.718526 310.718526 345.743411 0.945285 & Q! ?) F. Y( T
4 > CV(fit2). j! _/ d6 ?4 k- W
5 CV AIC AICc BIC AdjR2 ; v* W5 T" H4 U0 x+ c8 U
6 12.7985986 306.6337582 310.0677205 342.8711509 0.9449195 $ O0 T" R$ q0 f, G: W3 z7 V
' ]6 s3 c/ m! u. F& S11、forecast
2 o0 ^. s. Z' q4 m! f5 [& x这个函数可以给出模型的预测值用于画图和分析。
* M0 W3 Z! X4 t; Y& T, k1 x下面给出上述模型一的预测值。
, I: y; D8 X, P: H. _' g# C- Z4 u
- p. e9 e8 F& ?; n- m% @
结果说明:第一列是时间、第二列是预测值、后面4列是预测值的80%、95%的置信下限和置信下限。
5 l) z* \& A1 }
9 y4 Y& Y: |2 w+ J* L2 }2 K2 y12、geom_forecast+ H' e% S1 F7 d& U' A7 \9 R# E
这个图是ggplot2的预测图,下面贴出代码给出效果。这个函数也需要结合ggplot2包进行。3 I; c% e1 a$ U7 e8 X% @6 y
/ i6 M5 C' J8 k* M7 G) r/ v
1 library(ggplot2)& W- P5 ^" e$ I' g' S
2 autoplot(USAccDeaths) + geom_forecast() # 图一6 L6 C: m, h. I5 O) v
3 lungDeaths <- cbind(mdeaths, fdeaths)
9 L1 {: J3 C8 X: x9 y4 autoplot(lungDeaths) + geom_forecast() # 图二- v/ `. A5 L0 x) k @6 g
![]()
5 N+ k7 U# p5 _ , h) ]" ?- t7 s( r* u
# e, H3 i0 K, H8 ^0 H6 W5 c13、总结
3 ~. ]' j4 L% U1 Lforecast包里的函数众多,上面只是介绍很少的一部分,更多函数的使用方式留着给大家探索。# Z9 m3 ~8 a+ u/ q
* I+ n# n4 B; c1 Y. W* |; `8 @$ C, z9 ^
14、参考文献7 U% l! n1 Q' K# j! a
https://blog.csdn.net/weixin_46111814/article/details/105348265 ↩︎, [, o. b# p6 J; }& M2 T& d
$ D/ R8 a* |' H3 V* |5 u: D# dhttps://blog.csdn.net/weixin_46111814/article/details/105370507 ↩︎
' M1 s0 c @+ t# R, J4 E2 W' Z: A( g4 v+ k3 Q/ ^
http://127.0.0.1:17627/library/forecast/html/00Index.html ↩︎
K# L. l' X" M9 W0 b————————————————
& F, \- |: ^) X M. ^3 C/ |版权声明:本文为CSDN博主「逆天者顺A」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。' u8 Z7 }; i8 c1 S5 X ]
原文链接:https://blog.csdn.net/weixin_46111814/article/details/105583080- a+ O' \* ?, m5 S; c8 h& a
( ` ]* T- U7 S, n! G/ x* ~- S
# D2 b3 L( Q( D2 k3 ^/ q |
zan
|