stable_lm {stabreg}R Documentation

Linear-model fitting with Stable residuals

Description

Fitting of a linear model with stable residuals. Regresses only location of the distribution. NAs not allowed.

Usage

stable_lm(formula, data, trace, output_se, calc_confbounds, conf, optim_control)

Arguments

formula

regression formula for location

data

data.frame

trace

trace level

output_se

logical - whether to calculate standard errors (will entail calculation and inversion of final Hessian)

calc_confbounds

logical - whether to calculate exact confidence bounds. See Details

conf

confidence level for confidence bounds. Default 0.95

optim_control

list passed to nlminb's control argument

Details

Lowest possible estimate for alpha is 1.1.

By default, output_se = TRUE, which will calculate standard errors and approximate confidence bounds. These will be approximate in the sense that the likelihood will typically not be symmetric, and thus these confidence bounds will only provide an indicative measure of confidence. To calculate exact confidence bounds use calc_confbounds = TRUE. However, exact confidence bounds calculation is very time consuming as this requires repeated computation of profile likelihoods for each regression variable. If N is the number of regressors in the model, then the expected time to compute all confidence bounds is about 200N times the time it takes to just fit the model. Currently, confidence bounds are calculated only for the regressors and not the parameters of the distribution of the residuals (i.e. alpha, beta, and scale).

Note that standard errors and t-scores for alpha, beta, and scale parameters are calculated in transformed space and cannot be interpreted as-is. All confidence bounds (both approximate and exact), however, are transformed back to the original space and can be interpreted as-is.

In the case that alpha is estimated to be numerically equal to 2, beta is automatically set to 0. In this boundary case calculation of standard errors will fail and return the default maximum range for alpha, i.e. 1.1 to 2. This should be interpreted as the residuals having a Normal distribution, in which case OLS regression would be preferable.

Examples

# generate some data: y = 4x - 1 + epsilon
# where epsilon is heavy-tailed student-t with 5 df
set.seed(123)
df <- data.frame(x = rnorm(1000))
df$y <- 4 * df$x - 1 + rt(1000, df = 5)

sfit <- stable_lm(y ~ x, data = df)
print(sfit)

[Package stabreg version 0.1.2 Index]