The package *smooth* contains several smoothing (exponential and not) functions that are used in forecasting.

Here is the list of included functions:

- es - the ETS function. It can handle exogenous variables and has a handy "holdout" parameter. There are several cost function implemented, including trace forecast based ones. Model selection is done via branch and bound algorithm and there's a possibility to use AIC weights in order to produce combined forecasts. Finally, all the possible ETS functions are implemented here.
- ces - Complex Exponential Smoothing. Function estimates CES and makes forecast. See documentation for details.
- ges - Generalised Exponential Smoothing. Next step from CES. The paper on this is in the process.
- ssarima - SARIMA estimated in state-space framework. Allows multiple seasonalities.
- auto.ces - selection between seasonal and non-seasonal CES models.
- auto.ssarima - selection between different State-Space ARIMA models.
- sim.es - simulation of data using ETS framework with a predefined (or random) smoothing parameters and initial values.
- sim.ssarima - simulation of data using State-Space ARIMA framework with a predefined (or randomly generated) parameters and initial values.
- sim.ces - simulation of data using CES with a predefined (or random) complex smoothing parameters and initial values.
- sma - Simple Moving Average in state-space form.
- iss - Intermittent data state-space model. This function models the part with data occurrences using one of three methods: Croston's, TSB and fixed probability.

Future works:

- sim.ges - simulation functions for GES.
- cma - Centred Moving Average. This should be based on sma(), but would be available for time series decomposition.
- auto.ges - Automatic selection of the most appropriate GES model.
- nus - Non-uniform Smoothing. The estimation method used in order to update parameters of regression models.
- sofa.ts - Survival of the fittest algorithm applied to state-space models.

The stable version of the package is available on CRAN, so you can install it by running: > install.packages("smooth")

A recent, development version, is available via github and can be installed using "devtools" in R. Firstly make sure that you have devtools: > if (!require("devtools")){install.packages("devtools")}

and after that run: > devtools::install_github("config-i1/smooth")

The package depends on Rcpp and RcppArmadillo, which will be installed automatically.

However Mac OS users may need to install gfortran libraries in order to use Rcpp. Follow the link for the instructions: http://www.thecoatlessprofessor.com/programming/rcpp-rcpparmadillo-and-os-x-mavericks-lgfortran-and-lquadmath-error/

Sometimes after upgrade of smooth from previous versions some functions stop working. This is because C++ functions are occasionally stored in deeper unknown coners of R's mind. Restarting R usually solves the problem.