ALM stands for “Advanced Linear Model”. It’s not so much advanced as it sounds, but it has some advantages over the basic LM, retaining some basic features. In some sense alm() resembles the glm() function from stats package, but with a higher focus on forecasting rather than on hypothesis testing. You will not get p-values anywhere from the alm() function and won’t see \(R^2\) in the outputs. The maximum what you can count on is having confidence intervals for the parameters or for the regression line. The other important difference from glm() is the availability of distributions that are not supported by glm() (for example, Folded Normal or Chi Squared distributions). Finally, alm() supports different loss functions via the loss parameter, so you can estimate parameters of your model via, for example, likelihood maximisation or via minimisation of MSE / MAE, using LASSO / RIDGE or by minimising a loss provided by user.
Although alm() supports various loss functions, the core of the function is the likelihood approach. By default the estimation of parameters in the model is done via the maximisation of likelihood function of a selected distribution. The calculation of the standard errors is done based on the calculation of hessian of the distribution. And in the centre of all of that are information criteria that can be used for the models comparison.
This vignette contains the following sections:
All the supported distributions have specific functions which form the following four groups for the distribution parameter in alm():
All of them rely on respective d- and p- functions in R. For example, Log Normal distribution uses dlnorm() function from stats package.
The alm() function also supports occurrence parameter, which allows modelling non-zero values and the occurrence of non-zeroes as two different models. The combination of any distribution from (1) - (3) for the non-zero values and a distribution from (4) for the occurrence will result in a mixture distribution model, e.g. a mixture of Log-Normal and Cumulative Logistic or a Hurdle Poisson (with Cumulative Normal for the occurrence part).
Every model produced using alm() can be represented as: \[\begin{equation} \label{eq:basicALM}
    y_t = f(\mu_t, \epsilon_t) = f(x_t' B, \epsilon_t) ,
\end{equation}\] where \(y_t\) is the value of the response variable, \(x_t\) is the vector of exogenous variables, \(B\) is the vector of the parameters, \(\mu_t\) is the conditional mean (produced based on the exogenous variables and the parameters of the model), \(\epsilon_t\) is the error term on the observation \(t\) and \(f(\cdot)\) is the distribution function that does a transformation of the inputs into the output. In case of a mixture distribution the model becomes slightly more complicated: \[\begin{equation} \label{eq:basicALMMixture}
    \begin{matrix}
        y_t = o_t f(x_t' B, \epsilon_t) \\
        o_t \sim \mathcal{Bernoulli}(p_t) \\
        p_t = g(z_t' A)
    \end{matrix},
\end{equation}\] where \(o_t\) is the binary variable, \(p_t\) is the probability of occurrence, \(z_t\) is the vector of exogenous variables and \(A\) is the vector of parameters for the \(p_t\).
The alm() function returns, along with the set of common for lm() variables (such as coefficient and fitted.values), the variable mu, which corresponds to the conditional mean used inside the distribution, and scale – the second parameter, which usually corresponds to standard error or dispersion parameter. The values of these two variables vary from distribution to distribution. Note, however, that the model variable returned by lm() function was renamed into data in alm(), and that alm() does not return terms and QR decomposition.
Given that the parameters of any model in alm() are estimated via likelihood, it can be assumed that they have asymptotically normal distribution, thus the confidence intervals for any model rely on the normality and are constructed based on the unbiased estimate of variance, extracted using sigma() function.
The covariance matrix of parameters almost in all the cases is calculated as an inverse of the hessian of respective distribution function. The exclusions are Normal, Log-Normal, Poisson, Cumulative Logistic and Cumulative Normal distributions, that use analytical solutions.
alm() function also supports factors in the explanatory variables, creating the set of dummies from them. In case of ordered variables (ordinal scale, is.ordered()), the ordering is removed and the set of dummies is produced. This is done in order to avoid the built in behaviour of R, which creates linear, squared, cubic etc levels for ordered variables, which makes the interpretation of the parameters difficult.
When the number of estimated parameters is calculated, in case of loss=="likelihood" the scale is considered as one of the parameters as well, which aligns with the idea of the maximum likelihood estimation. For all the other losses, the scale does not count (this aligns, for example, with how the number of parameters is calculated in OLS, which corresponds to loss="MSE").
Although the basic principles of estimation of models and predictions from them are the same for all the distributions, each of the distribution has its own features. So it makes sense to discuss them individually. We discuss the distributions in the four groups mentioned above.
This group of functions includes:
For all the functions in this category resid() method returns \(e_t = y_t - \mu_t\).
The density of normal distribution is: \[\begin{equation} \label{eq:Normal} f(y_t) = \frac{1}{\sqrt{2 \pi \sigma^2}} \exp \left( -\frac{\left(y_t - \mu_t \right)^2}{2 \sigma^2} \right) , \end{equation}\] where \(\sigma^2\) is the variance of the error term.
alm() with Normal distribution (distribution="dnorm") is equivalent to lm() function from stats package and returns roughly the same estimates of parameters, so if you are concerned with the time of calculation, I would recommend reverting to lm().
Maximising the likelihood of the model is equivalent to the estimation of the basic linear regression using Least Squares method: \[\begin{equation} \label{eq:linearModel} y_t = \mu_t + \epsilon_t = x_t' B + \epsilon_t, \end{equation}\] where \(\epsilon_t \sim \mathcal{N}(0, \sigma^2)\).
The variance \(\sigma^2\) is estimated in alm() based on likelihood: \[\begin{equation} \label{eq:sigmaNormal}
    \hat{\sigma}^2 = \frac{1}{T} \sum_{t=1}^T \left(y_t - \mu_t \right)^2 ,
\end{equation}\] where \(T\) is the sample size. Its square root (standard deviation) is used in the calculations of dnorm() function, and the value is then return via scale variable. This value does not have bias correction. However the sigma() method applied to the resulting model, returns the bias corrected version of standard deviation. And vcov(), confint(), summary() and predict() rely on the value extracted by sigma().
\(\mu_t\) is returned as is in mu variable, and the fitted values are set equivalent to mu.
In order to produce confidence intervals for the mean (predict(model, newdata, interval="confidence")) the conditional variance of the model is calculated using: \[\begin{equation} \label{eq:varianceNormalForCI}
    V({\mu_t}) = x_t V(B) x_t',
\end{equation}\] where \(V(B)\) is the covariance matrix of the parameters returned by the function vcov. This variance is then used for the construction of the confidence intervals of a necessary level \(\alpha\) using the distribution of Student: \[\begin{equation} \label{eq:intervalsNormal}
    y_t \in \left(\mu_t \pm \tau_{df,\frac{1+\alpha}{2}} \sqrt{V(\mu_t)} \right),
\end{equation}\] where \(\tau_{df,\frac{1+\alpha}{2}}\) is the upper \({\frac{1+\alpha}{2}}\)-th quantile of the Student’s distribution with \(df\) degrees of freedom (e.g. with \(\alpha=0.95\) it will be 0.975-th quantile, which, for example, for 100 degrees of freedom will be \(\approx 1.984\)).
Similarly for the prediction intervals (predict(model, newdata, interval="prediction")) the conditional variance of the \(y_t\) is calculated: \[\begin{equation} \label{eq:varianceNormalForPI}
    V(y_t) = V(\mu_t) + s^2 ,
\end{equation}\] where \(s^2\) is the bias-corrected variance of the error term, calculated using: \[\begin{equation} \label{eq:varianceNormalUnbiased}
    s^2 = \frac{1}{T-k} \sum_{t=1}^T \left(y_t - \mu_t \right)^2 ,
\end{equation}\] where \(k\) is the number of estimated parameters (including the variance itself). This value is then used for the construction of the prediction intervals of a specify level, also using the distribution of Student, in a similar manner as with the confidence intervals.
Laplace distribution has some similarities with the Normal one: \[\begin{equation} \label{eq:Laplace} f(y_t) = \frac{1}{2 s} \exp \left( -\frac{\left| y_t - \mu_t \right|}{s} \right) , \end{equation}\] where \(s\) is the scale parameter, which, when estimated using likelihood, is equal to the mean absolute error: \[\begin{equation} \label{eq:bLaplace} \hat{s} = \frac{1}{T} \sum_{t=1}^T \left| y_t - \mu_t \right| . \end{equation}\] So maximising the likelihood is equivalent to estimating the linear regression via the minimisation of \(s\) . So when estimating a model via minimising \(s\), the assumption imposed on the error term is \(\epsilon_t \sim \mathcal{Laplace}(0, s)\). The main difference of Laplace from Normal distribution is its fatter tails.
alm() function with distribution="dlaplace" returns mu equal to \(\mu_t\) and the fitted values equal to mu. \(s\) is returned in the scale variable. The prediction intervals are derived from the quantiles of Laplace distribution after transforming the conditional variance into the conditional scale parameter \(s\) using the connection between the two in Laplace distribution: \[\begin{equation} \label{eq:bLaplaceAndSigma}
    s = \sqrt{\frac{\sigma^2}{2}},
\end{equation}\] where \(\sigma^2\) is substituted either by the conditional variance of \(\mu_t\) or \(y_t\).
The kurtosis of Laplace distribution is 6, making it suitable for modelling rarely occurring events.
Asymmetric Laplace distribution can be considered as a two Laplace distributions with different parameters \(s\) for left and right side. There are several ways to summarise the probability density function, the one used in alm() relies on the asymmetry parameter \(\alpha\) (Yu and Zhang 2005): \[\begin{equation} \label{eq:ALaplace}
    f(y_t) = \frac{\alpha (1- \alpha)}{s} \exp \left( -\frac{y_t - \mu_t}{s} (\alpha - I(y_t \leq \mu_t)) \right) ,
\end{equation}\] where \(s\) is the scale parameter, \(\alpha\) is the skewness parameter and \(I(y_t \leq \mu_t)\) is the indicator function, which is equal to one, when the condition is satisfied and to zero otherwise. The scale parameter \(s\) estimated using likelihood is equal to the quantile loss: \[\begin{equation} \label{eq:bALaplace}
    \hat{s} = \frac{1}{T} \sum_{t=1}^T \left(y_t - \mu_t \right)(\alpha - I(y_t \leq \mu_t)) .
\end{equation}\] Thus maximising the likelihood  is equivalent to estimating the linear regression  via the minimisation of \(\alpha\) quantile, making this equivalent to quantile regression. So quantile regression models assume indirectly that the error term is \(\epsilon_t \sim \mathcal{ALaplace}(0, s, \alpha)\) (Geraci and Bottai 2007). The advantage of using alm() in this case is in having the full distribution, which allows to do all the fancy things you can do when you have likelihood.
In case of \(\alpha=0.5\) the function reverts to the symmetric Laplace where \(s=\frac{1}{2}\text{MAE}\).
alm() function with distribution="dalaplace" accepts an additional parameter alpha in ellipsis, which defines the quantile \(\alpha\). If it is not provided, then the function will estimated it maximising the likelihood and return it as the first coefficient. alm() returns mu equal to \(\mu_t\) and the fitted values equal to mu. \(s\) is returned in the scale variable. The parameter \(\alpha\) is returned in the variable other of the final model. The prediction intervals are produced using qalaplace() function. In order to find the values of \(s\) for the holdout the following connection between the variance of the variable and the scale in Asymmetric Laplace distribution is used: \[\begin{equation} \label{eq:bALaplaceAndSigma}
    s = \sqrt{\sigma^2 \frac{\alpha^2 (1-\alpha)^2}{(1-\alpha)^2 + \alpha^2}},
\end{equation}\] where \(\sigma^2\) is substituted either by the conditional variance of \(\mu_t\) or \(y_t\).
The S distribution has the following density function: \[\begin{equation} \label{eq:S} f(y_t) = \frac{1}{4 s^2} \exp \left( -\frac{\sqrt{|y_t - \mu_t|}}{s} \right) , \end{equation}\] where \(s\) is the scale parameter. If estimated via maximum likelihood, the scale parameter is equal to: \[\begin{equation} \label{eq:bS} \hat{s} = \frac{1}{2T} \sum_{t=1}^T \sqrt{\left| y_t - \mu_t \right|} , \end{equation}\] which corresponds to the minimisation of a half of “Mean Root Absolute Error” or “Half Absolute Moment”.
S distribution has a kurtosis of 25.2, which makes it a “severe excess” distribution (thus the name). It might be useful in cases of randomly occurring incidents and extreme values (Black Swans?).
alm() function with distribution="ds" returns \(\mu_t\) in the same variables mu and fitted.values, and \(s\) in the scale variable. Similarly to the previous functions, the prediction intervals are based on the qs() function from greybox package and use the connection between the scale and the variance: \[\begin{equation} \label{eq:bSAndSigma}
    s = \left( \frac{\sigma^2}{120} \right) ^{\frac{1}{4}},
\end{equation}\] where once again \(\sigma^2\) is substituted either by the conditional variance of \(\mu_t\) or \(y_t\).
The Generalised Normal distribution is a generalisation, which has Normal, Laplace and S as special cases. It has the following density function: \[\begin{equation} \label{eq:gnormal} f(y_t) = \frac{\beta}{2\alpha \Gamma(1/\beta)}\exp\left(-\left(\frac{|y_t - \mu|}{\alpha}\right)^\beta\right), \end{equation}\] where \(\alpha\) is the scale and \(\beta\) is the shape parameters. If estimated via maximum likelihood, the scale parameter is equal to: \[\begin{equation} \label{eq:gnormalScale} \hat{\alpha} = \sqrt[^\beta]{\frac{\beta}{T} \sum_{t=1}^T \left| y_t - \mu_t \right|^{\beta}} . \end{equation}\] In the special cases, this becomes either \(\sqrt{2}\times\)RMSE (\(\beta=2\)), or MAE (\(\beta=1\)) or a half of HAM (\(\beta=0.5\)). It is important to note that although in case of \(\beta=2\), the distribution becomes equivalent to Normal, the scale of it will differ from the \(\sigma\) (this follows directly from the formula above). The relations between the two is: \(\alpha^2 = 2 \sigma^2\).
The kurtosis of Generalised Normal distribution is determined by \(\beta\) and is equal to \(\frac{\Gamma(5/\beta)\Gamma(1/\beta)}{\Gamma(3/\beta)^2}\).
alm() function with distribution="dgnorm" returns \(\mu_t\) in the same variables mu and fitted.values, \(\alpha\) in the scale variable and \(\beta\) in other$beta. Note that if beta is not provided in the function, then it will estimate it. However, the estimates of \(\beta\) are known not to be consistent and asymptotically normal if it is less than 2. So, use with care! As for the intervals, they are based on the internal qgnorm() function based on gnorm v1.0.2 package (not available on CRAN) and use the connection between the scale and the variance: \[\begin{equation} \label{eq:gnormalAlphaAndSigma}
    \alpha = \left( \frac{\sigma^2 \Gamma(1/\beta)}{\Gamma(3/\beta)} \right) ^{\frac{1}{2}},
\end{equation}\] where once again \(\sigma^2\) is substituted either by the conditional variance of \(\mu_t\) or \(y_t\), depending on what type of interval is needed.
The density function of Logistic distribution is: \[\begin{equation} \label{eq:Logistic}
    f(y_t) = \frac{\exp \left(- \frac{y_t - \mu_t}{s} \right)} {s \left( 1 + \exp \left(- \frac{y_t - \mu_t}{s} \right) \right)^{2}},
\end{equation}\] where \(s\) is the scale parameter, which is estimated in alm() based on the connection between the parameter and the variance in the logistic distribution: \[\begin{equation} \label{eq:sLogisticAndSigma}
    \hat{s} = \sigma \sqrt{\frac{3}{\pi^2}}.
\end{equation}\] Once again the maximisation of  implies the estimation of the linear model , where \(\epsilon_t \sim \mathcal{Logistic}(0, s)\).
Logistic is considered a fat tailed distribution, but its tails are not as fat as in Laplace. Kurtosis of standard Logistic is 4.2.
alm() function with distribution="dlogis" returns \(\mu_t\) in mu and in fitted.values variables, and \(s\) in the scale variable. Similar to Laplace distribution, the prediction intervals use the connection between the variance and scale, and rely on the qlogis function.
The Student t distribution has a difficult density function: \[\begin{equation} \label{eq:T} f(y_t) = \frac{\Gamma\left(\frac{\nu+1}{2}\right)}{\sqrt{\nu \pi} \Gamma\left(\frac{\nu}{2}\right)} \left( 1 + \frac{x^2}{\nu} \right)^{-\frac{\nu+1}{2}} , \end{equation}\] where \(\nu\) is the number of degrees of freedom, which can also be considered as the scale parameter of the distribution. It has the following connection with the in-sample variance of the error (but only for the case, when \(\nu>2\)): \[\begin{equation} \label{eq:scaleOfT} \nu = \frac{2}{1-\sigma^{-2}}. \end{equation}\]
Kurtosis of Student t distribution depends on the value of \(\nu\), and for the cases of \(\nu>4\) is equal to \(\frac{6}{\nu-4}\).
alm() function with distribution="dt" estimates the parameters of the model along with the \(\nu\) (if it is not provided by the user as a nu parameter) and returns \(\mu_t\) in the variables mu and fitted.values, and \(\nu\) in the scale variable. Both prediction and confidence intervals use qt() function from stats package and rely on the conventional number of degrees of freedom \(T-k\). The intervals are constructed similarly to how it is done in Normal distribution  (based on qt() function).
In order to see how this works, we will create the following data:
xreg <- cbind(rnorm(100,10,3),rnorm(100,50,5))
xreg <- cbind(500+0.5*xreg[,1]-0.75*xreg[,2]+rs(100,0,3),xreg,rnorm(100,300,10))
colnames(xreg) <- c("y","x1","x2","Noise")
inSample <- xreg[1:80,]
outSample <- xreg[-c(1:80),]ALM can be run either with data frame or with matrix. Here’s an example with normal distribution and several levels for the construction of prediction interval:
ourModel <- alm(y~x1+x2, data=inSample, distribution="dnorm")
summary(ourModel)
#> Response variable: y
#> Distribution used in the estimation: Normal
#> Loss function used in estimation: likelihood
#> Coefficients:
#>             Estimate Std. Error Lower 2.5% Upper 97.5%
#> (Intercept) 384.7448    82.4106   220.6100    548.8797
#> x1            2.8710     2.8772    -2.8595      8.6014
#> x2            0.8686     1.6157    -2.3493      4.0865
#> 
#> Error standard deviation: 67.3323
#> Sample size: 80
#> Number of estimated parameters: 4
#> Number of degrees of freedom: 76
#> Information criteria:
#>      AIC     AICc      BIC     BICc 
#> 904.4691 905.0024 913.9972 915.1657
plot(predict(ourModel,outSample,interval="p",level=c(0.9,0.95)))And here’s an example with Asymmetric Laplace and predefined \(\alpha=0.95\):
ourModel <- alm(y~x1+x2, data=inSample, distribution="dalaplace",alpha=0.95)
summary(ourModel)
#> Warning: Choleski decomposition of hessian failed, so we had to revert to the simple inversion.
#> The estimate of the covariance matrix of parameters might be inaccurate.
#> Response variable: y
#> Distribution used in the estimation: Asymmetric Laplace with alpha=0.95
#> Loss function used in estimation: likelihood
#> Coefficients:
#>             Estimate Std. Error Lower 2.5% Upper 97.5%
#> (Intercept) 477.0694     0.0018   477.0659    477.0729
#> x1            1.8340     0.0284     1.7775      1.8905
#> x2            1.2612     0.0018     1.2577      1.2647
#> 
#> Error standard deviation: 124.3672
#> Sample size: 80
#> Number of estimated parameters: 4
#> Number of degrees of freedom: 76
#> Information criteria:
#>       AIC      AICc       BIC      BICc 
#>  996.5696  997.1029 1006.0977 1007.2662
plot(predict(ourModel,outSample))
#> Warning: Choleski decomposition of hessian failed, so we had to revert to the simple inversion.
#> The estimate of the covariance matrix of parameters might be inaccurate.This group includes:
Although (2) and (3) in theory allow having zeroes in data, given that the density function is equal to zero in any specific point, it will be zero in these cases as well. So the alm() will return some solutions for these distributions, but don’t expect anything good. As for (1), it supports strictly positive data.
Log Normal distribution appears when a normally distributed variable is exponentiated. This means that if \(x \sim \mathcal{N}(\mu, \sigma^2)\), then \(\exp x \sim \text{log}\mathcal{N}(\mu, \sigma^2)\). The density function of Log Normal distribution is: \[\begin{equation} \label{eq:LogNormal} f(y_t) = \frac{1}{y_t \sqrt{2 \pi \sigma^2}} \exp \left( -\frac{\left(\log y_t - \mu_t \right)^2}{2 \sigma^2} \right) , \end{equation}\] where the variance estimated using likelihood is: \[\begin{equation} \label{eq:sigmaLogNormal} \hat{\sigma}^2 = \frac{1}{T} \sum_{t=1}^T \left(\log y_t - \mu_t \right)^2 . \end{equation}\] Estimating the model with Log Normal distribution is equivalent to estimating the parameters of log-linear model: \[\begin{equation} \label{eq:logLinearModel} \log y_t = \mu_t + \epsilon_t, \end{equation}\] where \(\epsilon_t \sim \mathcal{N}(0, \sigma^2)\) or: \[\begin{equation} \label{eq:logLinearModelExp} y_t = \exp(\mu_t + \epsilon_t). \end{equation}\]
alm() with distribution="dlnorm" does not transform the provided data and estimates the density directly using dlnorm() function with the estimated mean \(\mu_t\) and the variance . If you need a log-log model, then you would need to take logarithms of the external variables. The \(\mu_t\) is returned in the variable mu, the \(\sigma^2\) is in the variable scale, while the fitted.values contains the exponent of \(\mu_t\), which, given the connection between the Normal and Log Normal distributions, corresponds to median of distribution rather than mean. Finally, resid() method returns \(e_t = \log y_t - \mu_t\).
Box-Cox Normal distribution used in the greybox package is defined as a distribution that becomes normal after the Box-Cox transformations. This means that if \(x=\frac{y^\lambda+1}{\lambda}\), \(x \sim \mathcal{N}(\mu, \sigma^2)\), then \(y \sim \text{BC}\mathcal{N}(\mu, \sigma^2)\). The density function of the Box-Cox Normal distribution in this case is: \[\begin{equation} \label{eq:BCNormal}
    f(y_t) = \frac{y_t^{\lambda-1}} {\sqrt{2 \pi \sigma^2}} \exp \left( -\frac{\left(\frac{y_t^{\lambda}-1}{\lambda} - \mu_t \right)^2}{2 \sigma^2} \right) ,
\end{equation}\] where the variance estimated using likelihood is: \[\begin{equation} \label{eq:sigmaBCNormal}
    \hat{\sigma}^2 = \frac{1}{T} \sum_{t=1}^T \left(\frac{y_t^{\lambda}-1}{\lambda} - \mu_t \right)^2 .
\end{equation}\] Estimating the model with Box-Cox Normal distribution is equivalent to estimating the parameters of a linear model after the Box-Cox transform: \[\begin{equation} \label{eq:BCLinearModel}
    \frac{y_t^{\lambda}-1}{\lambda} = \mu_t + \epsilon_t,
\end{equation}\] where \(\epsilon_t \sim \mathcal{N}(0, \sigma^2)\) or: \[\begin{equation} \label{eq:BCLinearModelExp}
    y_t = \left((\mu_t + \epsilon_t) \lambda +1 \right)^{\frac{1}{\lambda}}.
\end{equation}\]
alm() with distribution="dbcnorm" does not transform the provided data and estimates the density directly using dbcnorm() function from greybox with the estimated mean \(\mu_t\) and the variance . The \(\mu_t\) is returned in the variable mu, the \(\sigma^2\) is in the variable scale, while the fitted.values contains the exponent of \(\mu_t\), which, given the connection between the Normal and Box-Cox Normal distributions, corresponds to median of distribution rather than mean. Finally, resid() method returns \(e_t = \frac{y_t^{\lambda}-1}{\lambda} - \mu_t\). The \(lambda\) parameter can be provided by the user via the lambdaBC in ellipsis.
Inverse Gaussian distribution is an interesting distribution, which is defined for positive values only and has some properties similar to the properties of the Normal distribution. It has two parameters: location \(\mu_t\) and scale \(\phi\) (aka “dispersion”). There are different ways to parameterise this distribution, we use the dispersion-based one. The important thing that distincts the implementation in alm() from the one in glm() or in any other function is that we assume that the model has the following form: \[\begin{equation} \label{eq:InverseGaussianModel}
    y_t = \mu_t \times \epsilon_t 
\end{equation}\] and that \(\epsilon_t \sim \mathcal{IG}(1, \phi)\). This means that \(y_t \sim \mathcal{IG}\left(\mu_t, \frac{\phi}{\mu_t} \right)\), implying that the dispersion of the model changes together with the expectation. The density function for the error term in this case is: \[\begin{equation} \label{eq:InverseGaussian}
    f(\epsilon_t) = \frac{1}{\sqrt{2 \pi \phi \epsilon_t^3}} \exp \left( -\frac{\left(\epsilon_t - 1 \right)^2}{2 \phi \epsilon_t} \right) ,
\end{equation}\] where the dispersion parameter is estimated via maximising the likelihood and is calculated using: \[\begin{equation} \label{eq:InverseGaussianDispersion}
    \hat{\phi} = \frac{1}{T} \sum_{t=1}^T \frac{\left(\epsilon_t - 1 \right)^2}{\epsilon_t} .
\end{equation}\] Note that in our formulation \(\mu_t = \exp\left( x_t' B \right)\), so that the means is always positive. This implies that we deal with a pure multiplicative model. In addition, we assume that \(\mu_t\) is just a scale for the distribution, otherwise \(y_t\) would not follow the Inverse Gaussian distribution.
alm() with distribution="dinvgauss" estimates the density for \(y_t\) using dinvgauss() function from statmod package. The \(\mu_t\) is returned in the variables mu and fitted.values, the dispersion \(\phi\) is in the variable scale. resid() method returns \(e_t = \frac{y_t}{\mu_t}\). Finally, the prediction and confidence intervals for the regression model are generated using qinvgauss() function from the statmod package.
This is based on the exponent of Laplace distribution, which means that the PDF in this case is: \[\begin{equation} \label{eq:lLaplace} f(y_t) = \frac{1}{2 s y_t} \exp \left( -\frac{\left| \log y_t - \mu_t \right|}{s} \right) . \end{equation}\] The model implemented in the package has similarity with Log Normal distribution. The MLE scale is: \[\begin{equation} \label{eq:bLogLaplace} \hat{s} = \frac{1}{T} \sum_{t=1}^T \left|\log y_t - \mu_t \right| . \end{equation}\] Estimating the model with Log Laplace distribution is equivalent to estimating the parameters of log-linear model: \[\begin{equation*} \log y_t = \mu_t + \epsilon_t, \end{equation*}\] where \(\epsilon_t \sim \mathcal{Laplace}(0, \sigma^2)\). This distribution might be useful if the data has a strong skewness (larger than in case of log normal distribution).
alm() with distribution="dllaplace" uses dlaplace() function with the logarithm of actual values, estimated mean \(\mu_t\) and the scale . The \(\mu_t\) is returned in the variable mu, the \(s\) is in the variable scale, while the fitted.values contains the exponent of \(\mu_t\), which corresponds to median of distribution rather than mean. Finally, resid() method returns \(e_t = \log y_t - \mu_t\).
This is based on the exponent of S distribution, giving the PDF: \[\begin{equation} \label{eq:ls} f(y_t) = \frac{1}{4 y_t s^2} \exp \left( -\frac{\sqrt{|\log y_t - \mu_t|}}{s} \right) , \end{equation}\] The model implemented in the package has similarity with Log Normal and Log Laplace distributions. The MLE scale is: \[\begin{equation} \label{eq:bLogS} \hat{s} = \frac{1}{2T} \sum_{t=1}^T \sqrt{\left| \log(y_t) - \mu_t \right|} , \end{equation}\] Estimating the model with Log S distribution is equivalent to estimating the parameters of log-linear model: \[\begin{equation*} \log y_t = \mu_t + \epsilon_t, \end{equation*}\] where \(\epsilon_t \sim \mathcal{S}(0, \sigma^2)\). This distribution can be used for sever seldom right tail cases.
alm() with distribution="dls" uses ds() function with the logarithm of actual values, estimated mean \(\mu_t\) and the scale . The \(\mu_t\) is returned in the variable mu, the \(s\) is in the variable scale, while the fitted.values contains the exponent of \(\mu_t\), which corresponds to median of distribution rather than mean. Finally, resid() method returns \(e_t = \log y_t - \mu_t\).
This is based on the exponent of Generalised Normal distribution, giving the PDF: \[\begin{equation} \label{eq:lgnormal} f(y_t) = \frac{\beta}{2\alpha \Gamma(1/\beta)y_t}\exp\left(-\left(\frac{|\log(y_t) - \mu|}{\alpha}\right)^\beta\right), \end{equation}\] The model implemented in the package has similarity with Log Normal, Log Laplace and Log S distributions. The MLE scale is: \[\begin{equation} \label{eq:LogAlpha} \hat{\alpha} = \sqrt[^\beta]{\frac{\beta}{T} \sum_{t=1}^T \left| \log(y_t) - \mu_t \right|^{\beta}} . \end{equation}\] Estimating the model with Log Generalised Normal distribution is equivalent to estimating the parameters of log-linear model: \[\begin{equation*} \log y_t = \mu_t + \epsilon_t, \end{equation*}\] where \(\epsilon_t \sim \mathcal{GN}(0, \alpha, \beta)\).
alm() with distribution="dlgnorm" uses the internal implementation of dgnorm() function from gnorm package v1.0.2 (not available on CRAN) with the logarithm of actual values, estimated mean \(\mu_t\), the scale  and either provided or estimated shape parameter \(\beta\). The \(\mu_t\) is returned in the variable mu, the \(\alpha\) is in the variable scale and \(\beta\) is in other$beta, while the fitted.values contains the exponent of \(\mu_t\), which corresponds to median of distribution rather than mean. Finally, resid() method returns \(e_t = \log y_t - \mu_t\).
Folded Normal distribution is obtained when the absolute value of normally distributed variable is taken: if \(x \sim \mathcal{N}(\mu, \sigma^2)\), then \(|x| \sim \text{folded }\mathcal{N}(\mu, \sigma^2)\). The density function is: \[\begin{equation} \label{eq:foldedNormal}
    f(y_t) = \frac{1}{\sqrt{2 \pi \sigma^2}} \left( \exp \left( -\frac{\left(y_t - \mu_t \right)^2}{2 \sigma^2} \right) + \exp \left( -\frac{\left(y_t + \mu_t \right)^2}{2 \sigma^2} \right) \right),
\end{equation}\] Conditional mean and variance of Folded Normal are estimated in alm() (with distribution="dfnorm") similarly to how this is done for Normal distribution. They are returned in the variables mu and scale respectively. In order to produce the fitted value (which is returned in fitted.values), the following correction is done: \[\begin{equation} \label{eq:foldedNormalFitted}
    \hat{y_t} = \sqrt{\frac{2}{\pi}} \sigma \exp \left( -\frac{\mu_t^2}{2 \sigma^2} \right) + \mu_t \left(1 - 2 \Phi \left(-\frac{\mu_t}{\sigma} \right) \right),
\end{equation}\] where \(\Phi(\cdot)\) is the CDF of Normal distribution.
The model that is assumed in the case of Folded Normal distribution can be summarised as: \[\begin{equation} \label{eq:foldedNormalModel} y_t = \left| \mu_t + \epsilon_t \right|. \end{equation}\]
The conditional variance of the forecasts is calculated based on the elements of vcov() (as in all the other functions), the predicted values are corrected in the same way as the fitted values , and the prediction intervals are generated from the qfnorm() function of greybox package. As for the residuals, resid() method returns \(e_t = y_t - \mu_t\).
There is currently only one distribution in this group:
Beta distribution is a distribution for a continuous variable that is defined on the interval of \((0, 1)\). Note that the bounds are not included here, because the probability density function is not well defined on them. If the provided data contains either zeroes or ones, the function will modify the values using: \[\begin{equation} \label{eq:BetaWarning} y^\prime_t = y_t (1 - 2 \cdot 10^{-10}), \end{equation}\] and it will warn the user about this modification. This correction makes sure that there are no boundary values in the data, and it is quite artificial and needed for estimation purposes only.
The density function of Beta distribution has the form: \[\begin{equation} \label{eq:Beta}
    f(y_t) = \frac{y_t^{\alpha_t-1}(1-y_t)^{\beta_t-1}}{B(\alpha_t, \beta_t)} ,
\end{equation}\] where \(\alpha_t\) is the first shape parameter and \(\beta_t\) is the second one. Note indices for the both shape parameters. This is what makes the alm() implementation of Beta distribution different from any other. We assume that both of them have underlying deterministic models, so that: \[\begin{equation} \label{eq:BetaAt}
    \alpha_t = \exp(x_t' A) ,
\end{equation}\] and \[\begin{equation} \label{eq:BetaBt}
    \beta_t = \exp(x_t' B),
\end{equation}\] where \(A\) and \(B\) are the vectors of parameters for the respective shape variables. This allows the function to model any shapes depending on the values of exogenous variables. The conditional expectation of the model is calculated using: \[\begin{equation} \label{eq:BetaExpectation}
    \hat{y}_t = \frac{\alpha_t}{\alpha_t + \beta_t} ,
\end{equation}\] while the conditional variance is: \[\begin{equation} \label{eq:BetaVariance}
    \text{V}({y}_t) = \frac{\alpha_t \beta_t}{((\alpha_t + \beta_t)^2 (\alpha_t + \beta_t + 1))} .
\end{equation}\]
alm() function with distribution="dbeta" returns \(\hat{y}_t\) in the variables mu and fitted.values, and \(\text{V}({y}_t)\) in the scale variable. The shape parameters are returned in the respective variables other$shape1 and other$shape2. You will notice that the output of the model contains twice more parameters than the number of variables in the model. This is because of the estimation of two models: \(\alpha_t\)  and \(\beta_t\)  - instead of one.
Respectively, when predict() function is used for the alm model with Beta distribution, the two models are used in order to produce predicted values for \(\alpha_t\) and \(\beta_t\). After that the conditional mean mu and conditional variance variances are produced using the formulae above. The prediction intervals are generated using qbeta function with the provided shape parameters for the holdout. As for the confidence intervals, they are produced assuming normality for the parameters of the model and using the estimate of the variance of the mean based on the variances (which is weird and probably wrong).
This group includes:
These distributions should be used in cases of count data.
Poisson distribution used in ALM has the following standard probability mass function: \[\begin{equation} \label{eq:Poisson} P(X=y_t) = \frac{\lambda_t^{y_t} \exp(-\lambda_t)}{y_t!}, \end{equation}\] where \(\lambda_t = \mu_t = \sigma^2_t = \exp(x_t' B)\). As it can be noticed, here we assume that the variance of the model varies in time and depends on the values of the exogenous variables, which is a specific case of heteroscedasticity. The exponent of \(x_t' B\) is needed in order to avoid the negative values in \(\lambda_t\).
alm() with distribution="dpois" returns mu, fitted.values and scale equal to \(\lambda_t\). The quantiles of distribution in predict() method are generated using qpois() function from stats package. Finally, the returned residuals correspond to \(y_t - \mu_t\), which is not really helpful or meaningful…
Negative Binomial distribution implemented in alm() is parameterised in terms of mean and variance: \[\begin{equation} \label{eq:NegBin}
    P(X=y_t) = \binom{y_t+\frac{\mu_t^2}{\sigma^2-\mu_t}}{y_t} \left( \frac{\sigma^2 - \mu_t}{\sigma^2} \right)^{y_t} \left( \frac{\mu_t}{\sigma^2} \right)^\frac{\mu_t^2}{\sigma^2 - \mu_t},
\end{equation}\] where \(\mu_t = \exp(x_t' B)\) and \(\sigma^2\) is estimated separately in the optimisation process. These values are then used in the dnbinom() function in order to calculate the log-likelihood based on the distribution function.
alm() with distribution="dnbinom" returns \(\mu_t\) in mu and fitted.values and \(\sigma^2\) in scale. The prediction intervals are produces using qnbinom() function. Similarly to Poisson distribution, resid() method returns \(y_t - \mu_t\). The user can also provide size parameter in ellipsis if it is reasonable to assume that it is known.
Round up the response variable for the next example:
Negative Binomial distribution:
ourModel <- alm(y~x1+x2, data=inSample, distribution="dnbinom")
summary(ourModel)
#> Response variable: y
#> Distribution used in the estimation: Negative Binomial with size=49.7177
#> Loss function used in estimation: likelihood
#> Coefficients:
#>             Estimate Std. Error Lower 2.5% Upper 97.5%
#> (Intercept)   5.9438     0.0304     5.8833      6.0043
#> x1            0.0066     0.0024     0.0018      0.0114
#> x2            0.0023     0.0007     0.0008      0.0038
#> 
#> Error standard deviation: 67.797
#> Sample size: 80
#> Number of estimated parameters: 5
#> Number of degrees of freedom: 75
#> Information criteria:
#>      AIC     AICc      BIC     BICc 
#> 912.2188 913.0296 924.1289 925.9054And an example with predefined size:
ourModel <- alm(y~x1+x2, data=inSample, distribution="dnbinom", size=30)
summary(ourModel)
#> Response variable: y
#> Distribution used in the estimation: Negative Binomial with size=30
#> Loss function used in estimation: likelihood
#> Coefficients:
#>             Estimate Std. Error Lower 2.5% Upper 97.5%
#> (Intercept)   5.9215     0.0385     5.8448      5.9982
#> x1            0.0055     0.0030    -0.0006      0.0115
#> x2            0.0030     0.0009     0.0011      0.0049
#> 
#> Error standard deviation: 67.3793
#> Sample size: 80
#> Number of estimated parameters: 4
#> Number of degrees of freedom: 76
#> Information criteria:
#>      AIC     AICc      BIC     BICc 
#> 917.6568 918.1901 927.1849 928.3534The final class of models includes two cases:
In both of them it is assumed that the response variable is binary and can be either zero or one. The main idea for this class of models is to use a transformation of the original data and link a continuous latent variable with the binary one. As a reminder, all the models eventually assume that: \[\begin{equation} \label{eq:basicALMCumulative}
    \begin{matrix}
        o_t \sim \mathcal{Bernoulli}(p_t) \\
        p_t = g(x_t' A)
    \end{matrix},
\end{equation}\] where \(o_t\) is the binary response variable and \(g(\cdot)\) is the cumulative distribution function. Given that we work with the probability of occurrence, the predict() method produces forecasts for the probability of occurrence rather than the binary variable itself. Finally, although many other cumulative distribution functions can be used for this transformation (e.g. plaplace() or plnorm()), the most popular ones are logistic and normal CDFs.
Given that the binary variable has Bernoulli distribution, its log-likelihood is: \[\begin{equation} \label{eq:BernoulliLikelihood} \ell(p_t | o_t) = \sum_{o_t=1} \log p_t + \sum_{o_t=0} \log(1 - p_t), \end{equation}\] So the estimation of parameters for all the CDFs can be done maximising this likelihood.
In all the functions it is assumed that the probability \(p_t\) corresponds to some sort of unobservable `level’ \(q_t = x_t' A\), and that there is no randomness in this level. So the aim of all the functions is to estimate correctly this level and then get an estimate of probability based on it.
The error of the model is calculated using the observed occurrence variable and the estimated probability \(\hat{p}_t\). In a way, in this calculation we assume that \(o_t=1\) happens mainly when the respective estimated probability \(\hat{p}_t\) is very close to one. So, the error can be calculated as: \[\begin{equation} \label{eq:BinaryError} u_t' = o_t - \hat{p}_t . \end{equation}\] However this error is not useful and should be somehow transformed into the original scale of \(q_t\). Given that both \(o_t \in (0, 1)\) and \(\hat{p}_t \in (0, 1)\), the error will lie in \((-1, 1)\). We therefore standardise it so that it lies in the region of \((0, 1)\): \[\begin{equation} \label{eq:BinaryErrorBounded} u_t = \frac{u_t' + 1}{2} = \frac{o_t - \hat{p}_t + 1}{2}. \end{equation}\]
This transformation means that, when \(o_t=\hat{p}_t\), then the error \(u_t=0.5\), when \(o_t=1\) and \(\hat{p}_t=0\) then \(u_t=1\) and finally, in the opposite case of \(o_t=0\) and \(\hat{p}_t=1\), \(u_t=0\). After that this error is transformed using either Logistic or Normal quantile generation function into the scale of \(q_t\), making sure that the case of \(u_t=0.5\) corresponds to zero, the \(u_t>0.5\) corresponds to the positive and \(u_t<0.5\) corresponds to the negative errors. The distribution of the error term is unknown, but it is in general bimodal.
We have previously discussed the density function of logistic distribution. The standardised cumulative distribution function used in alm() is: \[\begin{equation} \label{eq:LogisticCDFALM}
    \hat{p}_t = \frac{1}{1+\exp(-\hat{q}_t)},
\end{equation}\] where \(\hat{q}_t = x_t' A\) is the conditional mean of the level, underlying the probability. This value is then used in the likelihood  in order to estimate the parameters of the model. The error term of the model is calculated using the formula: \[\begin{equation} \label{eq:LogisticError}
    e_t = \log \left( \frac{u_t}{1 - u_t} \right) = \log \left( \frac{1 + o_t (1 + \exp(\hat{q}_t))}{1 + \exp(\hat{q}_t) (2 - o_t) - o_t} \right).
\end{equation}\] This way the error varies from \(-\infty\) to \(\infty\) and is equal to zero, when \(u_t=0.5\).
The alm() function with distribution="plogis" returns \(q_t\) in mu, standard deviation, calculated using the respective errors  in scale and the probability \(\hat{p}_t\) based on  in fitted.values. resid() method returns the errors discussed above. predict() method produces point forecasts and the intervals for the probability of occurrence. The intervals use the assumption of normality of the error term, generating respective quantiles (based on the estimated \(q_t\) and variance of the error) and then transforming them into the scale of probability using Logistic CDF. This method for intervals calculation is approximate and should not be considered as a final solution!
The case of cumulative Normal distribution is quite similar to the cumulative Logistic one. The transformation is done using the standard normal CDF: \[\begin{equation} \label{eq:NormalCDFALM} \hat{p}_t = \Phi(q_t) = \frac{1}{\sqrt{2 \pi}} \int_{-\infty}^{q_t} \exp \left(-\frac{1}{2}x^2 \right) dx , \end{equation}\] where \(q_t = x_t' A\). Similarly to the Logistic CDF, the estimated probability is used in the likelihood in order to estimate the parameters of the model. The error term is calculated using the standardised quantile function of Normal distribution: \[\begin{equation} \label{eq:NormalError} e_t = \Phi \left(\frac{o_t - \hat{p}_t + 1}{2}\right)^{-1} . \end{equation}\] It acts similar to the error from the Logistic distribution, but is based on the different functions.
Similar to the Logistic CDF, the alm() function with distribution="pnorm" returns \(q_t\) in mu, standard deviation, calculated based on the errors  in scale and the probability \(\hat{p}_t\) based on  in fitted.values. resid() method returns the errors discussed above. predict() method produces point forecasts and the intervals for the probability of occurrence. The intervals are also approximate and use the same principle as in Logistic CDF.
Finally, mixture distribution models can be used in alm() by defining distribution and occurrence parameters. Currently only plogis() and pnorm() are supported for the occurrence variable, but all the other distributions discussed above can be used for the modelling of the non-zero values. If occurrence="plogis" or occurrence="pnorm", then alm() is fit two times: first on the non-zero data only (defining the subset) and second - using the same data, substituting the response variable by the binary occurrence variable and specifying distribution=occurrence. As an alternative option, occurrence alm() model can be estimated separately and then provided as a variable in occurrence.
As an example of mixture model, let’s generate some data:
xreg[,1] <- round(exp(xreg[,1]-400) / (1 + exp(xreg[,1]-400)),0) * xreg[,1]
# Sometimes the generated data contains huge values
xreg[is.nan(xreg[,1]),1] <- 0;
inSample <- xreg[1:80,]
outSample <- xreg[-c(1:80),]First, we estimate the occurrence model (it will complain that the response variable is not binary, but it will work):
And then use it for the mixture model:
The occurrence model will be return in the respective variable:
summary(modelMixture)
#> Response variable: y
#> Distribution used in the estimation: Mixture of Log Normal and Cumulative logistic
#> Loss function used in estimation: likelihood
#> Coefficients:
#>             Estimate Std. Error Lower 2.5% Upper 97.5%
#> (Intercept)   6.5850     0.3407     5.9064      7.2636
#> x1            0.0065     0.0042    -0.0019      0.0149
#> x2           -0.0002     0.0024    -0.0050      0.0045
#> Noise        -0.0016     0.0010    -0.0037      0.0004
#> 
#> Error standard deviation: 0.0985
#> Sample size: 80
#> Number of estimated parameters: 5
#> Number of degrees of freedom: 75
#> Information criteria:
#>      AIC     AICc      BIC     BICc 
#> 804.2307 795.0415 828.0510 807.9174
summary(modelMixture$occurrence)
#> Warning: Choleski decomposition of hessian failed, so we had to revert to the simple inversion.
#> The estimate of the covariance matrix of parameters might be inaccurate.
#> Response variable: y
#> Distribution used in the estimation: Cumulative logistic
#> Loss function used in estimation: likelihood
#> Coefficients:
#>             Estimate Std. Error Lower 2.5% Upper 97.5%
#> (Intercept)  34.6766     0.1371    34.4036     34.9496
#> x1           -0.1355     0.0543    -0.2437     -0.0273
#> x2           -0.2588     0.0189    -0.2964     -0.2211
#> Noise        -0.0598     0.0016    -0.0631     -0.0565
#> 
#> Error standard deviation: 1.2275
#> Sample size: 80
#> Number of estimated parameters: 5
#> Number of degrees of freedom: 75
#> Information criteria:
#>     AIC    AICc     BIC    BICc 
#> 83.3630 84.1738 95.2731 97.0496We can also do regression diagnostics using plots:
After that we can produce forecasts using the data from the holdout sample (in this example we also ask for several confidence levels):
predict(modelMixture,outSample,interval="p",level=c(0.8,0.9,0.95))
#> Warning: Choleski decomposition of hessian failed, so we had to revert to the simple inversion.
#> The estimate of the covariance matrix of parameters might be inaccurate.
#>           Mean Lower bound (10%) Lower bound (5%) Lower bound (2.5%)
#>  [1,] 444.5804          417.1707         403.6527           392.3126
#>  [2,] 477.2853          428.1144         414.0438           402.2200
#>  [3,] 359.4104          409.4829         395.1471           383.2809
#>  [4,] 374.5132          414.8642         400.8036           389.1316
#>  [5,] 296.7791          427.1897         411.1861           398.1694
#>  [6,] 443.6541          404.3527         390.7301           379.3024
#>  [7,] 411.2315          421.8599         407.7756           396.0279
#>  [8,] 166.2265          449.9022         429.0808           413.2602
#>  [9,] 418.5715          421.1410         407.2408           395.6296
#> [10,] 430.6982          394.1895         380.9594           369.8616
#> [11,] 455.3592          403.5177         389.7271           378.1491
#> [12,] 452.6734          426.9832         412.8114           400.9366
#> [13,] 462.1728          415.2777         401.4240           389.7899
#> [14,] 345.0523          412.8425         398.3365           386.3656
#> [15,] 451.6178          410.3550         396.9193           385.6345
#> [16,] 447.2782          433.5549         419.2320           407.2449
#> [17,] 420.2362          403.8691         390.4619           379.2384
#> [18,] 473.8279          428.3498         414.3423           402.5738
#> [19,] 426.6260          426.5782         412.4519           400.6495
#> [20,] 349.7415          440.2593         424.2034           411.0143
#>       Upper bound (90%) Upper bound (95%) Upper bound (97.5%)
#>  [1,]          522.2883          539.7793            555.3821
#>  [2,]          541.2079          559.6000            576.0502
#>  [3,]          505.9073          524.2614            540.4922
#>  [4,]          511.4668          529.4097            545.2892
#>  [5,]          515.0824          535.1297            552.6238
#>  [6,]          512.7578          530.6348            546.6218
#>  [7,]          524.5196          542.6361            558.7328
#>  [8,]          500.7358          525.0343            545.1339
#>  [9,]          523.9016          541.7839            557.6845
#> [10,]          499.1346          516.4688            531.9656
#> [11,]          515.5694          533.8129            550.1570
#> [12,]          536.9080          555.3400            571.7879
#> [13,]          526.5850          544.7583            561.0176
#> [14,]          506.5692          525.0167            541.2835
#> [15,]          517.3363          534.8482            550.4994
#> [16,]          542.4281          560.9599            577.4715
#> [17,]          506.4519          523.8418            539.3448
#> [18,]          540.2806          558.5456            574.8737
#> [19,]          531.5171          549.7213            565.9151
#> [20,]          539.7493          560.1787            578.1543If you expect autoregressive elements in the data, then you can specify the order of AR via the respective parameter
modelMixtureAR <- alm(y~x1+x2+Noise, inSample, distribution="dlnorm", occurrence=modelOccurrence, ar=1)
summary(modelMixtureAR)
#> Response variable: y
#> Distribution used in the estimation: Mixture of Log Normal and Cumulative logistic
#> Loss function used in estimation: likelihood
#> ARIMA(1,0,0) components were included in the model
#> Coefficients:
#>             Estimate Std. Error Lower 2.5% Upper 97.5%
#> (Intercept)   6.2030     0.8491     4.5111      7.8950
#> x1            0.0063     0.0042    -0.0022      0.0147
#> x2            0.0000     0.0024    -0.0048      0.0048
#> Noise        -0.0016     0.0010    -0.0037      0.0004
#> yLag1         0.0603     0.1221    -0.1829      0.3036
#> 
#> Error standard deviation: 0.0991
#> Sample size: 80
#> Number of estimated parameters: 6
#> Number of degrees of freedom: 74
#> Information criteria:
#>      AIC     AICc      BIC     BICc 
#> 805.8862 797.0369 832.0885 812.6996
plot(predict(modelMixtureAR,outSample,interval="p",side="u"))
#> Warning: Choleski decomposition of hessian failed, so we had to revert to the simple inversion.
#> The estimate of the covariance matrix of parameters might be inaccurate.If the explanatory variables are not available for the holdout sample, the forecast() function can be used:
plot(forecast(modelMixtureAR, h=10, interval="p",side="u"))
#> Warning: No newdata provided, the values will be forecasted
#> Warning: Choleski decomposition of hessian failed, so we had to revert to the simple inversion.
#> The estimate of the covariance matrix of parameters might be inaccurate. It will produce forecasts for each of the explanatory variables based on the available data using 
es() function from smooth package (if it is available; otherwise, it will use Naive) and use those values as the new data.
There are several loss functions implemented in the function and there is an option for a user to provide their own. If the loss is not "likelihood", then the distribution is only needed for inference. Keep in mind that this typically means that the likelihood is not maximised, so the inference might be wrong and the results can be misleading. However, there are several cases, when this is not the case:
loss="MSE", distribution=c("dnorm","dlnorm","dbcnorm");loss="MAE", distribution=c("dlaplace","dllaplace");loss="HAM", distribution=c("ds","dls");The likelihoods of the distributions above are maximised, when the respective losses are minimised, so all the inference discussed above hold in these three situations. In all the other cases, the alm() function will not return logLik and might complain that the derivations can be misleading.
Also, when loss="likelihood" the number of estimated parameters includes the scale of distribution (e.g. standard deviation in case of Normal distribution), but it is not counted in the number of parameters of all the other losses.
Finally, we can provide custom loss functions. Here is an example:
lossFunction <- function(actual, fitted, B, xreg){
  return(mean(abs(actual-fitted)^3));
}
modelLossCustom <- alm(y~x1+x2+Noise, inSample, distribution="dnorm", loss=lossFunction)
summary(modelLossCustom)
#> Warning: You used the non-likelihood compatible loss, so the covariance matrix
#> might be incorrect. It is advised to use bootstrap='TRUE' option in this case.
#> Response variable: y
#> Distribution used in the estimation: Normal
#> Loss function used in estimation: custom
#> Coefficients:
#>             Estimate Std. Error Lower 2.5% Upper 97.5%
#> (Intercept) 997.8108   656.8859  -310.4908   2306.1125
#> x1            0.0108     8.1218   -16.1652     16.1868
#> x2            0.9911     4.5812    -8.1331     10.1153
#> Noise        -2.3334     1.9748    -6.2666      1.5997
#> 
#> Error standard deviation: 189.9801
#> Sample size: 80
#> Number of estimated parameters: 4
#> Number of degrees of freedom: 76Keep in mind that it is important to have parameters actual, fitted, B and xreg in the custom loss function, even if they are not used. xreg is the matrix of the expanded explanatory variables (including the intercept in the first column if it is needed).
You might also notice that there are LASSO and RIDGE available as options for loss parameter. These are experimental. When they are used, the explanatory variables are not normalised, but the parameters (all but intercept) are divided by the standard deviations of explanatory variables, which has a similar (but not the same) effect. Also, in order for this to work appropriately, you need to provide the parameter lambda, which should lie between 0 and 1, where lambda=0 means that there is no shrinkage and lambda=1 implies that there is only shrinkage, and the MSE is not used at all.
Note that due to the formulation of alm(), you can use LASSO for Logistic (distribution="plogis"), Poisson (distribution="dpois") and Negative Binomial (distribution="dnbinom") regressions as well. Keep in mind that in order to get better results, you might need to tune the parameters of the optimiser (e.g. set maxeval to a higher value or increase ftol_rel).
When working with non-conventional loss functions do not rely on the default standard errors of parameters, because they are not what they seem: they only work in case of loss="likelihood". A correct method for calculating the standard errors is the bootstrap, which is now available via the bootstrap=TRUE parameter. Here is an example:
summary(modelLossCustom, bootstrap=TRUE, nsim=100)
#> Response variable: y
#> Distribution used in the estimation: Normal
#> Loss function used in estimation: custom
#> Bootstrap was used for the estimation of uncertainty of parameters
#> Coefficients:
#>             Estimate Std. Error Lower 2.5% Upper 97.5%
#> (Intercept) 997.8108   308.0099   556.0768   1655.1417
#> x1            0.0108     3.8783    -7.2410      8.6046
#> x2            0.9911     1.9069    -3.0151      4.4874
#> Noise        -2.3334     0.9753    -4.4591     -0.6513
#> 
#> Error standard deviation: 189.9801
#> Sample size: 80
#> Number of estimated parameters: 4
#> Number of degrees of freedom: 76Where nsim is the parameter passed to the method coefbootstrap(), which is used in order to generate coefficients of models and then extract the necessary statistics. See ?coefbootstrap to see what parameters are accepted by the function. There are several methods that can use coefbootstrap() and will use bootstrapped covariance matrix: vcov(), coefint(), summary(), predict() and forecast().
There are several parameters in the optimiser that can be regulated by the user. Here is the list:
B - the vector of starting values of parameters for the optimiser, which should correspond to the ordering of the explanatory variables. In order to see the order of parameters, you can fit a model to the data and extract B from it via ourModel$B;algorithm the algorithm to use in optimisation ("NLOPT_LN_SBPLX" by default).maxeval - maximum number of iterations to carry out (default is 200 for simpler models, 500 for Logistic, Probit, Poisson and Negative Binomial and 1000 in case of loss=c("LASSO","RIDGE));maxtime - stop, when the optimisation time (in seconds) exceeds this;xtol_rel - the relative precision of the optimiser (the default is 1E-6);xtol_abs - the absolute precision of the optimiser (the default is 1E-8);ftol_rel - the stopping criterion in case of the relative change in the loss function (the default is 1E-4);ftol_abs - the stopping criterion in case of the absolute change in the loss function (the default is 0 - not used);print_level - the level of output for the optimiser (0 by default). If equal to 41, then the detailed results of the optimisation are returned.You can read more about these parameters by running the function {nloptr.print.options()} form the nloptr package. Typically, if your model does not work as expected, you might need to tune some of these parameters in order to make sure that the optimum of the loss is reached to the satisfactory extent.
Geraci, Marco, and Matteo Bottai. 2007. “Quantile regression for longitudinal data using the asymmetric Laplace distribution.” Biostatistics 8 (1): 140–54. https://doi.org/10.1093/biostatistics/kxj039.
Yu, Keming, and Jin Zhang. 2005. “A three-parameter asymmetric laplace distribution and its extension.” Communications in Statistics - Theory and Methods 34 (9-10): 1867–79. https://doi.org/10.1080/03610920500199018.