Letting be or ,
the full SVD of a matrix
, if k = min(m,n)
, is defined as
Arguments
- A
(Tensor): tensor of shape
(*, m, n)
where*
is zero or more batch dimensions.- full_matrices
(bool, optional): controls whether to compute the full or reduced SVD, and consequently, the shape of the returned tensors
U
andV
. Default:TRUE
.
Value
A list (U, S, V)
which corresponds to , , above.
S
will always be real-valued, even when A
is complex.
It will also be ordered in descending order.
U
and V
will have the same dtype as A
. The left / right singular vectors will be given by
the columns of U
and the rows of V
respectively.
Details
where , is the conjugate transpose when is complex, and the transpose when is real-valued.
The matrices , (and thus ) are orthogonal in the real case, and unitary in the complex case.
When m > n
(resp. m < n
) we can drop the last m - n
(resp. n - m
) columns of U
(resp. V
) to form the reduced SVD:
where .
In this case, and also have orthonormal columns. Supports input of float, double, cfloat and cdouble dtypes.
Also supports batches of matrices, and if A
is a batch of matrices then
the output has the same batch dimensions.
The returned decomposition is a named tuple (U, S, V)
which corresponds to , , above.
The singular values are returned in descending order.
The parameter full_matrices
chooses between the full (default) and reduced SVD.
Note
When full_matrices=TRUE
, the gradients with respect to U[..., :, min(m, n):]
and Vh[..., min(m, n):, :]
will be ignored, as those vectors can be arbitrary bases
of the corresponding subspaces.
Warnings
The returned tensors U
and V
are not unique, nor are they continuous with
respect to A
.
Due to this lack of uniqueness, different hardware and software may compute
different singular vectors.
This non-uniqueness is caused by the fact that multiplying any pair of singular
vectors by -1
in the real case or by
in the complex case produces another two
valid singular vectors of the matrix.
This non-uniqueness problem is even worse when the matrix has repeated singular values.
In this case, one may multiply the associated singular vectors of U
and V
spanning
the subspace by a rotation matrix and the resulting vectors will span the same subspace.
Gradients computed using U
or V
will only be finite when
A
does not have zero as a singular value or repeated singular values.
Furthermore, if the distance between any two singular values is close to zero,
the gradient will be numerically unstable, as it depends on the singular values
through the computation of
.
The gradient will also be numerically unstable when A
has small singular
values, as it also depends on the computaiton of .
See also
linalg_svdvals()
computes only the singular values. Unlikelinalg_svd()
, the gradients oflinalg_svdvals()
are always numerically stable.linalg_eig()
for a function that computes another type of spectral decomposition of a matrix. The eigendecomposition works just on on square matrices.linalg_eigh()
for a (faster) function that computes the eigenvalue decomposition for Hermitian and symmetric matrices.linalg_qr()
for another (much faster) decomposition that works on general matrices.
Other linalg:
linalg_cholesky_ex()
,
linalg_cholesky()
,
linalg_det()
,
linalg_eigh()
,
linalg_eigvalsh()
,
linalg_eigvals()
,
linalg_eig()
,
linalg_householder_product()
,
linalg_inv_ex()
,
linalg_inv()
,
linalg_lstsq()
,
linalg_matrix_norm()
,
linalg_matrix_power()
,
linalg_matrix_rank()
,
linalg_multi_dot()
,
linalg_norm()
,
linalg_pinv()
,
linalg_qr()
,
linalg_slogdet()
,
linalg_solve_triangular()
,
linalg_solve()
,
linalg_svdvals()
,
linalg_tensorinv()
,
linalg_tensorsolve()
,
linalg_vector_norm()
Examples
if (torch_is_installed()) {
a <- torch_randn(5, 3)
linalg_svd(a, full_matrices = FALSE)
}
#> [[1]]
#> torch_tensor
#> -0.0445 0.3368 -0.7746
#> -0.8789 -0.1809 0.1178
#> -0.0135 0.8168 0.1631
#> -0.4666 0.3359 -0.0405
#> 0.0876 0.2717 0.5983
#> [ CPUFloatType{5,3} ]
#>
#> [[2]]
#> torch_tensor
#> 2.7608
#> 1.9651
#> 0.9611
#> [ CPUFloatType{3} ]
#>
#> [[3]]
#> torch_tensor
#> -0.0630 -0.9964 0.0561
#> 0.9145 -0.0351 0.4031
#> 0.3997 -0.0767 -0.9134
#> [ CPUFloatType{3,3} ]
#>