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/616e5/616e523e1e7afcc4d866c72bac14cd3d2435cae3" alt=""
is returned by the function, the matrix
m2 will be assigned (resized if necessary) the matrix
data:image/s3,"s3://crabby-images/82ead/82ead2352ebfb3266085e4fd5724eaa25ec88191" alt=""
, and the matrix
m3 will be assigned (resized if necessary) the other matrix,
data:image/s3,"s3://crabby-images/27103/271038d3163e2f38419bfafb5c924aa827d60e2b" alt=""
, of the decomposition. The singular value decomposition satisfies:
where
data:image/s3,"s3://crabby-images/78e40/78e40fcbf4ac3b8f4a5b7d73ae3af8d01e5f46ac" 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/5e85b/5e85b373069c98483c390fd9bca6a2124e3000b3" alt=""
, W is
data:image/s3,"s3://crabby-images/b51bf/b51bfad2085da14789ae1ee13b2d5eb3d12f2521" alt=""
diagonal matrix with singular values on the diagonal, and V is
data:image/s3,"s3://crabby-images/2ced9/2ced96058949376dbfe5186e1709859ab84764bf" 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/44579/44579d9ba2c1e9d0babfe6a33f3e4c5a4dcba2dd" alt=""
, W is a
data:image/s3,"s3://crabby-images/2f758/2f7587117e517f891232d48a45a239370453f57c" alt=""
matrix with the singular values on the main diagonal and V is a
data:image/s3,"s3://crabby-images/b9f86/b9f86b2bbbee474df647ae1db9a6ca54b7a16deb" 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.