| Type: | Package | 
| Title: | Forecasting Time Series by Theta Models | 
| Version: | 3.0 | 
| Maintainer: | Jose Augusto Fiorucci <jafiorucci@gmail.com> | 
| Description: | Routines for forecasting univariate time series using Theta Models. | 
| License: | GPL-2 | GPL-3 [expanded from: GPL (≥ 2)] | 
| Encoding: | UTF-8 | 
| Depends: | R (≥ 2.0), forecast, tseries, foreach | 
| BugReports: | https://github.com/jafiorucci/forecTheta/issues | 
| RoxygenNote: | 7.3.2 | 
| Suggests: | testthat (≥ 3.0.0) | 
| Config/testthat/edition: | 3 | 
| NeedsCompilation: | no | 
| Packaged: | 2025-05-21 02:52:24 UTC; jafio | 
| Author: | Jose Augusto Fiorucci | 
| Repository: | CRAN | 
| Date/Publication: | 2025-05-21 03:20:02 UTC | 
Forecasting Time Series by Theta Models
Description
This package provides functions for forecasting univariate time series using several Theta models, originally proposed by Assimakopoulos and Nikolopoulos (2000) and later extended by Fiorucci et al. (2016). This version also includes implementations of bagging methods, based on the work of Bergmeir et al. (2016), applied to the DOTM, DSTM, OTM, and STM models.
Details
| Package: | forecTheta | 
| Type: | Package | 
| Version: | 3.0 | 
| Date: | 2025-05-20 | 
| License: | GPL (>=2.0) | 
dotm(y, h)
bagged_dotm(y, h)
stheta(y, h)
errorMetric(obs, forec, type = "sAPE", statistic = "M")
PI_eval(obs, forec, lower_bounds, upper_bounds, name = c("MSIS", "ACD"), alpha = 0.05)
groe(y, forecFunction = ses, g = "sAPE", n1 = length(y)-10)
Author(s)
Jose Augusto Fiorucci, Francisco Louzada, Igor De Oliveira Barros Faluhelyi.
Maintainer: Jose Augusto Fiorucci <jafiorucci@gmail.com>
References
Assimakopoulos, V. and Nikolopoulos k. (2000). The theta model: a decomposition approach to forecasting. International Journal of Forecasting 16, 4, 521–530, <doi:10.1016/S0169-2070(00)00066-2>.
Bergmeir, C., Hyndman, R.J. and Benítez, J. M. (2016). Bagging exponential smoothing methods using STL decomposition and Box–Cox transformation. International journal of forecasting 32 (2), 303–312, <doi:10.1016/j.ijforecast.2015.07.002>.
Fiorucci J.A., Pellegrini T.R., Louzada F., Petropoulos F., Koehler, A. (2016). Models for optimising the theta method and their relationship to state space models, International Journal of Forecasting, 32 (4), 1151–1161, <doi:10.1016/j.ijforecast.2016.02.005>.
Fioruci J.A., Pellegrini T.R., Louzada F., Petropoulos F. (2015). The Optimised Theta Method. arXiv preprint, arXiv:1503.03529.
Gneiting, T. and Raftery, A.E. (2007). Strictly proper scoring rules, prediction, and estimation. Journal of the American Statistical Association 102 (477), 359–378, doi:10.1198/016214506000001437.
Tashman, L.J. (2000). Out-of-sample tests of forecasting accuracy: an analysis and review. International Journal of Forecasting, 16 (4), 437–450, <doi:10.1016/S0169-2070(00)00065-0>.
See Also
dotm, bagged_dotm, stheta, otm.arxiv, groe, rolOrig, fixOrig,
errorMetric
Examples
##############################################################
y1 = 2+ 0.15*(1:20) + rnorm(20)
y2 = y1[20]+ 0.3*(1:30) + rnorm(30)
y =  as.ts(c(y1,y2))
out <- dotm(y, h=10)
summary(out)
plot(out)
out <- dotm(y=as.ts(y[1:40]), h=10)
summary(out)
plot(out)
out2 <- bagged_dotm(y=as.ts(y[1:40]), h=10)
summary(out2)
plot(out2)
out3 <- stheta(y=as.ts(y[1:40]), h=10)
summary(out3)
plot(out3)
### sMAPE metric
errorMetric(obs=as.ts(y[41:50]), forec=out$mean, type = "sAPE", statistic = "M")
errorMetric(obs=as.ts(y[41:50]), forec=out2$mean, type = "sAPE", statistic = "M")
errorMetric(obs=as.ts(y[41:50]), forec=out3$mean, type = "sAPE", statistic = "M")
### sMdAPE metric
errorMetric(obs=as.ts(y[41:50]), forec=out$mean, type = "sAPE", statistic = "Md")
errorMetric(obs=as.ts(y[41:50]), forec=out2$mean, type = "sAPE", statistic = "Md")
errorMetric(obs=as.ts(y[41:50]), forec=out3$mean, type = "sAPE", statistic = "Md")
### MASE metric
meanDiff1 = mean(abs(diff(as.ts(y[1:40]), lag = 1)))
errorMetric(obs=as.ts(y[41:50]), forec=out$mean, type = "AE", statistic = "M") / meanDiff1
errorMetric(obs=as.ts(y[41:50]), forec=out2$mean, type = "AE", statistic = "M") / meanDiff1
errorMetric(obs=as.ts(y[41:50]), forec=out3$mean, type = "AE", statistic = "M") / meanDiff1
Bagged Theta Models
Description
Bagged implementation (Bergmeir et al, 2016) of Dynamic Optimised Theta Model, Dynamic Standard Theta Model, Optimised Theta Model and Standard Theta Model (Fiorucci et al, 2016).
Usage
bagged_dotm(y, h=5, level=c(80,90,95), num_bootstrap = 100, bs_bootstrap = NULL,
  s_type="multiplicative", s_test="default", lambda=NULL,
  par_ini=c(y[1]/2, 0.5, 2),	estimation=TRUE, lower=c(-1e+10, 0.1, 1.0),
  upper=c(1e+10, 0.99, 1e+10), opt.method="Nelder-Mead", xreg=NULL)
