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/7a2e7/7a2e71d937b9ef67b0888d4d7bd025a049db01a4" 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/7edf0/7edf031146610cf2a737ba1aff861b03b001f2d2" alt=""
.
• if
M is a non-square
data:image/s3,"s3://crabby-images/2d1cd/2d1cdb73e282a52d86943f851bffbda322d7abf0" alt=""
matrix, if
data:image/s3,"s3://crabby-images/24e02/24e0225960678cc2c5c30b95aa9e93e393e064ee" alt=""
,
L will be unit lower trapezoidal (rather than triangular), and if
data:image/s3,"s3://crabby-images/a6bec/a6becb5db90e980f47d0a359f65ad3647c71adc1" 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