Linear equations with Python: the QR decomposition

Hdemo Magazines Team
Hdemo Magazines
Published in
3 min readDec 1, 2015

In this second article on methods for solving systems of linear equations using Python, we will see the QR Decomposition method.

This method is very similar to the LU decomposition. The equation to be solved is of the form Ax = B. In this particular case, the matrix A = QR, where Q is an orthogonal matrix and R is an upper triangular matrix.

What are the properties of an orthogonal matrix?

  • It is a square matrix;
  • Multiplying Q for its transpose, we obtain the identity matrix;
  • The inverse of an orthogonal matrix is equal to its transpose.

Moreover, from matrix algebra we remember that if A has n linearly independent columns, then the first n columns of Q form an orthonormal basis for the space of columns of A. In general, the first k columns of Q form an orthonormal basis for the subspace of the first k columns of A, for each

An identity matrix is a square matrix in which the elements of the main diagonal are 1 and all other elements are zeros.

Now you can restate the initial problem

this way:

We use the same variables as the LU decomposition example and using the function qr of scipy.linalg we calculate Q and R. Finally we assign to the variable y the value of

""" QR decomposition with scipy """ 
import scipy.linalg as linalg
import numpy as np # same matrix A and B as in LU decomposition
A = np.array([ [2., 1., 1.], [1., 3., 2.], [1., 0., 0]])
B = np.array([4., 5., 6.])
Q, R = linalg.qr(A) # QR decomposition with qr function
y = np.dot(Q.T, B) # Let y=Q'.B using matrix multiplication
x = linalg.solve(R, y) # Solve Rx=y
print x

Note that

is simply the transpose of Q, which is in turn equal to the inverse of Q.

We get the same results as in the LU decomposition example:

[ 6. 15. -23.]

Originally published at www.italiandirectory.ru on December 1, 2015.

--

--

Hdemo Magazines Team
Hdemo Magazines

We are the Hdemo Magazines editorial team, a unique pool of copywriters and engineers to get you through technologies, science and culture.