Singular-value soft-thresholding¶
Overwrites \(A\) with \(U S_{\tau}(\Sigma) V^H\), where \(U \Sigma V^H\) is the singular-value decomposition of \(A\) upon input and \(S_{\tau}\) performs soft-thresholding with parameter \(\tau\). The return value is the rank of the soft-thresholded matrix.
Standard algorithm¶
Runs the default SVT algorithm. In the sequential case, this is currently svt::Normal, and, in the parallel case, it is svt::Cross.
C++ API¶
C API¶
Approximate algorithm¶
Runs a faster (for small ranks), but less accurate, algorithm given an upper bound on the rank of the soft-thresholded matrix. The current implementation preprocesses via relaxedRank steps of (Businger-Golub) column-pivoted QR via the routine svt::PivotedQR.
C++ API¶
C API¶
TODO
Tall-skinny algorithm¶
Runs an SVT algorithm designed for tall-skinny matrices. The current implementation is based on TSQR factorization and is svt::TSQR.
C API¶
TODO
namespace svt¶
-
Int
svt
::
Normal
(ElementalMatrix<F> &A, Base<F> tau, bool relative = false)¶ Runs a standard SVD, soft-thresholds the singular values, and then reforms the matrix.
-
Int
svt
::
Cross
(ElementalMatrix<F> &A, Base<F> tau, bool relative = false)¶ Forms the normal matrix, computes its Hermitian EVD, soft-thresholds the eigenvalues, and then reforms the matrix. Note that Elemental’s parallel Hermitian EVD is much faster than its parallel SVD; this is typically worth the loss of accuracy in the computed small (truncated) singular values and is therefore the default choice for parallel SVT.