LU Decomposition is a way to break a matrix down (factor) into the product of two matrices: one lower triangular and the other upper triangular. This LU product can be used to solve systems in the form
data:image/s3,"s3://crabby-images/13d34/13d3421436e9f5fa9c7c543d0d3d35982f3f41d4" alt=""
. Of course, the first question that should come to mind is why do we care? We have a perfectly acceptable method (Gauss-Jordan) to solve systems. Why do we need an extra method that entails matrix multiplication and computing inverses in addition to row reductions? It turns out that if we have many
data:image/s3,"s3://crabby-images/89653/89653421903279657dc97a9c45acb820346c43f3" alt=""
vectors that we need to solve the system for, then LU decomposition beats Gauss-Jordan in computational efficiency. We will take the following matrix as an example:
To begin with, if we say
data:image/s3,"s3://crabby-images/b6d07/b6d071d3a0f63265fa0db655e9d7373a35cd0698" alt=""
how do we find the
data:image/s3,"s3://crabby-images/9e9e6/9e9e6ac29dbef799bed09a203b79567158499969" alt=""
and
data:image/s3,"s3://crabby-images/69c56/69c56f589f8b389aeff784a973505b134400f8a8" alt=""
matrices? First we row reduce to find an upper triangular matrix:
To find
data:image/s3,"s3://crabby-images/ea474/ea4744d2a37775451a27f53c1c22039ef9d5f12a" alt=""
we can say
data:image/s3,"s3://crabby-images/d911a/d911a07edc557f559be0a9c3fdfda49afa7b5ad4" alt=""
. So we need to find
data:image/s3,"s3://crabby-images/0afa9/0afa9792626fce0f8dacc5fc54481c06a50df42e" alt=""
by row reducing
data:image/s3,"s3://crabby-images/d89d5/d89d560940b32224158822a1514941affe98f73b" alt=""
to
data:image/s3,"s3://crabby-images/9cd75/9cd756392ac891a309340541dc2122db8a506a96" alt=""
:
Next we apply the definition above to find
Now before moving on to solve a system, let's check our factorization:
So, doing the multiplication shows that this is the correct
data:image/s3,"s3://crabby-images/fc704/fc704953aa63a3d32140105b27f2e5fa5878a2d4" alt=""
factorization. Now let's try to solve the following system:
We can do this by saying
data:image/s3,"s3://crabby-images/bf083/bf083e56a1b733ff3f0b9e68d33ae53305ff84fa" alt=""
. We will say that
data:image/s3,"s3://crabby-images/5254b/5254b5377595b5b712d729f0ec0f00a48bf1492e" alt=""
so that
data:image/s3,"s3://crabby-images/49199/49199415fb2ae45415d7daaf10f8fdc8a4213cce" alt=""
. Next we will solve for
data:image/s3,"s3://crabby-images/965a7/965a7f1359850891b6a04f8bfb245193a41a5f61" alt=""
.
To solve for
data:image/s3,"s3://crabby-images/0b8bc/0b8bc56226779fc9036960974fd106340efa4653" alt=""
we will use the inverse method so that
data:image/s3,"s3://crabby-images/c1698/c1698656f8784c0e58123e381ef2ef2dfaf609ef" alt=""
. Again, to find
data:image/s3,"s3://crabby-images/87925/8792530f5ecb0eabe96b5c6c7ecf214cf4e88c3a" alt=""
we will row reduce:
Now we will solve
data:image/s3,"s3://crabby-images/48e54/48e5417e4077c8dabba7bafbda3818e9d302aae0" alt=""
with
data:image/s3,"s3://crabby-images/2cd1f/2cd1f55cb5a99a8ec0ae51a61647ddecef4d70bf" alt=""
where we luckily already have
data:image/s3,"s3://crabby-images/b65db/b65dbfce6cd767b47b60f4c293d0b66463b00773" alt=""
from previous operations:
And this is the final solution of the
data:image/s3,"s3://crabby-images/495ef/495ef188554c53e098fb99759d62b6d54b2ea53b" alt=""
system. Though this took the longest of any method, it is never practically implemented by hand. As mentioned before, its strengths lie in computing
data:image/s3,"s3://crabby-images/3cb5a/3cb5aac25bccc6b2f7bf90b7fad64881ad75823e" alt=""
for the same
data:image/s3,"s3://crabby-images/b1828/b1828638ef3b24e4d360a557361191d3b9ff934a" alt=""
over many
data:image/s3,"s3://crabby-images/dc7f4/dc7f41af2f60f10b096c8c748e82eddd01b5144b" alt=""
vectors.