LTS Call |
The LTS subroutine performs least trimmed squares (LTS) robust regression by minimizing the sum of the smallest squared residuals. The subroutine also detects outliers and perform a least squares regression on the remaining observations. The LTS subroutine implements the FAST-LTS algorithm described by Rousseeuw and Van Driessen (1998).
The value of can be specified, but for many applications the default value works well and the results seem to be quite stable toward different choices of .
In the following discussion, is the number of observations and is the number of regressors. The input arguments to the LTS subroutine are as follows:
refers to an options vector with the following components (missing values are treated as default values). The options vector can be a null vector.
specifies whether an intercept is used in the model (opt[1]=0) or not (opt[1]). If opt[1]=0, then a column of ones is added as the last column to the input matrix ; that is, you do not need to add this column of ones yourself. The default is opt[1]=0.
specifies the amount of printed output. Higher values request additional output and include the output of lower values.
prints no output except error messages.
prints all output except (1) arrays of , such as weights, residuals, and diagnostics; (2) the history of the optimization process; and (3) subsets that result in singular linear systems.
additionally prints arrays of , such as weights, residuals, and diagnostics; it also prints the case numbers of the observations in the best subset and some basic history of the optimization process.
additionally prints subsets that result in singular linear systems.
The default is opt[2]=0.
specifies whether only LTS is computed or whether, additionally, least squares (LS) and weighted least squares (WLS) regression are computed:
computes only LTS.
computes, in addition to LTS, weighted least squares regression on the observations with small LTS residuals (where small is defined by opt[8]).
computes, in addition to LTS, unweighted least squares regression.
adds both unweighted and weighted least squares regression to LTS regression.
The default is opt[3]=0.
specifies the quantile to be minimized. This is used in the objective function. The default is opt[4], which corresponds to the highest possible breakdown value. This is also the default of the PROGRESS program. The value of should be in the range .
specifies the number of generated subsets. Each subset consists of observations , where . The total number of subsets that contain observations out of observations is
where is the number of parameters including the intercept.
Due to computer time restrictions, not all subset combinations of observations out of can be inspected for larger values of and . Specifying a value of enables you to save computer time at the expense of computing a suboptimal solution.
When opt[5] is zero or missing:
If , the default FAST-LTS algorithm constructs up to five disjoint random subsets with sizes as equal as possible, but not to exceed 300. Inside each subset, the algorithm chooses subset combinations of observations.
The number of subsets is taken from the following table:
n |
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
---|---|---|---|---|---|---|---|---|---|---|
500 |
50 |
22 |
17 |
15 |
14 |
0 |
0 |
0 |
0 |
|
|
1414 |
182 |
71 |
43 |
32 |
27 |
24 |
23 |
22 |
|
500 |
1000 |
1500 |
2000 |
2500 |
3000 |
3000 |
3000 |
3000 |
3000 |
n |
11 |
12 |
13 |
14 |
15 |
---|---|---|---|---|---|
0 |
0 |
0 |
0 |
0 |
|
22 |
22 |
22 |
23 |
23 |
|
3000 |
3000 |
3000 |
3000 |
3000 |
If the number of cases (observations) is smaller than , then all possible subsets are used; otherwise, fixed 500 subsets for FAST-LTS or subsets for algorithm before SAS/IML 8.1 are chosen randomly. This means that an exhaustive search is performed for opt[5]=. If is larger than , a note is printed in the log file that indicates how many subsets exist.
is not used.
specifies whether the last argument sorb contains a given parameter vector or a given subset for which the objective function should be evaluated.
sorb contains a given subset index.
sorb contains a given parameter vector .
The default is opt[7]=0.
is relevant only for LS and WLS regression (opt[3] > 0). It specifies whether the covariance matrix of parameter estimates and approximate standard errors (ASEs) are computed and printed.
does not compute covariance matrix and ASEs.
computes covariance matrix and ASEs but prints neither of them.
computes the covariance matrix and ASEs but prints only the ASEs.
computes and prints both the covariance matrix and the ASEs.
The default is opt[8]=0.
is relevant only for LTS. If opt[9]=0, the algorithm FAST-LTS of Rousseeuw and Van Driessen (1998) is used. If opt[9] = 1, the algorithm of Rousseeuw and Leroy (1987) is used. The default is opt[9]=0.
a response vector with observations.
an matrix of regressors. If opt[1] is zero or missing, an intercept is added by default as the last column of . If the matrix is not specified, is analyzed as a univariate data set.
refers to an vector that contains either of the following:
observation numbers of a subset for which the objective function should be evaluated; this subset can be the start for a pairwise exchange algorithm if opt[7] is specified.
given parameters (including the intercept, if necessary) for which the objective function should be evaluated.
Missing values are not permitted in or . Missing values in opt cause the default value to be used.
The LTS subroutine returns the following values:
is a column vector that contains the following scalar information, where rows 1–9 correspond to LTS regression and rows 11–14 correspond to either LS or WLS:
the quantile used in the objective function
number of subsets generated
number of subsets with singular linear systems
number of nonzero weights
lowest value of the objective function attained
preliminary LTS scale estimate
final LTS scale estimate
robust R square (coefficient of determination)
asymptotic consistency factor
If opt[3] > 0, then the following are also set:
LS or WLS objective function (sum of squared residuals)
LS or WLS scale estimate
R square value for LS or WLS
value for LS or WLS
For opt[3]=1 or opt[3]=3, these rows correspond to WLS estimates; for opt[3]=2, these rows correspond to LS estimates.
is a matrix with columns that contains the following results in its rows:
LTS parameter estimates
indices of observations in the best subset
If opt[3] > 0, then the following are also set:
LS or WLS parameter estimates
approximate standard errors of LS or WLS estimates
values
-values
lower boundary of Wald confidence intervals
upper boundary of Wald confidence intervals
For opt[3]=1 or opt[3]=3, these rows correspond to WLS estimates; for opt[3]=2, these rows correspond to LS estimates.
is a matrix with columns that contains the following results in its rows:
weights (1 for small residuals; 0 for large residuals)
residuals
resistant diagnostic (the resistant diagnostic cannot be computed for a perfect fit when the objective function is zero or nearly zero)
Consider Brownlee (1965) stackloss data used in the example for the LMS subroutine.
For and (three explanatory variables including intercept), you obtain a total of 5,985 different subsets of 4 observations out of 21. If you decide not to specify opt[5], the FAST-LTS algorithm chooses random sample subsets, as in the following statements:
/* X1 X2 X3 Y Stackloss data */ aa = { 1 80 27 89 42, 1 80 27 88 37, 1 75 25 90 37, 1 62 24 87 28, 1 62 22 87 18, 1 62 23 87 18, 1 62 24 93 19, 1 62 24 93 20, 1 58 23 87 15, 1 58 18 80 14, 1 58 18 89 14, 1 58 17 88 13, 1 58 18 82 11, 1 58 19 93 12, 1 50 18 89 8, 1 50 18 86 7, 1 50 19 72 8, 1 50 19 79 8, 1 50 20 80 9, 1 56 20 82 15, 1 70 20 91 15 }; a = aa[, 2:4]; b = aa[, 5]; opt = j(8, 1, .); opt[2]= 1; /* ipri */ opt[3]= 3; /* ilsq */ opt[8]= 3; /* icov */ call lts(sc, coef, wgt, opt, b, a);
Median and Mean | ||
---|---|---|
Median | Mean | |
VAR1 | 58 | 60.428571429 |
VAR2 | 20 | 21.095238095 |
VAR3 | 87 | 86.285714286 |
Intercep | 1 | 1 |
Response | 15 | 17.523809524 |
Dispersion and Standard Deviation | ||
---|---|---|
Dispersion | StdDev | |
VAR1 | 5.930408874 | 9.1682682584 |
VAR2 | 2.965204437 | 3.160771455 |
VAR3 | 4.4478066555 | 5.3585712381 |
Intercep | 0 | 0 |
Response | 5.930408874 | 10.171622524 |
LS Parameter Estimates | ||||||
---|---|---|---|---|---|---|
Variable | Estimate | Approx Std Err |
t Value | Pr > |t| | Lower WCI | Upper WCI |
VAR1 | 0.7156402 | 0.13485819 | 5.31 | <.0001 | 0.45132301 | 0.97995739 |
VAR2 | 1.29528612 | 0.36802427 | 3.52 | 0.0026 | 0.57397182 | 2.01660043 |
VAR3 | -0.1521225 | 0.15629404 | -0.97 | 0.3440 | -0.4584532 | 0.15420818 |
Intercep | -39.919674 | 11.8959969 | -3.36 | 0.0038 | -63.2354 | -16.603949 |
Cov Matrix of Parameter Estimates | ||||
---|---|---|---|---|
VAR1 | VAR2 | VAR3 | Intercep | |
VAR1 | 0.0181867302 | -0.036510675 | -0.007143521 | 0.2875871057 |
VAR2 | -0.036510675 | 0.1354418598 | 0.0000104768 | -0.651794369 |
VAR3 | -0.007143521 | 0.0000104768 | 0.024427828 | -1.676320797 |
Intercep | 0.2875871057 | -0.651794369 | -1.676320797 | 141.51474107 |
5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 15 | 16 | 17 | 18 | 19 |
Estimated Coefficients | |||
---|---|---|---|
VAR1 | VAR2 | VAR3 | Intercep |
0.7409210642 | 0.3915267228 | 0.0111345398 | -37.32332647 |
RLS Parameter Estimates Based on LTS | ||||||
---|---|---|---|---|---|---|
Variable | Estimate | Approx Std Err |
t Value | Pr > |t| | Lower WCI | Upper WCI |
VAR1 | 0.75694055 | 0.07860766 | 9.63 | <.0001 | 0.60287236 | 0.91100874 |
VAR2 | 0.45353029 | 0.13605033 | 3.33 | 0.0067 | 0.18687654 | 0.72018405 |
VAR3 | -0.05211 | 0.05463722 | -0.95 | 0.3607 | -0.159197 | 0.054977 |
Intercep | -34.05751 | 3.82881873 | -8.90 | <.0001 | -41.561857 | -26.553163 |
Cov Matrix of Parameter Estimates | ||||
---|---|---|---|---|
VAR1 | VAR2 | VAR3 | Intercep | |
VAR1 | 0.0061791648 | -0.005776855 | -0.002300587 | -0.034290068 |
VAR2 | -0.005776855 | 0.0185096933 | 0.0002582502 | -0.069740883 |
VAR3 | -0.002300587 | 0.0002582502 | 0.0029852254 | -0.131487406 |
Intercep | -0.034290068 | -0.069740883 | -0.131487406 | 14.659852903 |
The preceding program produces the following output associated with the LTS analysis. In this analysis, observations, 1, 2, 3, 4, 13, and 21 have scaled residuals larger than 2.5 (table not shown) and are considered outliers.
See the documentation for the LMS subroutine for additional details.