Class HessenbergSimilarDecomposition_DDRM
- java.lang.Object
-
- org.ejml.dense.row.decomposition.hessenberg.HessenbergSimilarDecomposition_DDRM
-
- All Implemented Interfaces:
org.ejml.interfaces.decomposition.DecompositionInterface<org.ejml.data.DMatrixRMaj>
public class HessenbergSimilarDecomposition_DDRM extends java.lang.Object implements org.ejml.interfaces.decomposition.DecompositionInterface<org.ejml.data.DMatrixRMaj>Finds the decomposition of a matrix in the form of:
A = OHOT
where A is an m by m matrix, O is an orthogonal matrix, and H is an upper Hessenberg matrix.A matrix is upper Hessenberg if aij = 0 for all i > j+1. For example, the following matrix is upper Hessenberg.
WRITE IT OUT USING A TABLEThis decomposition is primarily used as a step for computing the eigenvalue decomposition of a matrix. The basic algorithm comes from David S. Watkins, "Fundamentals of MatrixComputations" Second Edition.
-
-
Constructor Summary
Constructors Constructor Description HessenbergSimilarDecomposition_DDRM()HessenbergSimilarDecomposition_DDRM(int initialSize)Creates a decomposition that won't need to allocate new memory if it is passed matrices up to the specified size.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description booleandecompose(org.ejml.data.DMatrixRMaj A)Computes the decomposition of the provided matrix.double[]getGammas()org.ejml.data.DMatrixRMajgetH(org.ejml.data.DMatrixRMaj H)An upper Hessenberg matrix from the decomposition.org.ejml.data.DMatrixRMajgetQ(org.ejml.data.DMatrixRMaj Q)An orthogonal matrix that has the following property: H = QTAQorg.ejml.data.DMatrixRMajgetQH()The raw QH matrix that is stored internally.booleaninputModified()
-
-
-
Constructor Detail
-
HessenbergSimilarDecomposition_DDRM
public HessenbergSimilarDecomposition_DDRM(int initialSize)
Creates a decomposition that won't need to allocate new memory if it is passed matrices up to the specified size.- Parameters:
initialSize- Expected size of the matrices it will decompose.
-
HessenbergSimilarDecomposition_DDRM
public HessenbergSimilarDecomposition_DDRM()
-
-
Method Detail
-
decompose
public boolean decompose(org.ejml.data.DMatrixRMaj A)
Computes the decomposition of the provided matrix. If no errors are detected then true is returned, false otherwise.- Specified by:
decomposein interfaceorg.ejml.interfaces.decomposition.DecompositionInterface<org.ejml.data.DMatrixRMaj>- Parameters:
A- The matrix that is being decomposed. Not modified.- Returns:
- If it detects any errors or not.
-
inputModified
public boolean inputModified()
- Specified by:
inputModifiedin interfaceorg.ejml.interfaces.decomposition.DecompositionInterface<org.ejml.data.DMatrixRMaj>
-
getQH
public org.ejml.data.DMatrixRMaj getQH()
The raw QH matrix that is stored internally.- Returns:
- QH matrix.
-
getH
public org.ejml.data.DMatrixRMaj getH(org.ejml.data.DMatrixRMaj H)
An upper Hessenberg matrix from the decomposition.- Parameters:
H- If not null then the results will be stored here. Otherwise a new matrix will be created.- Returns:
- The extracted H matrix.
-
getQ
public org.ejml.data.DMatrixRMaj getQ(org.ejml.data.DMatrixRMaj Q)
An orthogonal matrix that has the following property: H = QTAQ- Parameters:
Q- If not null then the results will be stored here. Otherwise a new matrix will be created.- Returns:
- The extracted Q matrix.
-
getGammas
public double[] getGammas()
-
-