- QR decomposition
In
linear algebra , the QR decomposition (also called the QR factorization) of a matrix is a decomposition of the matrix into an orthogonal and aright triangular matrix . The QR decomposition is often used to solve thelinear least squares problem. The QR decomposition is also the basis for a particulareigenvalue algorithm , theQR algorithm .Definition
A QR decomposition of a real square matrix "A" is a decomposition of "A" as: A = QR, , where "Q" is an
orthogonal matrix (meaning that "Q"T"Q" = "I" ) and "R" is an uppertriangular matrix (also called right triangular matrix). Analogously, we can define the QL, RQ, and LQ decompositions of A (with "L" being a lower triangular matrix in this case).More generally, we can factor a complex m×n matrix (with "m" ≥ "n") as the product of an m×m
unitary matrix and an m×n upper triangular matrix. An alternative definition is decomposing a complex m×n matrix (with "m" ≥ "n") as the product of an m×n matrix with orthogonal columns and an n×n upper triangular matrix; (-1, 3, -2)^T, and then:Q_1 = I - {2 over sqrt{14} sqrt{14 egin{pmatrix} -1 \ 3 \ -2 end{pmatrix}egin{pmatrix} -1 & 3 & -2 end{pmatrix}:I - {1 over 7}egin{pmatrix}1 & -3 & 2 \-3 & 9 & -6 \2 & -6 & 4 end{pmatrix}:egin{pmatrix}6/7 & 3/7 & -2/7 \3/7 &-2/7 & 6/7 \-2/7 & 6/7 & 3/7 \end{pmatrix}.Now observe::Q_1A = egin{pmatrix}14 & 21 & -14 \0 & -49 & -14 \0 & 168 & -77 end{pmatrix},so we already have almost a triangular matrix. We only need to zero the (3, 2) entry.
Take the (1, 1) minor, and then apply the process again to:A' = M_{11} = egin{pmatrix}-49 & -14 \168 & -77 end{pmatrix}.By the same method as above, we obtain the matrix of the Householder transformation:Q_2 = egin{pmatrix}1 & 0 & 0 \0 & -7/25 & 24/25 \0 & 24/25 & 7/25 end{pmatrix}after performing a direct sum with 1 to make sure the next step in the process works properly.
Now, we find:Q=Q_1 Q_2=egin{pmatrix}6/7 & -69/175 & 58/175\3/7 & 158/175 & -6/175 \-2/7 & 6/35 & 33/35end{pmatrix} :R=Q_2Q_1A=Q^T A=egin{pmatrix}14 & 21 & -14 \0 & 175 & -70 \0 & 0 & -35end{pmatrix}.The matrix "Q" is orthogonal and "R" is upper triangular, so "A" = "QR" is the required QR-decomposition.
Using Givens rotations
"QR" decompositions can also be computed with a series of
Givens rotation s. Each rotation zeros an element in the subdiagonal of the matrix, forming the "R" matrix. The concatenation of all the Givens rotations forms the orthogonal "Q" matrix.In practice, Givens rotations are not actually performed by building a whole matrix and doing a matrix multiplication. A Givens rotation procedure is used instead which does the equivalent of the sparse Givens matrix multiplication, without the extra work of handling the sparse elements. The Givens rotation procedure is useful in situations where only a relatively few off diagonal elements need to be zeroed, and is more easily parallelized than Householder transformations.
Example
Let us calculate the decomposition of : A = egin{pmatrix}12 & -51 & 4 \6 & 167 & -68 \-4 & 24 & -41 end{pmatrix}.
First, we need to form a rotation matrix that will zero the lowermost left element, mathbf{a}_{31} = -4. We form this matrix using the
Givens rotation method, and call the matrix G_1. We will first rotate the vector 6,-4), to point along the "X" axis. This vector has an angle heta = arctan({-4 over 6}). We create the orthogonal Givens rotation matrix, G_1::G_1 = egin{pmatrix}1 & 0 & 0 \0 & cos( heta) & sin( heta) \0 & -sin( heta) & cos( heta)end{pmatrix}:approx egin{pmatrix}1 & 0 & 0 \0 & 0.83205 & -0.55470 \0 & 0.55470 & 0.83205end{pmatrix}
And the result of G_1A now has a zero in the mathbf{a}_{31} element.:G_1A approx egin{pmatrix}12 & -51 & 4 \7.21110 & 125.6396 & -33.83671 \0 & 112.6041 & -71.83368end{pmatrix}
We can similarly form Givens matrices G_2 and G_3, which will zero the sub-diagonal elements a_{21} and a_{32}, forming a triangular matrix R. The orthogonal matrix Q^T is formed from the concatenation of all the Givens matrices Q^T = G_3G_2G_1. Thus, we have G_3G_2G_1A= Q^TA = R, and the "QR" decomposition is A = QR.
Connection to a determinant or a product of eigenvalues
We can use QR decomposition to find the absolute value of the
determinant of a square matrix. Suppose a matrix is decomposed as A=QR. Then we have:det(A)=det(Q)cdotdet(R).Since "Q" is unitary, det(Q)|=1. Thus, :det(A)|=|det(R)|=Big|prod_{i} r_{ii}Big|,where r_{ii} are the entries on the diagonal of "R".Furthermore, because the determinant equals the product of the eigenvalues, we have :Big|prod_{i} r_{ii}Big|=Big|prod_{i} lambda_{i}Big|,where lambda_{i} are eigenvalues of A.
We can extend the above properties to non-square complex matrix A by introducing the definition of QR-decomposition for non-square complex matrixand replacing eigenvalues with singular values.
Suppose a QR decomposition for a non-square matrix "A"::A = Q egin{pmatrix}R\Oend{pmatrix}, qquad Q^*Q = I,where O is a zero matrix and Q is an unitary matrix.
From the properties of SVD and determinant of matrix, we have:Big|prod_{i} r_{ii}Big| = prod_{i} sigma_{i},where sigma_{i} are singular values of A.
Note that the singular values of A and R are identical, although the complex eigenvalues of them may be different.However, if "A" is square, it holds that:prod_{i} sigma_{i = Big|{prod_{i} lambda_{iBig|.
In conclusion, QR decomposition can be used efficiently to calculate a product of eigenvalues or singular values of matrix.
ee also
*
Polar decomposition
*Eigenvalue decomposition
*Spectral decomposition
*Matrix decomposition References
*.
*. Section 2.8.
*.External links
* [http://www.bluebit.gr/matrix-calculator/ Online Matrix Calculator] Performs QR decomposition of matrices.
* [http://netlib.org/lapack/lug/node39.html LAPACK users manual] gives details of subroutines to calculate the QR decomposition
* [http://documents.wolfram.com/mathematica/functions/QRDecomposition Mathematica users manual] gives details and examples of routines to calculate QR decomposition
* [http://math.fullerton.edu/mathews/n2003/QRMethodMod.html Module for the QR Method]
* [http://www.alglib.net/ ALGLIB] includes a partial port of the LAPACK to C++, C#, Delphi, etc.
Wikimedia Foundation. 2010.