# Linear least squares (mathematics)

Template:Regression bar {{#invoke:Hatnote|hatnote}}

In statistics and mathematics, **linear least squares** is an approach fitting a mathematical or statistical model to data in cases where the idealized value provided by the model for any data point is expressed linearly in terms of the unknown parameters of the model. The resulting fitted model can be used to summarize the data, to predict unobserved values from the same system, and to understand the mechanisms that may underlie the system.

Mathematically, linear least squares is the problem of approximately solving an overdetermined system of linear equations, where the best approximation is defined as that which minimizes the sum of squared differences between the data values and their corresponding modeled values. The approach is called "linear" least squares since the assumed function is linear in the parameters to be estimated. Linear least squares problems are convex and have a closed-form solution that is unique, provided that the number of data points used for fitting equals or exceeds the number of unknown parameters, except in special degenerate situations. In contrast, non-linear least squares problems generally must be solved by an iterative procedure, and the problems can be non-convex with multiple optima for the objective function. If prior distributions are available, then even an underdetermined system can be solved using the Bayesian MMSE estimator.

In statistics, linear least squares problems correspond to a particularly important type of statistical model called linear regression which arises as a particular form of regression analysis. One basic form of such a model is an ordinary least squares model. The present article concentrates on the mathematical aspects of linear least squares problems, with discussion of the formulation and interpretation of statistical regression models and statistical inferences related to these being dealt with in the articles just mentioned. See outline of regression analysis for an outline of the topic.

## Example

{{#invoke:see also|seealso}}

As a result of an experiment, four data points were obtained, and (shown in red in the picture on the right). We hope to find a line that best fits these four points. In other words, we would like to find the numbers and that approximately solve the overdetermined linear system

of four equations in two unknowns in some "best" sense.

The "error", at each point, between the curve fit and the data is the difference between the right- and left-hand sides of the equations above. The least squares approach to solving this problem is to try to make as small as possible the sum of the squares of these errors; that is, to find the minimum of the function

The minimum is determined by calculating the partial derivatives of with respect to and and setting them to zero

This results in a system of two equations in two unknowns, called the normal equations, which give, when solved

and the equation of the line of best fit. The residuals, that is, the discrepancies between the values from the experiment and the values calculated using the line of best fit are then found to be and (see the picture on the right). The minimum value of the sum of squares of the residuals is

### Using a quadratic model

Importantly, in "linear least squares", we are not restricted to using a line as the model as in the above example. For instance, we could have chosen the restricted quadratic model . This model is still linear in the parameter, so we can still perform the same analysis, constructing a system of equations from the data points:

The partial derivatives with respect to the parameters (this time there is only one) are again computed and set to 0:

and solved

leading to the resulting best fit model

## The general problem

Consider an overdetermined system

of *m* linear equations in *n* unknown coefficients, *β*_{1},*β*_{2},…,*β*_{n}, with *m* > *n*. This can be written in matrix form as

where

Such a system usually has no solution, so the goal is instead to find the coefficients * β* which fit the equations "best," in the sense of solving the quadratic minimization problem

where the objective function *S* is given by

A justification for choosing this criterion is given in properties below. This minimization problem has a unique solution, provided that the *n* columns of the matrix *X* are linearly independent, given by solving the normal equations

Following is one generalized example which shows how to find a best fit line using least squares method (in two dimension). Later, a MATLAB code implementation of the same is also written which can help one visualize graphically.

Let us consider 3 points (x_{1},y_{1}), (x_{2},y_{2}) and (x_{3},y_{3}) in a two dimensional frame.
Now, assume that the best fit line is in the form: y = C + Dx. Substituting the three points in this equation will give us three equations.

These three equations can be written in the form of a matrix equation of the type **Ax**=**b**.
Projection of matrix A on b gives us x. This can be represented by the formula :

We get beta from this expression; i.e. is x. Hence, this follows that we have obtained C and D of the equation
**y = C + Dx**.
Hence, the best fit line obtained.

Matlab code implementation for better understanding in visuals:

1 %MATLAB code for finding the best fit line using least squares method 2 x=input('enter a') %input in the form of matrix, rows contain points 3 a=[1,x(1,1);1,x(2,1);1,x(3,1)] %forming A of Ax=b 4 b=[x(1,2);x(2,2);x(3,2)] %forming b of Ax=b 5 yy=inv(transpose(a)*a)*transpose(a)*b %computing projection of matrix A on b, giving x 6 %plotting the best fit line 7 xx=linspace(1,10,50); 8 y=yy(1)+yy(2)*xx; 9 plot(xx,y) 10 %plotting the points(data) for which we found the best fit line 11 hold on 12 plot(x(2,1),x(2,2),'x') 13 hold on 14 plot(x(1,1),x(1,2),'x') 15 hold on 16 plot(x(3,1),x(3,2),'x') 17 hold off

Python code using the same variable naming as the Matlab code:

import numpy as np import matplotlib.pyplot as plt x = np.random.rand(5,2)*10 a = np.matrix([ [1,x[0][0]], [1,x[1][0]], [1,x[2][0]] ]) b = np.matrix([ [x[0][1]], [x[1][1]], [x[2][1]] ]) yy = (a.T * a).I * a.T*b xx = np.linspace(1,10,50) y = np.array(yy[0]+yy[1]*xx) plt.figure(1) plt.plot(xx,y.T,color='r') plt.scatter([x[0][0],x[1][0],x[2][0] ],[x[0][1],x[1][1],x[2][1] ]) plt.show()

## Derivation of the normal equations

*S* is minimized when its gradient vector is zero. (This follows by definition: if the gradient vector is not zero, there is a direction in which we can move to minimize it further - see maxima and minima.) The elements of the gradient vector are the partial derivatives of *S* with respect to the parameters:

The derivatives are

Substitution of the expressions for the residuals and the derivatives into the gradient equations gives

Upon rearrangement, we obtain the **normal equations**:

The normal equations are written in matrix notation as

- (where
*X*^{T}is the matrix transpose of*X*).

The solution of the normal equations yields the vector of the optimal parameter values.

### Derivation directly in terms of matrices

The normal equations can be derived directly from a matrix representation of the problem as follows. The objective is to minimize

Note that : has the dimension 1x1 (the number of columns of ), so it is a scalar and the quantity to minimize becomes

Differentiating this with respect to and equating to zero to satisfy the first-order conditions gives

which is equivalent to the above-given normal equations. A sufficient condition for satisfaction of the second-order conditions for a minimum is that have full column rank, in which case is positive definite.

## Computation

A general approach to the least squares problem can be described as follows. Suppose that we can find an *n* by *m* matrix **S**
such that **XS** is an
orthogonal projection onto the image of **X**. Then a solution to our minimization problem is given by

simply because

is exactly a sought for orthogonal projection of onto an image of **X**
(see the picture below and note that as explained in the
next section the image of **X** is just a subspace generated by column vectors of **X**).
A few popular ways to find such a matrix *S* are described below.

### Inverting the matrix of the normal equations

The algebraic solution of the normal equations can be written as

where *X*^{+} is the Moore–Penrose pseudoinverse of *X*. Although this equation is correct, and can work in many applications, it is not computationally efficient to invert the normal equations matrix. An exception occurs in numerical smoothing and differentiation where an analytical expression is required.

If the matrix *X*^{T}*X* is well-conditioned and positive definite, implying that it has full rank, the normal equations can be solved directly by using the Cholesky decomposition *R*^{T}*R*, where *R* is an upper triangular matrix, giving:

The solution is obtained in two stages, a forward substitution step, solving for **z**:

followed by a backward substitution, solving for

Both substitutions are facilitated by the triangular nature of *R*.

See example of linear regression for a worked-out numerical example with three parameters.

### Orthogonal decomposition methods

Orthogonal decomposition methods of solving the least squares problem are slower than the normal equations method but are more numerically stable because they avoid forming the product *X*^{T}*X*.

The residuals are written in matrix notation as

The matrix *X* is subjected to an orthogonal decomposition, e.g., the QR decomposition as follows.

where *Q* is an *m*×*n* orthogonal matrix (*Q*^{T}*Q=I*) and *R* is an *n*×*n* upper triangular matrix with .

The residual vector is left-multiplied by *Q*^{T}.

Because *Q* is orthogonal, the sum of squares of the residuals, *s*, may be written as:

Since **v** doesn't depend on * β*, the minimum value of

*s*is attained when the upper block,

**u**, is zero. Therefore the parameters are found by solving:

These equations are easily solved as *R* is upper triangular.

An alternative decomposition of *X* is the singular value decomposition (SVD)^{[1]}

where *U* is *m* by *m* orthogonal matrix, *V* is *n* by *n* orthogonal matrix and is an *m* by *n* matrix with all its elements outside of the main diagonal equal to *0*. The pseudoinverse of is easily obtained by inverting its non-zero diagonal elements and transposing. Hence,

where *P* is obtained from by replacing its non-zero diagonal elements with ones. Since (the property of pseudoinverse), the matrix is an orthogonal projection onto the image (column-space) of *X*. In accordance with a general approach described in the introduction above (find **XS** which is an orthogonal projection),

and thus,

is a solution of a least squares problem. This method is the most computationally intensive, but is particularly useful if the normal equations matrix, *X*^{T}*X*, is very ill-conditioned (i.e. if its condition number multiplied by the machine's relative round-off error is appreciably large). In that case, including the smallest singular values in the inversion merely adds numerical noise to the solution. This can be cured with the truncated SVD approach, giving a more stable and exact answer, by explicitly setting to zero all singular values below a certain threshold and so ignoring them, a process closely related to factor analysis.

## Properties of the least-squares estimators

The gradient equations at the minimum can be written as

A geometrical interpretation of these equations is that the vector of residuals, is orthogonal to the column space of *X*, since the dot product is equal to zero for *any* conformal vector, **v**. This means that is the shortest of all possible vectors , that is, the variance of the residuals is the minimum possible. This is illustrated at the right.

Introducing and a matrix *K* with the assumption that a matrix is non-singular and *K*^{T} *X* = 0 (cf. Orthogonal projections), the residual vector should satisfy the following equation:

The equation and solution of linear least squares are thus described as follows:

If the experimental errors, , are uncorrelated, have a mean of zero and a constant variance, , the Gauss-Markov theorem states that the least-squares estimator, , has the minimum variance of all estimators that are linear combinations of the observations. In this sense it is the best, or optimal, estimator of the parameters. Note particularly that this property is independent of the statistical distribution function of the errors. In other words, *the distribution function of the errors need not be a normal distribution*. However, for some probability distributions, there is no guarantee that the least-squares solution is even possible given the observations; still, in such cases it is the best estimator that is both linear and unbiased.

For example, it is easy to show that the arithmetic mean of a set of measurements of a quantity is the least-squares estimator of the value of that quantity. If the conditions of the Gauss-Markov theorem apply, the arithmetic mean is optimal, whatever the distribution of errors of the measurements might be.

However, in the case that the experimental errors do belong to a normal distribution, the least-squares estimator is also a maximum likelihood estimator.^{[2]}

These properties underpin the use of the method of least squares for all types of data fitting, even when the assumptions are not strictly valid.

### Limitations

An assumption underlying the treatment given above is that the independent variable, *x*, is free of error. In practice, the errors on the measurements of the independent variable are usually much smaller than the errors on the dependent variable and can therefore be ignored. When this is not the case, total least squares or more generally errors-in-variables models, or *rigorous least squares*, should be used. This can be done by adjusting the weighting scheme to take into account errors on both the dependent and independent variables and then following the standard procedure.^{[3]}^{[4]}

In some cases the (weighted) normal equations matrix *X*^{T}*X* is ill-conditioned. When fitting polynomials the normal equations matrix is a Vandermonde matrix. Vandermonde matrices become increasingly ill-conditioned as the order of the matrix increases.{{ safesubst:#invoke:Unsubst||date=__DATE__ |$B=
{{#invoke:Category handler|main}}{{#invoke:Category handler|main}}^{[citation needed]}
}} In these cases, the least squares estimate amplifies the measurement noise and may be grossly inaccurate.{{ safesubst:#invoke:Unsubst||date=__DATE__ |$B=
{{#invoke:Category handler|main}}{{#invoke:Category handler|main}}^{[citation needed]}
}} Various regularization techniques can be applied in such cases, the most common of which is called ridge regression. If further information about the parameters is known, for example, a range of possible values of , then various techniques can be used to increase the stability of the solution. For example, see constrained least squares.

Another drawback of the least squares estimator is the fact that the norm of the residuals, is minimized, whereas in some cases one is truly interested in obtaining small error in the parameter , e.g., a small value of .{{ safesubst:#invoke:Unsubst||date=__DATE__ |$B=
{{#invoke:Category handler|main}}{{#invoke:Category handler|main}}^{[citation needed]}
}} However, since the true parameter is necessarily unknown, this quantity cannot be directly minimized. If a prior probability on is known, then a Bayes estimator can be used to minimize the mean squared error, . The least squares method is often applied when no prior is known. Surprisingly, when several parameters are being estimated jointly, better estimators can be constructed, an effect known as Stein's phenomenon. For example, if the measurement error is Gaussian, several estimators are known which dominate, or outperform, the least squares technique; the best known of these is the James–Stein estimator. This is an example of more general shrinkage estimators that have been applied to regression problems.

## Weighted linear least squares

{{#invoke:see also|seealso}} {{#invoke:see also|seealso}}

In some cases the observations may be weighted—for example, they may not be equally reliable. In this case, one can minimize the weighted sum of squares:

where *w*_{i} > 0 is the weight of the *i*th observation, and *W* is the diagonal matrix of such weights.

The weights should, ideally, be equal to the reciprocal of the variance of the measurement.^{[5]} ^{[6]}
The normal equations are then:

This method is used in iteratively reweighted least squares.

### Parameter errors and correlation

The estimated parameter values are linear combinations of the observed values

Therefore an expression for the residuals (i.e., the *estimated* errors in the observations) can be obtained by error propagation from the errors in the observations. Let the variance-covariance matrix for the observations be denoted by *M* and that of the parameters by *M ^{β}*. Then,

When *W* = *M*^{ −1} this simplifies to

When unit weights are used (*W* = *I*) it is implied that the experimental errors are uncorrelated and all equal: *M* = *σ*^{2}*I*, where *σ*^{2} is the variance of an observation, and *I* is the identity matrix. In this case *σ*^{2} is approximated by , where *S* is the minimum value of the objective function

The denominator, *m* − *n*, is the number of degrees of freedom; see effective degrees of freedom for generalizations for the case of correlated observations. In all cases, the variance of the parameter is given by and the covariance between parameters and is given by . Standard deviation is the square root of variance, and the correlation coefficient is given by . These error estimates reflect only random errors in the measurements. The true uncertainty in the parameters is larger due to the presence of systematic errors which, by definition, cannot be quantified.
Note that even though the observations may be un-correlated, the parameters are typically correlated.

### Parameter confidence limits

{{#invoke:main|main}}
It is often *assumed*, for want of any concrete evidence but often appealing to the central limit theorem -- see Normal distribution#Occurrence -- that the error on each observation belongs to a normal distribution with a mean of zero and standard deviation . Under that assumption the following probabilities can be derived for a single scalar parameter estimate in terms of its estimated standard error (given here):

- 68% that the interval encompasses the true coefficient value
- 95% that the interval encompasses the true coefficient value
- 99% that the interval encompasses the true coefficient value

The assumption is not unreasonable when *m* >> *n*. If the experimental errors are normally distributed the parameters will belong to a Student's t-distribution with *m* − *n* degrees of freedom. When *m* >> *n* Student's t-distribution approximates a normal distribution. Note, however, that these confidence limits cannot take systematic error into account. Also, parameter errors should be quoted to one significant figure only, as they are subject to sampling error.^{[7]}

When the number of observations is relatively small, Chebychev's inequality can be used for an upper bound on probabilities, regardless of any assumptions about the distribution of experimental errors: the maximum probabilities that a parameter will be more than 1, 2 or 3 standard deviations away from its expectation value are 100%, 25% and 11% respectively.

### Residual values and correlation

The residuals are related to the observations by

where *H* is the idempotent matrix known as the hat matrix:

and *I* is the identity matrix. The variance-covariance matrice of the residuals, **M ^{r}** is given by

Thus the residuals are correlated, even if the observations are not.

The sum of residual values is equal to zero whenever the model function contains a constant term. Left-multiply the expression for the residuals by *X*^{T}:

Say, for example, that the first term of the model is a constant, so that for all *i*. In that case it follows that

Thus, in the motivational example, above, the fact that the sum of residual values is equal to zero it is not accidental but is a consequence of the presence of the constant term, α, in the model.

If experimental error follows a normal distribution, then, because of the linear relationship between residuals and observations, so should residuals,^{[8]} but since the observations are only a sample of the population of all possible observations, the residuals should belong to a Student's t-distribution. Studentized residuals are useful in making a statistical test for an outlier when a particular residual appears to be excessively large.

## Objective function

The optimal value of the objective function, found by substituting in the optimal expression for the coefficient vector, can be written as

the latter equality holding since (*I* – *H*) is symmetric and idempotent. It can be shown from this^{[9]} that under an appropriate assignment of weights the expected value of *S* is *m-n*. If instead unit weights are assumed, the expected value of *S* is , where is the variance of each observation.

If it is assumed that the residuals belong to a normal distribution, the objective function, being a sum of weighted squared residuals, will belong to a chi-squared () distribution with *m-n* degrees of freedom. Some illustrative percentile values of are given in the following table.^{[10]}

These values can be used for a statistical criterion as to the goodness-of-fit. When unit weights are used, the numbers should be divided by the variance of an observation.

## Constrained linear least squares

Often it is of interest to solve a linear least squares problem with an additional constraint on the solution. With constrained linear least squares, the original equation

must be satisfied (in the least squares sense) while also ensuring that some other property of is maintained. There are often special purpose algorithms for solving such problems efficiently. Some examples of constraints are given below:

- Equality constrained least squares: the elements of must exactly satisfy
- Regularized least squares: the elements of must satisfy
- Non-negative least squares (NNLS): The vector satisfies the vector inequality that is defined componentwise --- that is, each component must be either positive or zero.
- Box-constrained least squares: The vector satisfies the vector inequalities , each of which is defined componentwise.
- Integer constrained least squares: all elements of must be integer (instead of real numbers).
- Phase constrained least squares: all elements of must have the same phase (or must be real rather than complex numbers, i.e. phase = 0).

When the constraint only applies to some of the variables, the mixed problem may be solved using **separable least squares** by letting and represent the unconstrained (1) and constrained (2) components. Then substituting the least squares solution for , i.e.

back into the original expression gives (following some rearrangement) an equation that can be solved as a purely constrained problem in .

where is a projection matrix. Following the constrained estimation of the vector is obtained from the expression above.

## Typical uses and applications

- Polynomial fitting: models are polynomials in an independent variable,
*x*:- Straight line: .
^{[11]} - Quadratic: .
- Cubic, quartic and higher polynomials. For regression with high-order polynomials, the use of orthogonal polynomials is recommended.
^{[12]}

- Straight line: .
- Numerical smoothing and differentiation — this is an application of polynomial fitting.
- Multinomials in more than one independent variable, including surface fitting
- Curve fitting with B-splines
^{[3]} - Chemometrics, Calibration curve, Standard addition, Gran plot, analysis of mixtures

### Uses in data fitting

The primary application of linear least squares is in data fitting. Given a set of *m* data points consisting of experimentally measured values taken at *m* values of an independent variable ( may be scalar or vector quantities), and given a model function with it is desired to find the parameters such that the model function "best" fits the data. In linear least squares, linearity is meant to be with respect to parameters so

Here, the functions may be **nonlinear** with respect to the variable **x**.

Ideally, the model function fits the data exactly, so

for all This is usually not possible in practice, as there are more data points than there are parameters to be determined. The approach chosen then is to find the minimal possible value of the sum of squares of the residuals

so to minimize the function

After substituting for and then for , this minimization problem becomes the quadratic minimization problem above with

and the best fit can be found by solving the normal equations.

## Further discussion

The *numerical methods for linear least squares* are important because linear regression models are among the most important types of model, both as formal statistical models and for exploration of data-sets. The majority of statistical computer packages contain facilities for regression analysis that make use of linear least squares computations. Hence it is appropriate that considerable effort has been devoted to the task of ensuring that these computations are undertaken efficiently and with due regard to round-off error.

Individual statistical analyses are seldom undertaken in isolation, but rather are part of a sequence of investigatory steps. Some of the topics involved in considering numerical methods for linear least squares relate to this point. Thus important topics can be

- Computations where a number of similar, and often nested, models are considered for the same data-set. That is, where models with the same dependent variable but different sets of independent variables are to be considered, for essentially the same set of data-points.
- Computations for analyses that occur in a sequence, as the number of data-points increases.
- Special considerations for very extensive data-sets.

Fitting of linear models by least squares often, but not always, arise in the context of statistical analysis. It can therefore be important that considerations of computation efficiency for such problems extend to all of the auxiliary quantities required for such analyses, and are not restricted to the formal solution of the linear least squares problem.

### Rounding errors

Matrix calculations, like any other, are affected by rounding errors. An early summary of these effects, regarding the choice of computation methods for matrix inversion, was provided by Wilkinson.^{[13]}

## See also

- Line-line intersection#Nearest point to non-intersecting lines, an application

## References

- ↑ {{#invoke:citation/CS1|citation |CitationClass=book }}
- ↑ {{#invoke:citation/CS1|citation |CitationClass=book }}
- ↑
^{3.0}^{3.1}{{#invoke:citation/CS1|citation |CitationClass=book }} - ↑ {{#invoke:citation/CS1|citation |CitationClass=book }}
- ↑ This implies that the observations are uncorrelated. If the observations are correlated, the expression applies. In this case the weight matrix should ideally be equal to the inverse of the variance-covariance matrix of the observations.
- ↑ {{#invoke:citation/CS1|citation |CitationClass=book }}, chapter 3
- ↑ {{#invoke:citation/CS1|citation |CitationClass=book }}
- ↑ {{#invoke:citation/CS1|citation |CitationClass=book }}
- ↑ {{#invoke:citation/CS1|citation |CitationClass=book }}
- ↑ {{#invoke:citation/CS1|citation |CitationClass=book }}
- ↑ {{#invoke:citation/CS1|citation |CitationClass=book }}
- ↑ {{#invoke:citation/CS1|citation |CitationClass=book }}Template:Page needed
- ↑ Wilkinson, J.H. (1963) "Chapter 3: Matrix Computations",
*Rounding Errors in Algebraic Processes*, London: Her Majesty's Stationery Office (National Physical Laboratory, Notes in Applied Science, No.32)

## Further reading

- {{#invoke:citation/CS1|citation

|CitationClass=book }}

- {{#invoke:citation/CS1|citation

|CitationClass=citation }}

- {{#invoke:citation/CS1|citation

|CitationClass=book }}

- {{#invoke:citation/CS1|citation

|CitationClass=citation }}

- {{#invoke:citation/CS1|citation

|CitationClass=citation }}

- {{#invoke:citation/CS1|citation

|CitationClass=citation }}

## External links

Template:Least Squares and Regression Analysis

af:Kleinste-kwadratemetode cs:Metoda nejmenších čtverců de:Methode der kleinsten Quadrate es:Mínimos cuadrados fa:کمینه مربعات خطی fr:Méthode des moindres carrés gl:Mínimos cadrados gl:Mínimos cadrados lineais it:Minimi Quadrati he:שיטת הריבועים הפחותים la:Methodus quadratorum minimorum hu:Legkisebb négyzetek módszere nl:Kleinste-kwadratenmethode ja:最小二乗法 pl:Metoda najmniejszych kwadratów pt:Método dos mínimos quadrados ru:Метод наименьших квадратов su:Kuadrat leutik uk:Метод найменших квадратів fi:Pienimmän neliösumman menetelmä sv:Minstakvadratmetoden tr:En küçük kareler yöntemi ur:لکیری اقل مربعات vi:Bình phương tối thiểu vi:Bình phương tối thiểu tuyến tính zh:最小二乘法