Iteratively reweighted least squares

From Infogalactic: the planetary knowledge core
Jump to: navigation, search

Lua error in package.lua at line 80: module 'strict' not found. The method of iteratively reweighted least squares (IRLS) is used to solve certain optimization problems with objective functions of the form:

\underset{\boldsymbol\beta} {\operatorname{arg\,min}} \sum_{i=1}^n \big| y_i - f_i (\boldsymbol\beta) \big|^p,

by an iterative method in which each step involves solving a weighted least squares problem of the form:

\boldsymbol\beta^{(t+1)} = \underset{\boldsymbol\beta} {\operatorname{arg\,min}} \sum_{i=1}^n w_i (\boldsymbol\beta^{(t)}) \big| y_i - f_i (\boldsymbol\beta) \big|^2.

IRLS is used to find the maximum likelihood estimates of a generalized linear model, and in robust regression to find an M-estimator, as a way of mitigating the influence of outliers in an otherwise normally-distributed data set. For example, by minimizing the least absolute error rather than the least square error.

Although not a linear regression problem, Weiszfeld's algorithm for approximating the geometric median can also be viewed as a special case of iteratively reweighted least squares, in which the objective function is the sum of distances of the estimator from the samples.

One of the advantages of IRLS over linear programming and convex programming is that it can be used with Gauss–Newton and Levenberg–Marquardt numerical algorithms.

Examples

L1 minimization for sparse recovery

IRLS can be used for \ell1 minimization and smoothed \ellp minimization, p < 1, in the compressed sensing problems. It has been proved that the algorithm has a linear rate of convergence for \ell1 norm and superlinear for \ell t with t < 1, under the restricted isometry property, which is generally a sufficient condition for sparse solutions.[1][2] However in most practical situations, the restricted isometry property is not satisfied.

Lp norm linear regression

To find the parameters β = (β1, …,βk)T which minimize the Lp norm for the linear regression problem,


\underset{\boldsymbol \beta}{ \operatorname{arg\,min} }
    \big\| \mathbf y - X \boldsymbol \beta \|_p
 =
\underset{\boldsymbol \beta}{ \operatorname{arg\,min} }
     \sum_{i=1}^n  \left| y_i - X_i \boldsymbol\beta \right|^p ,

the IRLS algorithm at step t+1 involves solving the weighted linear least squares problem:[3]


\boldsymbol\beta^{(t+1)}
 =
\underset{\boldsymbol\beta}{ \operatorname{arg\,min} }
    \sum_{i=1}^n w_i^{(t)}  \left| y_i - X_i \boldsymbol\beta \right|^2
 =
(X^{\rm T} W^{(t)} X)^{-1} X^{\rm T} W^{(t)} \mathbf{y},

where W(t) is the diagonal matrix of weights, usually with all elements set initially to:

w_i^{(0)} = 1

and updated after each iteration to:

w_i^{(t)} = \big|y_i - X_i \boldsymbol \beta ^{(t)} \big|^{p-2}.

In the case p = 1, this corresponds to least absolute deviation regression (in this case, the problem would be better approached by use of linear programming methods,[4] so the result would be exact) and the formula is:

w_i^{(t)} = \frac{1}{\big|y_i - X_i \boldsymbol \beta ^{(t)} \big|}.

To avoid dividing by zero, regularization must be done, so in practice the formula is:

w_i^{(t)} = \frac{1}{\text{max}(\delta, \big|y_i - X_i \boldsymbol \beta ^{(t)} \big|)}.

where \delta is some small value, like 0.0001.[4]

Notes

  1. Lua error in package.lua at line 80: module 'strict' not found.
  2. Lua error in package.lua at line 80: module 'strict' not found.
  3. Lua error in package.lua at line 80: module 'strict' not found.
  4. 4.0 4.1 William A. Pfeil, Statistical Teaching Aids, Bachelor of Science thesis, Worcester Polytechnic Institute, 2006

References

External links