Class SvdImplicitQrDecompose_FDRM
- All Implemented Interfaces:
DecompositionInterface<FMatrixRMaj>,SingularValueDecomposition<FMatrixRMaj>,SingularValueDecomposition_F32<FMatrixRMaj>
- Direct Known Subclasses:
SvdImplicitQrDecompose_MT_FDRM
Computes the Singular value decomposition of a matrix using the implicit QR algorithm for singular value decomposition. It works by first by transforming the matrix to a bidiagonal A=U*B*VT form, then it implicitly computing the eigenvalues of the BTB matrix, which are the same as the singular values in the original A matrix.
Based off of the description provided in:
David S. Watkins, "Fundamentals of Matrix Computations," Second Edition. Page 404-411
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected BidiagonalDecomposition_F32<FMatrixRMaj>protected booleanprotected booleanprotected booleanprotected booleanprotected intprotected intprotected intprotected intprotected booleanprotected booleanprotected SvdImplicitQrAlgorithm_FDRMprotected boolean -
Constructor Summary
ConstructorsConstructorDescriptionSvdImplicitQrDecompose_FDRM(boolean compact, boolean computeU, boolean computeV, boolean canUseTallBidiagonal) Configures the class -
Method Summary
Modifier and TypeMethodDescriptionprotected voidbooleandecompose(FMatrixRMaj orig) Computes the decomposition of the input matrix.float[]Returns the singular values.getU(@Nullable FMatrixRMaj U, boolean transpose) Returns the orthogonal 'U' matrix.getV(@Nullable FMatrixRMaj V, boolean transpose) Returns the orthogonal 'V' matrix.getW(@Nullable FMatrixRMaj W) Returns a diagonal matrix with the singular values.booleanChecks if the input matrix toDecompositionInterface.decompose(org.ejml.data.Matrix)is modified during the decomposition process.booleanIf true then compact matrices are returned.intThe number of singular values in the matrix.intnumCols()Number of columns in the decomposed matrix.intnumRows()Number of rows in the decomposed matrix.protected voidtranspose(@NotNull FMatrixRMaj V, FMatrixRMaj Vt)
-
Field Details
-
numRows
protected int numRows -
numCols
protected int numCols -
numRowsT
protected int numRowsT -
numColsT
protected int numColsT -
canUseTallBidiagonal
protected boolean canUseTallBidiagonal -
bidiag
-
qralg
-
compact
protected boolean compact -
computeU
protected boolean computeU -
computeV
protected boolean computeV -
prefComputeU
protected boolean prefComputeU -
prefComputeV
protected boolean prefComputeV -
transposed
protected boolean transposed
-
-
Constructor Details
-
SvdImplicitQrDecompose_FDRM
public SvdImplicitQrDecompose_FDRM(boolean compact, boolean computeU, boolean computeV, boolean canUseTallBidiagonal) Configures the class- Parameters:
compact- Compute a compact SVDcomputeU- If true it will compute the U matrixcomputeV- If true it will compute the V matrixcanUseTallBidiagonal- If true then it can choose to use a tall Bidiagonal decomposition to improve runtime performance.
-
-
Method Details
-
getSingularValues
public float[] getSingularValues()Description copied from interface:SingularValueDecomposition_F32Returns the singular values. This is the diagonal elements of the W matrix in the decomposition. Ordering of singular values is not guaranteed..- Specified by:
getSingularValuesin interfaceSingularValueDecomposition_F32<FMatrixRMaj>- Returns:
- Singular values. Note this array can be longer than the number of singular values. Extra elements have no meaning.
-
numberOfSingularValues
public int numberOfSingularValues()Description copied from interface:SingularValueDecompositionThe number of singular values in the matrix. This is equal to the length of the smallest side.- Specified by:
numberOfSingularValuesin interfaceSingularValueDecomposition<FMatrixRMaj>- Returns:
- Number of singular values in the matrix.
-
isCompact
public boolean isCompact()Description copied from interface:SingularValueDecompositionIf true then compact matrices are returned.- Specified by:
isCompactin interfaceSingularValueDecomposition<FMatrixRMaj>- Returns:
- true if results use compact notation.
-
getU
Description copied from interface:SingularValueDecompositionReturns the orthogonal 'U' matrix.
Internally the SVD algorithm might compute U transposed or it might not. To avoid an unnecessary double transpose the option is provided to select if the transpose is returned.
- Specified by:
getUin interfaceSingularValueDecomposition<FMatrixRMaj>- Parameters:
U- Optional storage for U. If null a new instance or internally maintained matrix is returned. Modified.transpose- If the returned U is transposed.- Returns:
- An orthogonal matrix.
-
getV
Description copied from interface:SingularValueDecompositionReturns the orthogonal 'V' matrix.
Internally the SVD algorithm might compute V transposed or it might not. To avoid an unnecessary double transpose the option is provided to select if the transpose is returned.
- Specified by:
getVin interfaceSingularValueDecomposition<FMatrixRMaj>- Parameters:
V- Optional storage for v. If null a new instance or internally maintained matrix is returned. Modified.transpose- If the returned V is transposed.- Returns:
- An orthogonal matrix.
-
transpose
-
getW
Description copied from interface:SingularValueDecompositionReturns a diagonal matrix with the singular values. Order of the singular values is not guaranteed.- Specified by:
getWin interfaceSingularValueDecomposition<FMatrixRMaj>- Parameters:
W- Optional storage for W. If null a new instance or internally maintained matrix is returned. Modified.- Returns:
- Diagonal matrix with singular values along the diagonal.
-
decompose
Description copied from interface:DecompositionInterfaceComputes the decomposition of the input matrix. Depending on the implementation the input matrix might be stored internally or modified. If it is modified then the functionDecompositionInterface.inputModified()will return true and the matrix should not be modified until the decomposition is no longer needed.- Specified by:
decomposein interfaceDecompositionInterface<FMatrixRMaj>- Parameters:
orig- The matrix which is being decomposed. Modification is implementation dependent.- Returns:
- Returns if it was able to decompose the matrix.
-
inputModified
public boolean inputModified()Description copied from interface:DecompositionInterfaceChecks if the input matrix toDecompositionInterface.decompose(org.ejml.data.Matrix)is modified during the decomposition process.- Specified by:
inputModifiedin interfaceDecompositionInterface<FMatrixRMaj>- Returns:
- true if the input matrix to decompose() is modified.
-
declareBidiagonalDecomposition
protected void declareBidiagonalDecomposition() -
numRows
public int numRows()Description copied from interface:SingularValueDecompositionNumber of rows in the decomposed matrix.- Specified by:
numRowsin interfaceSingularValueDecomposition<FMatrixRMaj>- Returns:
- Number of rows in the decomposed matrix.
-
numCols
public int numCols()Description copied from interface:SingularValueDecompositionNumber of columns in the decomposed matrix.- Specified by:
numColsin interfaceSingularValueDecomposition<FMatrixRMaj>- Returns:
- Number of columns in the decomposed matrix.
-