LU decomposition of matrix.
Syntax: @lu(M, L, U)
M: matrix
L: matrix
U: matrix
Return: matrix (P)
Performs an LU decomposition with partial (row) pivoting of the matrix M:
• if
M is a square
data:image/s3,"s3://crabby-images/9335a/9335a241a59d592316371660b5d764bd365a7848" alt=""
produce a unit lower triangular matrix,
L, an upper triangular matrix,
U, and a row permutation matrix,
P, such that
data:image/s3,"s3://crabby-images/19e8e/19e8eeab51040ba2633db37634a69d6ae941341f" alt=""
.
• if
M is a non-square
data:image/s3,"s3://crabby-images/ce820/ce8209a1295c1905e145fdce9f2cfe40091fa816" alt=""
matrix, if
data:image/s3,"s3://crabby-images/18a32/18a3215833a8d6428675bd47ba2f3bab7b7c6648" alt=""
,
L will be unit lower trapezoidal (rather than triangular), and if
data:image/s3,"s3://crabby-images/f0bc2/f0bc2f0580e3e2d4a6f9c609250914b551929645" alt=""
,
U will be upper trapezoidal (rather than triangular).
Examples
matrix m = @mnrnd(10, 8)
matrix lmat
matrix umat
matrix pmat = @lu(m, lmat, umat)
generates the random matrix M, then performs the LU decomposition returning PMAT and yielding updated LMAT, UMAT.
The following commands validate the definition
matrix m1 = pmat * lmat * umat
matrix diff = m - m1
since DIFF equals zero.
Cross-references