Class LUDecompositionBase_CDRM

java.lang.Object
org.ejml.dense.row.decompose.lu.LUDecompositionBase_CDRM
All Implemented Interfaces:
DecompositionInterface<CMatrixRMaj>, LUDecomposition<CMatrixRMaj>, LUDecomposition_F32<CMatrixRMaj>
Direct Known Subclasses:
LUDecompositionAlt_CDRM

@Generated("org.ejml.dense.row.decompose.lu.LUDecompositionBase_ZDRM") public abstract class LUDecompositionBase_CDRM extends Object implements LUDecomposition_F32<CMatrixRMaj>

Contains common data structures and operations for LU decomposition algorithms.

  • Field Details

    • LU

      protected CMatrixRMaj LU
    • maxWidth

      protected int maxWidth
    • m

      protected int m
    • n

      protected int n
    • stride

      protected int stride
    • dataLU

      protected float[] dataLU
    • vv

      protected float[] vv
    • indx

      protected int[] indx
    • pivot

      protected int[] pivot
    • pivsign

      protected float pivsign
    • det

      protected Complex_F32 det
  • Constructor Details

    • LUDecompositionBase_CDRM

      public LUDecompositionBase_CDRM()
  • Method Details

    • setExpectedMaxSize

      public void setExpectedMaxSize(int numRows, int numCols)
    • getLU

      public CMatrixRMaj getLU()
    • getIndx

      public int[] getIndx()
    • getPivot

      public int[] getPivot()
    • inputModified

      public boolean inputModified()
      Description copied from interface: DecompositionInterface
      Checks if the input matrix to DecompositionInterface.decompose(org.ejml.data.Matrix) is modified during the decomposition process.
      Specified by:
      inputModified in interface DecompositionInterface<CMatrixRMaj>
      Returns:
      true if the input matrix to decompose() is modified.
    • getLower

      public CMatrixRMaj getLower(@Nullable @Nullable CMatrixRMaj lower)
      Writes the lower triangular matrix into the specified matrix.
      Specified by:
      getLower in interface LUDecomposition<CMatrixRMaj>
      Parameters:
      lower - Where the lower triangular matrix is written to.
      Returns:
      The L matrix.
    • getUpper

      public CMatrixRMaj getUpper(@Nullable @Nullable CMatrixRMaj upper)
      Writes the upper triangular matrix into the specified matrix.
      Specified by:
      getUpper in interface LUDecomposition<CMatrixRMaj>
      Parameters:
      upper - Where the upper triangular matrix is writen to.
      Returns:
      The U matrix.
    • getRowPivot

      public CMatrixRMaj getRowPivot(@Nullable @Nullable CMatrixRMaj pivot)
      Description copied from interface: LUDecomposition

      For numerical stability there are often row interchanges. This computes a pivot matrix that will undo those changes.

      Specified by:
      getRowPivot in interface LUDecomposition<CMatrixRMaj>
      Parameters:
      pivot - Storage for the pivot matrix. If null then a new matrix is returned. Modified.
      Returns:
      The pivot matrix.
    • getRowPivotV

      public int[] getRowPivotV(@Nullable @Nullable IGrowArray pivot)
      Description copied from interface: LUDecomposition
      Returns the row pivot vector
      Specified by:
      getRowPivotV in interface LUDecomposition<CMatrixRMaj>
      Parameters:
      pivot - (Optional) Storage for pivot vector
      Returns:
      The pivot vector
    • decomposeCommonInit

      protected void decomposeCommonInit(CMatrixRMaj a)
    • isSingular

      public boolean isSingular()
      Determines if the decomposed matrix is singular. This function can return false and the matrix be almost singular, which is still bad.
      Specified by:
      isSingular in interface LUDecomposition<CMatrixRMaj>
      Returns:
      true if singular false otherwise.
    • computeDeterminant

      public Complex_F32 computeDeterminant()
      Computes the determinant from the LU decomposition.
      Specified by:
      computeDeterminant in interface LUDecomposition_F32<CMatrixRMaj>
      Returns:
      The matrix's determinant.
    • quality

      public double quality()
    • _solveVectorInternal

      public void _solveVectorInternal(float[] vv)
      a specialized version of solve that avoid additional checks that are not needed.
    • solveL

      protected void solveL(float[] vv)
      Solve the using the lower triangular matrix in LU. Diagonal elements are assumed to be 1
    • _getVV

      public float[] _getVV()