An
square matrix
can be decomposed into a
product of a lower triangular matrix
and an upper
triangular matrix
,
![$\displaystyle {\bf A}=\left[ \begin{array}{cccc}
a_{11} & a_{12} & \cdots & a_{...
...ddots & \vdots \\
0 & 0 & \cdots & u_{NN} \end{array} \right]
={\bf L} {\bf U}$](img761.svg) |
(186) |
and the equation system
can be trivially
solved by two rounds of back substitution:
- Rewrite the equation as below and solve for
by back substitution (top-down):
data:image/s3,"s3://crabby-images/a0b9d/a0b9d87a46b6621928de9fee684b99563e604ad6" alt="$\displaystyle {\bf A}{\bf x}={\bf L}{\bf U}{\bf x}={\bf L}{\bf y}={\bf b}$" |
(187) |
- Solve the equation below for
by back substitution (bottom-up):
data:image/s3,"s3://crabby-images/aa1cb/aa1cbdbb621be05344f0057b4619e5fa725feb3b" alt="$\displaystyle {\bf U}{\bf x}={\bf y}$" |
(188) |
We now consider how to find
and
. The ijth element of
the equation
can be written as
data:image/s3,"s3://crabby-images/22f60/22f60ae193bdca75585d1f6bee217aa0fdbd1abd" alt="$\displaystyle a_{ij}=\sum_{k=1}^N l_{ik} u_{kj}=\sum_{k=1}^{min(i,j)} l_{ik} u_{kj},
\;\;\;\;\;\;\;\;(i,j=1,\cdots,N)$" |
(189) |
Note that there are
equations (one for each element) but
unknowns in both
and
. We can therefore arbitrarily
set the all diagonal elements of
to 1:
.
Moreover, as
and
are both triangular, we do not have
to solve an
nonlinear equations, as they can be disentangled if they
are solved in a specific order. Actually these equations can be solved in
iterations, each carried out in two steps for the jth column
(
):
, find
in step 1 and
in step 2;
, find
and
in step 1 and
in step 2;
-
, find
in step 1 and
in step 2;
, find
in step 1.
Note that in each iteration for the jth column, we find all
(
)
in the upper triangle of
, and all
(
) in the lower triangle
of
:
- For all
, i.e.,
(upper triangle), find all
by
data:image/s3,"s3://crabby-images/20bb2/20bb2dbe2a0c7ed7def4a24fb5b7e5285ffcb46b" alt="$\displaystyle a_{ij}=\sum_{k=1}^i l_{ik} u_{kj}$" |
(190) |
If
(when
)
data:image/s3,"s3://crabby-images/8690b/8690b5e6447e533b83e5715e341bcc3bc6edec1a" alt="$\displaystyle a_{1j}=l_{11}u_{1j}=u_{1j},\;\;\;\;\;u_{1j}=a_{1j}$" |
(191) |
We see that the first row of
is the same as the first two of
.
If
(when
),
data:image/s3,"s3://crabby-images/ca13c/ca13cde302f6e1186f2b041aa5772d7242fd8af1" alt="$\displaystyle a_{2j}=l_{21}u_{1j}+l_{22}u_{2j},\;\;\;\;\;u_{2j}=a_{2j}-l_{21}u_{1j}$" |
(192) |
where
has been obtained in previous iteration for
.
In general, for all
, we have
data:image/s3,"s3://crabby-images/e936e/e936e8516f506396301aebb229f8d0a6a1eea8a2" alt="$\displaystyle a_{ij}=\sum_{k=1}^i l_{ik}u_{kj},\;\;\;\;\;u_{ij}=a_{ij}-\sum_{k=1}^{i-1}l_{ik}u_{kj}$" |
(193) |
All
in the ith row of
have already been obtained
from previous iterations of
.
- For all
, i.e.,
(lower triangle), find all
by
data:image/s3,"s3://crabby-images/c445f/c445f86fcae853eb18d7e02cac80a3f1be596b29" alt="$\displaystyle a_{ij}=\sum_{k=1}^j l_{ik} u_{kj}$" |
(194) |
When
and
,
data:image/s3,"s3://crabby-images/534ba/534ba25e155d67931a9113edfe30149617872d25" alt="$\displaystyle a_{i1}=l_{i1}u_{11},\;\;\;\;\;\;l_{i1}=a_{i1}/u_{11}$" |
(195) |
where
has been found in step 1.
When
and
,
data:image/s3,"s3://crabby-images/c68f5/c68f5e015de8d7b2f71cca38fad5f8faf6b2244f" alt="$\displaystyle a_{i2}=l_{i1}u_{12}+l_{i2}u_{22},\;\;\;\;\;l_{i2}
=\frac{1}{u_{22}}\left(a_{i2}-l_{i1}u_{12}\right)$" |
(196) |
where
and
have been found in step 1.
In general, when
and
, we have
data:image/s3,"s3://crabby-images/a1112/a111242b183d261b1d6d8fec6ff5994372a10a98" alt="$\displaystyle a_{ij}=\sum_{k=1}^{j-1} l_{ik}u_{kj},\;\;\;\;\;\;l_{i2}
=\frac{1}{u_{jj}}\left(a_{ij}-\sum_{k=1}^{j-1} l_{ik}u_{kj}\right)$" |
(197) |
where
in the jth column of
have been found
in step 1.
Example
(for column 1)
(for column 2)
(for column 3)
Now the LU decomposition of
is:
The LU decomposition can be used to solve linear systems.
wheredata:image/s3,"s3://crabby-images/074fe/074fee7b49072196d0acee671a6bdf4bfb65cd1c" alt="$\displaystyle \;\;\;\;\;\;{\bf y}={\bf U}{\bf x}$" |
(198) |
We can first solve
for
by forward
substitution, and then solve
for
by backward substitution:
![$\displaystyle \left[ \begin{array}{cccc}
l_{11} & 0 & 0 & 0 \\
l_{21} & l_{22}...
...rray}\right]=
\left[\begin{array}{c}
b_1\\ b_2\\ \vdots\\ b_N\end{array}\right]$](img813.svg) |
(199) |
which can be easily solved for
by forward substitution:
data:image/s3,"s3://crabby-images/9752f/9752ff79996607117544a816865daea6992861a4" alt="$\displaystyle y_1=\frac{b_1}{l_{11}},\;\;\;\;\;\;\;\;\;
y_i=\frac{1}{l_{ii}}\left(b_i-\sum_{j=1}^{i-1} l_{ij}y_j\right),
\;\;\;\;\;\;(i=2,\cdots,N)$" |
(200) |
And then
can be found by solving
![$\displaystyle \left[ \begin{array}{cccc}
u_{11} & u_{12} & \cdots & u_{1N} \\
...
...ay}\right]
\left[\begin{array}{c}
y_1 \\ y_2 \\ \vdots \\ y_N\end{array}\right]$](img816.svg) |
(201) |
which can be easily solved by backward substitution:
data:image/s3,"s3://crabby-images/02e04/02e04f54b593f4c2563e7a8b9aff4cbe03921cdb" alt="$\displaystyle x_N=\frac{y_N}{u_{NN}},\;\;\;\;\;\;\;\;\;\;
x_i=\frac{1}{u_{ii}} \left(y_i-\sum_{j=i+1}^n u_{ij}x_j\right),
\;\;\;\;\;\;\;(i=N-1,\cdots,1)$" |
(202) |
Example
By LU decomposition, this system can be written as:
We first solve the system
to get
![$\displaystyle {\bf y}=[14, -17, 54]^T$](img821.svg) |
(203) |
We then solve the system
to get
.
The LU decomposition
can also be used to find the
inverse
that satisfies
![$\displaystyle {\bf A}{\bf A}^{-1}={\bf I}=diag(1,\cdots,1)=\left[{\bf e}_1,\cdots,{\bf e}_n \right]$](img825.svg) |
(204) |
where
is the ith column vector of the
identity matrix
with all element equal to 0 except the ith one which
is 1. The ith column
of
can be found by solving the following
data:image/s3,"s3://crabby-images/93d9e/93d9e8799012992127742810cc13839cb6f066ea" alt="$\displaystyle {\bf A}{\bf x}_i={\bf e}_i,\;\;\;\;\;\;\;(i=1,\cdots,n)$" |
(205) |
Example
Find the inverse of
Note that
where
,
, and
are the three columns of
, which can be found by solving three equation systems:
We use LU decomposition to get
i.e.,
Solving these three equation systems we get
i.e.,