Class CholeskyDecompositionLDL_DDRM
- All Implemented Interfaces:
CholeskyLDLDecomposition<DMatrixRMaj>
,CholeskyLDLDecomposition_F64<DMatrixRMaj>
,DecompositionInterface<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
-
Method Summary
Modifier and TypeMethodDescriptiondouble[]
_getVV()
boolean
decompose
(DMatrixRMaj mat) Performs Choleksy decomposition on the provided matrix.getD
(@Nullable DMatrixRMaj D) Returns the diagonal matrixfrom the decomposition.double[]
Diagonal elements of the diagonal D matrix.getL()
Returns L matrix from the decomposition.
L*D*LT=AgetL
(@Nullable DMatrixRMaj L) Returns the lower triangular matrix from the decomposition.boolean
Checks if the input matrix toDecompositionInterface.decompose(org.ejml.data.Matrix)
is modified during the decomposition process.void
setExpectedMaxSize
(int numRows, int numCols)
-
Constructor Details
-
CholeskyDecompositionLDL_DDRM
public CholeskyDecompositionLDL_DDRM()
-
-
Method Details
-
setExpectedMaxSize
public void setExpectedMaxSize(int numRows, int numCols) -
decompose
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:
decompose
in interfaceDecompositionInterface<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()Description copied from interface:DecompositionInterface
Checks if the input matrix toDecompositionInterface.decompose(org.ejml.data.Matrix)
is modified during the decomposition process.- Specified by:
inputModified
in interfaceDecompositionInterface<DMatrixRMaj>
- Returns:
- true if the input matrix to decompose() is modified.
-
getDiagonal
public double[] getDiagonal()Diagonal elements of the diagonal D matrix.- Specified by:
getDiagonal
in interfaceCholeskyLDLDecomposition_F64<DMatrixRMaj>
- Returns:
- diagonal elements of D
-
getL
Returns L matrix from the decomposition.
L*D*LT=A- Returns:
- A lower triangular matrix.
-
_getVV
public double[] _getVV() -
getL
Description copied from interface:CholeskyLDLDecomposition
Returns the lower triangular matrix from the decomposition.
If an input is provided that matrix is used to write the results to. Otherwise a new matrix is created and the results written to it.
- Specified by:
getL
in interfaceCholeskyLDLDecomposition<DMatrixRMaj>
- Parameters:
L
- If not null then the decomposed matrix is written here.- Returns:
- A lower triangular matrix.
-
getD
Description copied from interface:CholeskyLDLDecomposition
Returns the diagonal matrixfrom the decomposition.
If an input is provided that matrix is used to write the results to. Otherwise a new matrix is created and the results written to it.
- Specified by:
getD
in interfaceCholeskyLDLDecomposition<DMatrixRMaj>
- Parameters:
D
- If not null it will be used to store the diagonal matrix- Returns:
- D Square diagonal matrix
-