ges() constructs Generalised Exponential Smoothing - pure additive state-space model. It is a part of smooth package.
In this vignette we will use data from Mcomp package, so it is adviced to install it.
Let’s load the necessary packages:
require(smooth)
require(Mcomp)You may note that Mcomp depends on forecast package and if you load both forecast and smooth, then you will have a message that forecast() function is masked from the environment. There is nothing to be worried about - smooth uses this function for consistency purposes and has exactly the same original forecast() as in the forecast package. The inclusion of this function in smooth was done only in order not to include forecast in dependencies of the package.
Generalised Exponential Smoothing is a next step from CES. It is a state-space model in which all the matrices and vectors are estimated. It is very demanding in sample size, but is also insanely flexible.
A simple call by default constructs GES\((1^1,1^m)\), where \(m\) is frequency of the data. So for our example with monthly data N2457, we will have GES\((1^1,1^{12})\):
ges(M3$N2457$x, h=18, holdout=TRUE)## Time elapsed: 0.59 seconds
## Model estimated: GES(1[1],1[12])
## Persistence vector g:
##       [,1]   [,2]
## [1,] 0.257 -1.883
## Transition matrix F: 
##       [,1]  [,2]
## [1,] 0.923 0.003
## [2,] 4.224 1.100
## Measurement vector w: 1.01, 0.102
## Initial values were optimised.
## 22 parameters were estimated in the process
## Residuals standard deviation: 1301.123
## Cost function type: MSE; Cost function value: 1308959.686
## 
## Information criteria:
##      AIC     AICc      BIC 
## 1685.494 1699.170 1742.138 
## Forecast errors:
## MPE: -6.7%; Bias: 29.6%; MAPE: 38%; SMAPE: 34.2%
## MASE: 2.185; sMAE: 89.2%; RelMAE: 0.934; sMSE: 129.2%But some different orders and lags can be specified. For example:
ges(M3$N2457$x, h=18, holdout=TRUE, orders=c(2,1), lags=c(1,12))## Time elapsed: 0.35 seconds
## Model estimated: GES(2[1],1[12])
## Persistence vector g:
##       [,1]  [,2]   [,3]
## [1,] 0.286 0.028 -0.095
## Transition matrix F: 
##       [,1]   [,2]  [,3]
## [1,] 0.793 -0.816 0.228
## [2,] 0.393  0.360 0.175
## [3,] 0.686  0.037 1.090
## Measurement vector w: 0.306, 1.996, 0.691
## Initial values were optimised.
## 30 parameters were estimated in the process
## Residuals standard deviation: 1464.722
## Cost function type: MSE; Cost function value: 1481880.923
## 
## Information criteria:
##      AIC     AICc      BIC 
## 1713.530 1741.712 1790.771 
## Forecast errors:
## MPE: 24%; Bias: 82.4%; MAPE: 35.1%; SMAPE: 44.3%
## MASE: 2.647; sMAE: 108%; RelMAE: 1.131; sMSE: 219.4%Function auto.ges() is not yet implemented in smooth, but manual selection allows to conclude that GES\((1^1)\) has the lowest AIC amongst other possible GES models:
ges(M3$N2457$x, h=18, holdout=TRUE, orders=c(1), lags=c(1), intervals=TRUE)## Time elapsed: 0.12 seconds
## Model estimated: GES(1[1])
## Persistence vector g:
##       [,1]
## [1,] 0.137
## Transition matrix F: 
##       [,1]
## [1,] 1.011
## Measurement vector w: 0.714
## Initial values were optimised.
## 5 parameters were estimated in the process
## Residuals standard deviation: 1430.36
## Cost function type: MSE; Cost function value: 1940469.186
## 
## Information criteria:
##      AIC     AICc      BIC 
## 1689.683 1690.342 1702.556 
## 95% parametric prediction intervals were constructed
## 56% of values are in the prediction interval
## Forecast errors:
## MPE: 15.7%; Bias: 76.4%; MAPE: 37.4%; SMAPE: 42.7%
## MASE: 2.636; sMAE: 107.5%; RelMAE: 1.126; sMSE: 204.4%In theory inclusion of more orders and lags should lead to decrease of MSE. However this is not the case in our implementation, because currently we use linear programming optimisers, which may leave us with suboptimal values in cases when parameter space is wide.
In addition to standard values that other functions accept, GES accepts predefined values for transition matrix, measurement and persistence vectors. For example, something more common can be passed to the function:
    transition <- matrix(c(1,0,0,1,1,0,0,0,1),3,3)
    measurement <- c(1,1,1)
    ges(M3$N2457$x, h=18, holdout=TRUE, orders=c(2,1), lags=c(1,12), transition=transition, measurement=measurement)## Time elapsed: 0.22 seconds
## Model estimated: GES(2[1],1[12])
## Persistence vector g:
##       [,1]  [,2]  [,3]
## [1,] 0.172 0.004 0.083
## Transition matrix F: 
##      [,1] [,2] [,3]
## [1,]    1    1    0
## [2,]    0    1    0
## [3,]    0    0    1
## Measurement vector w: 1, 1, 1
## Initial values were optimised.
## 18 parameters were estimated in the process
## 12 parameters were provided
## Residuals standard deviation: 1559.733
## Cost function type: MSE; Cost function value: 1981326.617
## 
## Information criteria:
##      AIC     AICc      BIC 
## 1717.704 1726.473 1764.049 
## Forecast errors:
## MPE: 14.4%; Bias: 74.6%; MAPE: 34.5%; SMAPE: 39.1%
## MASE: 2.456; sMAE: 100.2%; RelMAE: 1.049; sMSE: 183.6%The resulting model will be equivalent to ETS(A,A,A). However due to different initialisation of optimisers and different method of number of parameters calculation, ges() above and es(y, "AAA", h=h, holdout=TRUE) will lead to different models.