Singular value decomposition (full) of matrix
Syntax: @svdfull(m1, m2, m3)
m1: matrix, sym
m2: matrix
m3: matrix, sym
Return: matrix
Performs a singular value decomposition of the matrix m1.
The matrix
data:image/s3,"s3://crabby-images/3f20f/3f20f5b74eeb746cc46d8b824cbed9e8cffbaecc" alt=""
is returned by the function, the matrix
m2 will be assigned (resized if necessary) the matrix
data:image/s3,"s3://crabby-images/6d658/6d6582a4163678731c0fd6f25a08565b4a25fb93" alt=""
, and the matrix
m3 will be assigned (resized if necessary) the other matrix,
data:image/s3,"s3://crabby-images/37882/37882159d35b15cd44dee3c0955abdb09a99d4d4" alt=""
, of the decomposition. The singular value decomposition satisfies:
where
data:image/s3,"s3://crabby-images/926b9/926b94503e223c5748da7b9d1e9ce6aaad22dd73" alt=""
is a diagonal matrix with the singular values along the diagonal. Singular values close to zero indicate that the matrix may not be of full rank. See the
@rank function for a related discussion.
Examples
matrix x = @mnrnd(5, 7)
matrix w
matrix v
matrix u = @svdfull(x, w, v)
performs the full SVD of the matrix X. U is
data:image/s3,"s3://crabby-images/638c1/638c1879931320a4a6c1856f331d722b09af31ec" alt=""
, W is
data:image/s3,"s3://crabby-images/8ac55/8ac5581648382cbfb61bf98884a7dfe8a6079e37" alt=""
diagonal matrix with singular values on the diagonal, and V is
data:image/s3,"s3://crabby-images/fb911/fb9115222b534a709829bf4fcc6b37b34a39a687" alt=""
.
Alternately, if the rank is less than the number of rows,
matrix x = @mnrnd(7, 5)
matrix u = @svdfull(x, w, v)
then U is
data:image/s3,"s3://crabby-images/170df/170df5f6d9933c45db71c4cb2835ce8066a49a49" alt=""
, W is a
data:image/s3,"s3://crabby-images/bc1bd/bc1bd538f450487c8dd66f7c5830e229a00f1699" alt=""
matrix with the singular values on the main diagonal and V is a
data:image/s3,"s3://crabby-images/2a960/2a960b3ca53488e450735ac3094153dab23df796" alt=""
matrix.
In both cases, the following demonstrate the properties of the decomposition:
sym i1 = @inner(u)
sym i2 = @inner(v)
matrix x1 = u * w * v.@t
where I1 and I2 and the identity matrix, and X1 is equal to X.
Cross-references
See also
@svd,
@cholesky,
@lu and
@qr.