Class CholeskyDecompositionLDL_DDRM
java.lang.Object
org.ejml.dense.row.decomposition.chol.CholeskyDecompositionLDL_DDRM
- All Implemented Interfaces:
org.ejml.interfaces.decomposition.CholeskyLDLDecomposition<org.ejml.data.DMatrixRMaj>,org.ejml.interfaces.decomposition.CholeskyLDLDecomposition_F64<org.ejml.data.DMatrixRMaj>,org.ejml.interfaces.decomposition.DecompositionInterface<org.ejml.data.DMatrixRMaj>
public class CholeskyDecompositionLDL_DDRM
extends java.lang.Object
implements org.ejml.interfaces.decomposition.CholeskyLDLDecomposition_F64<org.ejml.data.DMatrixRMaj>
This variant on the Cholesky decomposition avoid the need to take the square root
by performing the following decomposition:
L*D*LT=A
where L is a lower triangular matrix with zeros on the diagonal. D is a diagonal matrix.
The diagonal elements of L are equal to one.
Unfortunately the speed advantage of not computing the square root is washed out by the increased number of array accesses. There only appears to be a slight speed boost for very small matrices.
-
Constructor Summary
Constructors Constructor Description CholeskyDecompositionLDL_DDRM() -
Method Summary
Modifier and Type Method Description double[]_getVV()booleandecompose(org.ejml.data.DMatrixRMaj mat)Performs Choleksy decomposition on the provided matrix.org.ejml.data.DMatrixRMajgetD(@Nullable org.ejml.data.DMatrixRMaj D)double[]getDiagonal()Diagonal elements of the diagonal D matrix.org.ejml.data.DMatrixRMajgetL()Returns L matrix from the decomposition.
L*D*LT=Aorg.ejml.data.DMatrixRMajgetL(@Nullable org.ejml.data.DMatrixRMaj L)booleaninputModified()voidsetExpectedMaxSize(int numRows, int numCols)
-
Constructor Details
-
CholeskyDecompositionLDL_DDRM
public CholeskyDecompositionLDL_DDRM()
-
-
Method Details
-
setExpectedMaxSize
public void setExpectedMaxSize(int numRows, int numCols) -
decompose
public boolean decompose(org.ejml.data.DMatrixRMaj mat)Performs Choleksy decomposition on the provided matrix.
If the matrix is not positive definite then this function will return false since it can't complete its computations. Not all errors will be found.
- Specified by:
decomposein interfaceorg.ejml.interfaces.decomposition.DecompositionInterface<org.ejml.data.DMatrixRMaj>- Parameters:
mat- A symmetric n by n positive definite matrix.- Returns:
- True if it was able to finish the decomposition.
-
inputModified
public boolean inputModified()- Specified by:
inputModifiedin interfaceorg.ejml.interfaces.decomposition.DecompositionInterface<org.ejml.data.DMatrixRMaj>
-
getDiagonal
public double[] getDiagonal()Diagonal elements of the diagonal D matrix.- Specified by:
getDiagonalin interfaceorg.ejml.interfaces.decomposition.CholeskyLDLDecomposition_F64<org.ejml.data.DMatrixRMaj>- Returns:
- diagonal elements of D
-
getL
public org.ejml.data.DMatrixRMaj getL()Returns L matrix from the decomposition.
L*D*LT=A- Returns:
- A lower triangular matrix.
-
_getVV
public double[] _getVV() -
getL
public org.ejml.data.DMatrixRMaj getL(@Nullable @Nullable org.ejml.data.DMatrixRMaj L)- Specified by:
getLin interfaceorg.ejml.interfaces.decomposition.CholeskyLDLDecomposition<org.ejml.data.DMatrixRMaj>
-
getD
public org.ejml.data.DMatrixRMaj getD(@Nullable @Nullable org.ejml.data.DMatrixRMaj D)- Specified by:
getDin interfaceorg.ejml.interfaces.decomposition.CholeskyLDLDecomposition<org.ejml.data.DMatrixRMaj>
-