bagged_dstm(y, h=5, level=c(80,90,95), num_bootstrap = 100, bs_bootstrap = NULL,
  s_type="multiplicative", s_test="default", lambda=NULL, par_ini=c(y[1]/2, 0.5),
  estimation=TRUE, lower=c(-1e+10, 0.1), upper=c(1e+10, 0.99),
  opt.method="Nelder-Mead", xreg=NULL)
bagged_otm(y, h=5, level=c(80,90,95), num_bootstrap = 100, bs_bootstrap = NULL,
  s_type="multiplicative", s_test="default", lambda=NULL, par_ini=c(y[1]/2, 0.5, 2),
  estimation=TRUE, lower=c(-1e+10, 0.1, 1.0), upper=c(1e+10, 0.99, 1e+10),
  opt.method="Nelder-Mead", xreg=NULL)
bagged_stm(y, h=5, level=c(80,90,95), num_bootstrap = 100, bs_bootstrap = NULL,
  s_type="multiplicative", s_test="default", lambda=NULL, par_ini=c(y[1]/2, 0.5),
  estimation=TRUE, lower=c(-1e+10, 0.1), upper=c(1e+10, 0.99),
  opt.method="Nelder-Mead", xreg=NULL)
Arguments
| y | Object of time series class. | 
| h | Number of required forecasting periods. | 
| level | Levels for prediction intervals. | 
| num_bootstrap | Number of bootstrap samples to be considered in the forecast ( | 
| bs_bootstrap | Block size for bootstrap samples to be considered in the forecast ( | 
| s_type | Use  | 
| s_test | If  | 
| lambda | Parameter for Box-Cox transformation ( | 
| par_ini | Vector of initialization for  | 
| estimation | If  | 
| lower | The lower limit of parametric space. | 
| upper | The upper limit of parametric space. | 
| opt.method | The numeric optimisation method for  | 
| xreg | A matrix with the regressor variables including the out-of-sample data. | 
Details
This version allows bagging to be used in conjunction with the models DOTM, DSTM, OTM and STM (Fiorucci et al, 2016), which usually generates considerably more accurate results, whether point or interval forecasts. In this case, Box-Cox and Loess-based decomposition bootstrap (BLD-MBB) is used, for details see Bergmeir et al, 2016.
If num_bootstrap > 1, then the bagged series are extrapolated through simulation. In the end, point forecasts are calculated as the mean ($mean) or the median ($median) of these series, while interval forecasts are computed based on quantiles. To ensure a substantial number of simulations, each bagged series can be extrapolated multiple times through simulation, aiming for a total simulation volume of at least 10,000 series.
By default, the 90% significance seasonal Z-test, used by Assimakopoulos and Nikolopoulos (2000), is applied for quarterly and monthly time series. The possibility of first checking the unit root was included because it was pointed out that this test presents many flaws for time series with this characteristic (Fiorucci et al, 2016). In this case, the KPSS test is performed with a significance level of 5% and in the case of a unit root, then the series is differentiated before checking for seasonal behavior.
Value
An object of thetaModel class with one list containing the elements:
| $method | The name of the model/method | 
| $y | The original time series. | 
| $s | A binary indication for seasonal decomposition (original time series). | 
| type | Seasonal decomposition type (original time series). | 
| opt.method | The optimisation method used in the  | 
| $par | The estimated values of  | 
| $weights | The estimated weights values (original time series). | 
| $fitted | A time series element with the fitted points (original time series). | 
| $residuals | A time series element with the residual points (original time series). | 
| $mean | The forecasting values calculed as the mean of bootstrapping simulations. | 
| $median | The forecasting values calculed as the median of bootstrapping simulations. | 
| $level | The levels for prediction intervals. | 
| $lower | Lower limits for prediction intervals. | 
| $upper | Upper limits for prediction intervals. | 
Author(s)
Jose Augusto Fiorucci, Francisco Louzada, Igor De Oliveira Barros Faluhelyi.
References
Assimakopoulos, V. and Nikolopoulos k. (2000). The theta model: a decomposition approach to forecasting. International Journal of Forecasting 16 (4), 521–530, <doi:10.1016/S0169-2070(00)00066-2>.
Bergmeir, C., Hyndman, R.J. and Benítez, J. M. (2016). Bagging exponential smoothing methods using STL decomposition and Box–Cox transformation. International journal of forecasting 32 (2), 303–312, <doi:10.1016/j.ijforecast.2015.07.002>.
Fiorucci J.A., Pellegrini T.R., Louzada F., Petropoulos F., Koehler, A. (2016). Models for optimising the theta method and their relationship to state space models, International Journal of Forecasting, 32 (4), 1151–1161, <doi:10.1016/j.ijforecast.2016.02.005>.
See Also
forecTheta-package, dotm,
dstm, otm,
stm
Examples
#### additive seasonal decomposition ###
x = sin(2*pi*seq(0,9,len=300)) + exp((1:300)/150) + rnorm(mean=100,sd=0.5,n=300)
y = ts(x, frequency=33)
out <- bagged_dotm(y, h=50, s_type='additive', num_bootstrap = 5)
summary(out)
plot(out)
Generalised Rolling Origin Evaluation
Description
This function implements the Generalised Rolling Origin Evaluation of Fioruci et al (2015). Its particular cases include the cross validation methods: Rolling Origin Evaluation and Fixed Origin Evaluation of Tashman(2000).
Usage
	groe(y, forecFunction, g="sAPE", n1=length(y)-10, m=5,
	        H=length(y)-n1, p=1+floor((length(y)-n1)/m), ...)
	rolOrig(y, forecFunction, g="sAPE", n1=length(y)-10, ...)
	fixOrig(y, forecFunction, g="sAPE", n1=length(y)-10, ...)
Arguments
| y | Object of time series class or a vector | 
| forecFunction | A forecasting method as one object of the  | 
| g | The prediction error type of  | 
| n1 | The index of the first origin element. | 
| m | The number of movements of the origin in each update. | 
| H | The number of predictions forward of each origin. | 
| p | The number of origin updates. Default is the maximum. | 
| ... | Additional arguments for  | 
Details
If m=1 is computed the Rolling Origin Evaluation.
If m>=length(y)-n1 is computed the Fixed Origin Evaluation.
Value
The sum of the prediction errors.
Note
The otm.arxiv function use this function for estimate the theta parameter when the theta argument is NULL.
Your computer may go into an infinite looping if you use forecFunction = otm.arxiv without specific a numeric value for the theta argument.
Author(s)
Jose Augusto Fiorucci and Francisco Louzada
References
Fioruci J.A., Pellegrini T.R., Louzada F., Petropoulos F. (2015). The Optimised Theta Method. arXiv preprint, arXiv:1503.03529.
Tashman, L.J. (2000). Out-of-sample tests of forecasting accuracy: an analysis and review. International Journal of Forecasting 16 (4), 437–450.
See Also
forecTheta-package, dotm, otm.arxiv
Examples
y1 = 2+ 0.15*(1:20) + rnorm(20,2)
y2 = y1[20]+ 0.3*(1:30) + rnorm(30,2)
y =  as.ts(c(y1,y2))
## Rolling Origin Evaluation
rolOrig( y=y, forecFunction = dotm, n1=40)
rolOrig( y=y, forecFunction = expSmoot, n1=40)
rolOrig( y=y, forecFunction = stheta, n1=40)
rolOrig( y=y, forecFunction = otm.arxiv, n1=40, theta=3)
## Fixed Origin Evaluation
fixOrig( y=y, forecFunction = dotm, n1=40)
fixOrig( y=y, forecFunction = expSmoot, n1=40)
fixOrig( y=y, forecFunction = stheta, n1=40)
fixOrig( y=y, forecFunction = otm.arxiv, n1=40, theta=3)
## Generalised Rolling Origin Evaluation with two origin updates.
## Where the first is the 40th element and second is the 45th element
groe( y=y, forecFunction = dotm, m=5, n1=40)
groe( y=y, forecFunction = expSmoot, m=5, n1=40)
groe( y=y, forecFunction = stheta, m=5, n1=40)
groe( y=y, forecFunction = otm.arxiv, m=5, n1=40, theta=3)
Error Metric Function
Description
This function implements some of the more used error metrics. These metrics are "sMAPE", "MAPE", "MAE", "MSE" and they respectively versions with median "sMdAPE", "MdAPE", "MdAE", "MdSE".
Usage
	errorMetric(obs, forec, type="sAPE", statistic="M")
Arguments
| obs | A vector or a matrix with the real values. | 
| forec | A vector or a matrix with the estimated values. | 
| type | The error type of "sAPE", "APE", "AE" and "SE". | 
| statistic | The statistic to be returned. Use "M" or "Md" for return the mean or median of the errors. If "N" so a vector with all errors will be returned. | 
Details
The metric sMAPE is obtained using type = "sAPE" and  statistic = "M"
The metric sMdAPE is obtained using type = "sAPE" and  statistic = "Md"
The metric MAPE is obtained using type = "APE" and  statistic = "M"
The metric MdAPE is obtained using type = "APE" and  statistic = "Md"
The metric MAE is obtained using type = "AE" and  statistic = "M"
The metric MdAE is obtained using type = "AE" and  statistic = "Md"
The metric MSE is obtained using type = "SE" and  statistic = "M"
The metric MdSE is obtained using type = "SE" and  statistic = "Md"
Value
If statistic="M" or statistic="Md" it is returned the respectively error metric result.
If statistic="N" so is returned a vector with all errors points according to the chosen error type.
Author(s)
Jose Augusto Fiorucci and Francisco Louzada
See Also
forecTheta-package, PIEval, groe
Examples
##############################################################
y1 = 2+ 0.15*(1:20) + rnorm(20,2)
y2 = y1[20]+ 0.3*(1:30) + rnorm(30,2)
y =  as.ts(c(y1,y2))
out <- dotm(y=as.ts(y[1:40]), h=10)
### sMAPE metric
errorMetric(obs=as.ts(y[41:50]), forec=out$mean)
### sMdAPE metric
errorMetric(obs=as.ts(y[41:50]), forec=out$mean, statistic = "Md")
### MASE metric
meanDiff1 = mean(abs(diff(as.ts(y[1:40]), lag = 1)))
errorMetric(obs=as.ts(y[41:50]), forec=out$mean, type = "AE", statistic = "M") / meanDiff1
Prediction Interval (PI) evaluation
Description
Implementation of Mean Scaled Interval Score (MSIS) and Absolute Coverage Difference (ACD).
Usage
PI_eval(obs, forec, lower_bounds, upper_bounds, name = c("MSIS", "ACD"), alpha = 0.05)
Arguments
| obs | Observed time series values. | 
| forec | Forecasted values corresponding to the observed data. | 
| lower_bounds | Lower bounds of the prediction interval. | 
| upper_bounds | Upper bounds of the prediction interval. | 
| name | Evaluation metric to be used. Options are  | 
| alpha | Significance level for the prediction interval. Default is 0.05. | 
Details
The MSIS is computed by combining the width of the prediction interval with a penalty for observations falling outside the interval. This score is averaged over time and scaled by the mean absolute seasonal difference, following the same approach used for the MASE in the M4 competition, to ensure scale invariance. As a complementary metric, the ACD measures the absolute difference between the empirical and nominal coverage (e.g., 0.95), helping to assess interval reliability.
Value
Returns a numeric value corresponding to the selected evaluation metric (MSIS or ACD).
Author(s)
Jose Augusto Fiorucci, Francisco Louzada, Igor De Oliveira Barros Faluhelyi.
References
Gneiting, T. and Raftery, A.E. (2007). Strictly proper scoring rules, prediction, and estimation. Journal of the American Statistical Association 102 (477), 359–378, doi:10.1198/016214506000001437.
Makridakis, S., Spiliotis, E. and Assimakopoulos, V. (2018). The M4 Competition: 100,000 time series and 61 forecasting methods. International Journal of Forecasting 36 (1), 54–74, doi:10.1016/j.ijforecast.2019.04.014.
See Also
forecTheta-package,
errorMetricFunctions,
dotm,
dstm,
otm,
stm
Examples
y1 <- 2 + 0.15 * (1:20) + rnorm(20)
y2 <- y1[20] + 0.3 * (1:30) + rnorm(30)
y <- as.ts(c(y1, y2))
out <- dotm(y, h = 10)
# MSIS metric
PI_eval(
  obs = y, forec = out$mean,
  lower_bounds = out$lower[, 3], upper_bounds = out$upper[, 3],
  name = "MSIS", alpha = 0.05
)
# ACD metric
PI_eval(
  obs = y, forec = out$mean,
  lower_bounds = out$lower[, 3], upper_bounds = out$upper[, 3],
  name = "ACD", alpha = 0.05
)
Plot forecasts points and prediction intervals for thetaModel objects
Description
Produces a figure of the time series and the forecasts points from Optimised Theta Method.
Usage
## S3 method for class 'thetaModel'
plot(x, ylim=NULL, xlim=NULL, ylab=NULL, xlab=NULL, main=NULL, ...)
Arguments
| x | Object of class “thetaModel”. | 
| ylim | the y limits of the plot. | 
| xlim | the x limits of the plot. | 
| ylab | a label for the y axis. | 
| xlab | a label for the x axis. | 
| main | a main title for the plot. | 
| ... | Other plotting parameters passed to  | 
Value
None. Function produces a plot
Author(s)
Jose A Fiorucci
See Also
Examples
y1 = 2+ 0.15*(1:20) + rnorm(20,2)
y2 = y1[20]+ 0.3*(1:30) + rnorm(30,2)
y =  as.ts(c(y1,y2))
out <- dotm(y, h=10)
plot(out)
Theta Models
Description
Functions for forecast univariate time series using the Dynamic Optimised Theta Model, Dynamic Standard Theta Model, Optimised Theta Model and Standard Theta Model (Fiorucci et al, 2016). We also provide an implementation for the Standard Theta Method (STheta) of Assimakopoulos and Nikolopoulos (2000).
Usage
dotm(y, h=5, level=c(80,90,95),	s_type="multiplicative", s_test="default",
  	lambda=NULL, par_ini=c(y[1]/2, 0.5, 2),	estimation=TRUE,
  	lower=c(-1e+10, 0.1, 1.0), upper=c(1e+10, 0.99, 1e+10),
  	opt.method="Nelder-Mead", xreg=NULL, s=NULL)
dstm(y, h=5, level=c(80,90,95), s_type="multiplicative", s_test="default",
  	lambda=NULL, par_ini=c(y[1]/2, 0.5), estimation=TRUE,
  	lower=c(-1e+10, 0.1), upper=c(1e+10, 0.99),
  	opt.method="Nelder-Mead", xreg=NULL, s=NULL)
otm(y, h=5, level=c(80,90,95), s_type="multiplicative", s_test="default",
  	lambda=NULL, par_ini=c(y[1]/2, 0.5, 2), estimation=TRUE,
  	lower=c(-1e+10, 0.1, 1.0), upper=c(1e+10, 0.99, 1e+10),
  	opt.method="Nelder-Mead", xreg=NULL, s=NULL)
stm(y, h=5, level=c(80,90,95), s_type="multiplicative", s_test="default",
  	lambda=NULL, par_ini=c(y[1]/2, 0.5), estimation=TRUE,
  	lower=c(-1e+10, 0.1), upper=c(1e+10, 0.99),
  	opt.method="Nelder-Mead", xreg=NULL, s=NULL)
stheta(y, h=5, s_type="multiplicative", s_test="default", s=NULL)
Arguments
| y | Object of time series class. | 
| h | Number of required forecasting periods. | 
| level | Levels for prediction intervals. | 
| s_type | Use  | 
| s_test | If  | 
| lambda | Parameter for Box-Cox transformation ( | 
| par_ini | Vector of initialization for  | 
| estimation | If  | 
| lower | The lower limit of parametric space. | 
| upper | The upper limit of parametric space. | 
| opt.method | The numeric optimisation method for  | 
| xreg | A matrix with the regressor variables including the out-of-sample data. | 
| s | The argument  | 
Details
By default, the 90% significance seasonal Z-test, used by Assimakopoulos and Nikolopoulos (2000), is applied for quarterly and monthly time series. The possibility of first checking the unit root was included because it was pointed out that this test presents many flaws for time series with this characteristic (Fiorucci et al, 2016). In this case, the KPSS test is performed with a significance level of 5% and in the case of a unit root, then the series is differentiated before checking for seasonal behavior.
For details of each model see Fiorucci et al, 2016.
If you are looking for the methods presented in the arXiv paper (Fiorucci et al, 2015), see otm.arxiv function.
This version allows bagging to be used in conjunction with these models, see bagged_dotm,
bagged_dstm,
bagged_otm and
bagged_stm functions.
Value
An object of thetaModel class with one list containing the elements:
| $method | The name of the model/method | 
| $y | The original time series. | 
| $s | A binary indication for seasonal decomposition. | 
| type | Classical seasonal decomposition type. | 
| opt.method | The optimisation method used in the  | 
| $par | The estimated values for  | 
| $weights | The estimated weights values. | 
| $fitted | A time series element with the fitted points. | 
| $residuals | A time series element with the residual points. | 
| $mean | The forecasting values. | 
| $level | The levels for prediction intervals. | 
| $lower | Lower limits for prediction intervals. | 
| $upper | Upper limits for prediction intervals. | 
| $tests | The p.value of Teraesvirta Neural Network test applied on unseasoned time series and the p.value of Shapiro-Wilk test applied on unseasoned residuals. | 
Author(s)
Jose Augusto Fiorucci, Francisco Louzada
References
Fiorucci J.A., Pellegrini T.R., Louzada F., Petropoulos F., Koehler, A. (2016). Models for optimising the theta method and their relationship to state space models, International Journal of Forecasting, 32 (4), 1151–1161, <doi:10.1016/j.ijforecast.2016.02.005>.
Assimakopoulos, V. and Nikolopoulos k. (2000). The theta model: a decomposition approach to forecasting. International Journal of Forecasting 16 (4), 521–530, <doi:10.1016/S0169-2070(00)00066-2>.
See Also
forecTheta-package,
bagged_dotm,
bagged_dstm,
bagged_otm,
bagged_stm,
otm.arxiv
Examples
y1 = 2+ 0.15*(1:20) + rnorm(20)
y2 = y1[20]+ 0.3*(1:30) + rnorm(30)
y =  as.ts(c(y1,y2))
out <- dotm(y, h=10)
summary(out)
plot(out)
#### additive seasonal decomposition ###
x = sin(2*pi*seq(0,9,len=300)) + exp((1:300)/150) + rnorm(mean=0,sd=0.5,n=300)
y = ts(x, frequency=33)
out <- dotm(y, h=50, s_type='additive')
summary(out)
plot(out)
# #########################################################
# ######### Reproducing the M3 results by DOTM ############
# #########################################################
#
# library(Mcomp)
# data(M3)
#
# forec = matrix(NA, nrow=3003, ncol=18)
# obs = matrix(NA, nrow=3003, ncol=18) #matrix of the out-sample values
# meanDiff <- rep(1, 3003)
#
# for(i in 1:3003){
#   x=M3[[i]]$x
#   h=M3[[i]]$h
#   out = dotm(x,h,level=NULL)
#   forec[i,1:h] = out$mean
#   obs[i,1:h] = M3[[i]]$xx
#   meanDiff[i] = mean(abs(diff(x, lag = frequency(x))))
# }
#
# ############## sMAPE ###################
# sAPE_matrix = errorMetric(obs=obs, forec=forec, type="sAPE", statistic="N")
# #### Yearly ###
# mean( sAPE_matrix[1:645, 1:6] )
# #### QUARTERLY ###
# mean( sAPE_matrix[646:1401, 1:8] )
# #### MONTHLY ###
# mean( sAPE_matrix[1402:2829, 1:18] )
# #### Other ###
# mean( sAPE_matrix[2830:3003, 1:8] )
# #### ALL ###
# mean( sAPE_matrix, na.rm=TRUE )
# #
# ############# MASE ######################
# AE_matrix = errorMetric(obs=obs, forec=forec, type="AE", statistic="N")
# ASE_matrix=AE_matrix/meanDiff
# #### Yearly ###
# mean( ASE_matrix[1:645, 1:6] )
# #### QUARTERLY ###
# mean( ASE_matrix[646:1401, 1:8] )
# #### MONTHLY ###
# mean( ASE_matrix[1402:2829, 1:18] )
# #### Other ###
# mean( ASE_matrix[2830:3003, 1:8] )
# #### ALL ###
# mean( ASE_matrix, na.rm=TRUE )
# ########################################################
Simple Exponential Smoothing Method
Description
Estimation of Simple Exponential Smoothing Method
Usage
	expSmoot(y, h=5, ell0=NULL, alpha=NULL, lower = c(-1e+10, 0.1), 
	upper = c(1e+10, 0.99))
Arguments
| y | Object of time series class. | 
| h | Number of required forecasting periods. | 
| ell0 | The value of  | 
| alpha | The value of  | 
| lower | The lower limit of parametric space. | 
| upper | The upper limit of parametric space. | 
Value
A list containing the elements:
| $y | The original time series. | 
| $par | The estimated values for  | 
| $mean | The forecasting values | 
| $fitted | A time series element with the fitted points. | 
| $residuals | A time series element with the residual points. | 
Author(s)
Jose Augusto Fiorucci, Francisco Louzada and Bao Yiqi
See Also
forecTheta-package, stheta, dotm
Examples
y1 = 2+ 0.15*(1:20) + rnorm(20,2)
y2 = y1[20]+ 0.3*(1:30) + rnorm(30,2)
y =  as.ts(c(y1,y2))
expSmoot(y, h=10)
Optimised Theta Method
Description
Functions for forecast univariate time series using the Optimised Theta Method presented in the arxiv paper (Fioruci et al, 2015). If the theta parameter is not specified so the Generalised Rolling Origin Evaluation is used for select the theta value over the thetaList argument.
Usage
	otm.arxiv( y, h=5, s=NULL, theta=NULL, tLineExtrap=expSmoot, g="sAPE",
		approach="c", n1=NULL, m=NULL, H=NULL, p=NULL,
		thetaList=seq(from=1,to=5,by=0.5), mc.cores=1, ...)
Arguments
| y | Object of time series class | 
| h | Number of required forecasting periods | 
| s | If  | 
| theta | The value of theta parameter. If  | 
| tLineExtrap | A forecasting function for extrapolation the second theta-line. Default is  | 
| g | The error type that will be used by  | 
| approach | The approach set-up for  | 
| n1 | The first origin for Generalised Rolling Origin Evaluation.
This argument is not used if  | 
| m | The number of movements of the origin in each step. This argument is not used if  | 
| H | The number of predictions in each step. This argument is not used if  | 
| p | The number of origin updates. This argument is not used if  | 
| thetaList | A vector with the possible values for  | 
| mc.cores | Number of cores that will be used for estimate the theta parameter. It is not accepted  | 
| ... | Additional arguments for  | 
Details
These functions are fully automatic, you just need to pass your time series. Particular cases are obtained by:
If theta = 1 the tLineExtrapModel method is computed;
If theta = 2 so the Standard Theta Method of Assimakopoulos and Nikolopoulos (2000) is computed.
By default (s=NULL), the 90% significance seasonal Z-test, used by Assimakopoulos and Nikolopoulos (2000), is applied for quarterly and monthly time series.
Value
An list containing the elements:
| $y | The original time series. | 
| $mean | A time series element with the forecasting points. | 
| $fitted | A time series element with the fitted points. | 
| $residuals | A time series element with the residual points. | 
| $theta | The estimated theta value. | 
| $tLineExtrap_par | The estimated parameters of  | 
| $weights | The estimated weights values. | 
Note
The thetaM function is just a particular case of otm with theta=2.
Author(s)
Jose Augusto Fiorucci, Francisco Louzada
References
Fioruci J.A., Pellegrini T.R., Louzada F., Petropoulos F. (2015). The Optimised Theta Method. arXiv preprint, arXiv:1503.03529.
Assimakopoulos, V. and Nikolopoulos k. (2000). The theta model: a decomposition approach to forecasting. International Journal of Forecasting 16, 4, 521-530.
See Also
forecTheta-package, dotm, groe
Examples
y1 = 2+ 0.15*(1:20) + rnorm(20,2)
y2 = y1[20]+ 0.3*(1:30) + rnorm(30,2)
y =  as.ts(c(y1,y2))
otm.arxiv(y, h=10)
### running the M3-competition data base by OTM approach (a) ###
#require(Mcomp)
#data(M3)
#
#forec = matrix(NA, nrow=3003, ncol=18)
#obs = matrix(NA, nrow=3003, ncol=18) #matrix of the out-sample values
#
#for(i in 1:3003){
#	if(i %% 100 == 0){print(i)}
#	x=M3[[i]]$x
#	h=M3[[i]]$h
#	out = otm.arxiv(x,h,approach='a',tLineExtrap=ses)
#	forec[i,1:h] = out$mean
#	obs[i,1:h] = M3[[i]]$xx
#}
#
#sAPE = errorMetric(obs, forec, type="sAPE", statistic="N") ## sAPE matrix
#
##### sMAPE results ##
### Yearly
#mean( sAPE[1:645, 1:6] )
### QUARTERLY
#mean( sAPE[646:1401, 1:8] )
### MONTHLY
#mean( sAPE[1402:2829, 1:18] )
### Other
#mean( sAPE[2830:3003, 1:8] )
### ALL
#mean( sAPE, na.rm=TRUE )
Statistical test for seasonal behavior
Description
Statistical test for seasonal behavior
Usage
seasonal_test(y, s_test = c("default", "unit_root"))
Arguments
| y | Object of time series class | 
| s_test | If  | 
Details
By default, the 90 The possibility of first checking the unit root was included because it was pointed out that this test presents many flaws for time series with this characteristic (Fiorucci et al, 2016)). In this case, the KPSS test is performed with a significance level of 5
Value
A logical result indicating whether or not seasonal behavior was detected.
References
Fiorucci J.A., Pellegrini T.R., Louzada F., Petropoulos F., Koehler, A. (2016). Models for optimising the theta method and their relationship to state space models, International Journal of Forecasting, 32 (4), 1151–1161, <doi:10.1016/j.ijforecast.2016.02.005>. Assimakopoulos, V. and Nikolopoulos k. (2000). The theta model: a decomposition approach to forecasting. International Journal of Forecasting 16, 4, 521–530, <doi:10.1016/S0169-2070(00)00066-2>.
Examples
seasonal_test(AirPassengers)
seasonal_test(AirPassengers, "unit")