Class SvdImplicitQrAlgorithm_FDRM
java.lang.Object
org.ejml.dense.row.decomposition.svd.implicitqr.SvdImplicitQrAlgorithm_FDRM
@Generated("org.ejml.dense.row.decomposition.svd.implicitqr.SvdImplicitQrAlgorithm_DDRM")
public class SvdImplicitQrAlgorithm_FDRM
extends Object
 Computes the QR decomposition of a bidiagonal matrix. Internally this matrix is stored as
 two arrays. Shifts can either be provided to it or it can generate the shifts on its own.
 It optionally computes the U and V matrices. This comparability allows it to be used to
 compute singular values and associated matrices efficiently.
 
 A = U*S*VT
 where A is the original m by n matrix.
 
 Based off of the outline provided in:
 
 David S. Watkins, "Fundamentals of Matrix Computations," Second Edition. Page 404-411
 
Note: To watch it process the matrix step by step uncomment commented out code.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected float[]protected EigenvalueSmall_F32protected floatprotected intprotected intprotected intprotected intprotected float[]protected Randomprotected int[]protected intprotected @Nullable FMatrixRMajprotected @Nullable FMatrixRMajprotected intprotected int
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionboolean_process()protected booleanChecks to see if either the diagonal element or off diagonal element is zero.protected voidcomputeRotator(float rise, float run) Computes a rotator that will set run to zero (?)protected voidcreateBulge(int x1, float p, float scale, boolean byAngle) Performs a similar transform on BTB-pIprotected voideigenBB_2x2(int x1) Computes the eigenvalue of the 2 by 2 matrix BTBvoidIt is possible for the QR algorithm to get stuck in a loop because of symmetries.float[]getDiag()floatintfloat[]getOff()floatgetSingularValue(int index) float[]@Nullable FMatrixRMajgetUt()@Nullable FMatrixRMajgetVt()voidvoidinitParam(int M, int N) booleanisDiagonalZero(int i) booleanisOffZero(int i) booleanTells it to process the submatrix at the next split.voidperformImplicitSingleStep(float scale, float lambda, boolean byAngle) Given the lambda value perform an implicit QR step on the matrix.voidbooleanprocess()booleanprocess(float[] values) Perform a sequence of steps based off of the singular values provided.protected voidremoveBulgeLeft(int x1, boolean notLast) protected voidremoveBulgeRight(int x1) voidfloatselectWilkinsonShift(float scale) Selects the Wilkinson's shift for BTB.voidsetFastValues(boolean b) voidsetMatrix(int numRows, int numCols, float[] diag, float[] off) voidsetMaxValue(float maxValue) voidsetSubmatrix(int x1, int x2) voidsetUt(@Nullable FMatrixRMaj ut) voidsetVt(@Nullable FMatrixRMaj vt) float[]swapDiag(float[] diag) float[]swapOff(float[] off) protected voidupdateRotator(FMatrixRMaj Q, int m, int n, float c, float s) Multiplied a transpose orthogonal matrix Q by the specified rotator.
- 
Field Details- 
rand
- 
Ut
- 
Vt
- 
totalStepsprotected int totalSteps
- 
maxValueprotected float maxValue
- 
Nprotected int N
- 
eigenSmall
- 
numExceptionalprotected int numExceptional
- 
nextExceptionalprotected int nextExceptional
- 
diagprotected float[] diag
- 
offprotected float[] off
- 
x1protected int x1
- 
x2protected int x2
- 
splitsprotected int[] splits
- 
numSplitsprotected int numSplits
 
- 
- 
Constructor Details- 
SvdImplicitQrAlgorithm_FDRMpublic SvdImplicitQrAlgorithm_FDRM(boolean fastValues) 
- 
SvdImplicitQrAlgorithm_FDRMpublic SvdImplicitQrAlgorithm_FDRM()
 
- 
- 
Method Details- 
getUt
- 
setUt
- 
getVt
- 
setVt
- 
setMatrixpublic void setMatrix(int numRows, int numCols, float[] diag, float[] off) 
- 
swapDiagpublic float[] swapDiag(float[] diag) 
- 
swapOffpublic float[] swapOff(float[] off) 
- 
setMaxValuepublic void setMaxValue(float maxValue) 
- 
initParampublic void initParam(int M, int N) 
- 
processpublic boolean process()
- 
processpublic boolean process(float[] values) Perform a sequence of steps based off of the singular values provided.
- 
_processpublic boolean _process()
- 
incrementStepspublic void incrementSteps()
- 
isOffZeropublic boolean isOffZero(int i) 
- 
isDiagonalZeropublic boolean isDiagonalZero(int i) 
- 
resetStepspublic void resetSteps()
- 
nextSplitpublic boolean nextSplit()Tells it to process the submatrix at the next split. Should be called after the current submatrix has been processed.
- 
performImplicitSingleSteppublic void performImplicitSingleStep(float scale, float lambda, boolean byAngle) Given the lambda value perform an implicit QR step on the matrix. B^T*B-lambda*I- Parameters:
- lambda- Stepping factor.
 
- 
updateRotatorMultiplied a transpose orthogonal matrix Q by the specified rotator. This is used to update the U and V matrices. Updating the transpose of the matrix is faster since it only modifies the rows.- Parameters:
- Q- Orthogonal matrix
- m- Coordinate of rotator.
- n- Coordinate of rotator.
- c- cosine of rotator.
- s- sine of rotator.
 
- 
createBulgeprotected void createBulge(int x1, float p, float scale, boolean byAngle) Performs a similar transform on BTB-pI
- 
computeRotatorprotected void computeRotator(float rise, float run) Computes a rotator that will set run to zero (?)
- 
removeBulgeLeftprotected void removeBulgeLeft(int x1, boolean notLast) 
- 
removeBulgeRightprotected void removeBulgeRight(int x1) 
- 
setSubmatrixpublic void setSubmatrix(int x1, int x2) 
- 
selectWilkinsonShiftpublic float selectWilkinsonShift(float scale) Selects the Wilkinson's shift for BTB. See page 410. It is guaranteed to converge and converges fast in practice.- Parameters:
- scale- Scale factor used to help prevent overflow/underflow
- Returns:
- Shifting factor lambda/(scale*scale)
 
- 
eigenBB_2x2protected void eigenBB_2x2(int x1) Computes the eigenvalue of the 2 by 2 matrix BTB
- 
checkForAndHandleZerosprotected boolean checkForAndHandleZeros()Checks to see if either the diagonal element or off diagonal element is zero. If one is then it performs a split or pushes it off the matrix.- Returns:
- True if there was a zero.
 
- 
exceptionShiftpublic void exceptionShift()It is possible for the QR algorithm to get stuck in a loop because of symmetries. This happens more often with larger matrices. By taking a random step it can break the symmetry and finish.
- 
printMatrixpublic void printMatrix()
- 
getNumberOfSingularValuespublic int getNumberOfSingularValues()
- 
getSingularValuepublic float getSingularValue(int index) 
- 
setFastValuespublic void setFastValues(boolean b) 
- 
getSingularValuespublic float[] getSingularValues()
- 
getDiagpublic float[] getDiag()
- 
getOffpublic float[] getOff()
- 
getMaxValuepublic float getMaxValue()
 
-