Class CommonOps_CDRM
- 
Method SummaryModifier and TypeMethodDescriptionstatic voidPerforms the following operation:
 
 c = a + b
 cij = aij + bijstatic CMatrixRMaj[]columnsToVector(CMatrixRMaj A, @Nullable CMatrixRMaj[] v) Converts the columns in a matrix into a set of vectors.static CMatrixD1conjugate(CMatrixD1 input, @Nullable CMatrixRMaj output) Computes the complex conjugate of the input matrix.
 
 reali,j = reali,j
 imaginaryi,j = -1*imaginaryi,jstatic voidConverts the real matrix into a complex matrix.static Complex_F32det(CMatrixRMaj mat) Returns the determinant of the matrix.static CMatrixRMajdiag(float... data) Creates a new square matrix whose diagonal elements are specified by data and all the other elements are zero.
 
 aij = 0 if i ≤ j
 aij = diag[i] if i = jstatic CMatrixRMajdiag(@Nullable CMatrixRMaj output, int N, float... data) static CMatrixRMajelementDivide(float real, float imaginary, CMatrixD1 input, @Nullable CMatrixRMaj output) Performs element by element division operation with a complex number on the right
 
 outputij = (real + imaginary*i) / inputijstatic CMatrixRMajelementDivide(CMatrixD1 input, float real, float imaginary, @Nullable CMatrixRMaj output) Performs element by element division operation with a complex number on the right
 
 outputij = inputij / (real + imaginary*i)static CMatrixRMajelementDivide(CMatrixD1 inputA, CMatrixD1 inputB, @Nullable CMatrixRMaj output) Performs complex division between two matrices with the same shape element by element.
 
 outputij = inputAij / inputBijstatic floatReturns the largest absolute value of any element in the matrix.
 
 Max{ |aij| } for all i and jstatic floatReturns the value of the imaginary element in the matrix that has the minimum value.
 
 Min{ aij } for all i and jstatic floatReturns the magnitude squared of the complex element with the largest magnitude
 
 Max{ |aij|^2 } for all i and jstatic floatReturns the value of the real element in the matrix that has the minimum value.
 
 Min{ aij } for all i and jstatic floatReturns the smallest absolute value of any element in the matrix.
 
 Min{ |aij| } for all i and jstatic floatReturns the value of the imaginary element in the matrix that has the minimum value.
 
 Min{ aij } for all i and jstatic floatReturns the value of the real element in the matrix that has the minimum value.
 
 Min{ aij } for all i and jstatic CMatrixRMajelementMultiply(CMatrixD1 input, float real, float imaginary, @Nullable CMatrixRMaj output) Performs element by element multiplication operation with a complex number
 
 outputij = inputij * (real + imaginary*i)static CMatrixRMajelementMultiply(CMatrixD1 inputA, CMatrixD1 inputB, @Nullable CMatrixRMaj output) Performs complex multiplication between two matrices with the same shape element by element.
 
 outputij = inputAij * inputBijstatic CMatrixRMajelementPower(CMatrixD1 input, float b, @Nullable CMatrixRMaj output) Element by element complex power
 
 outputij = inputAij / inputBijstatic Complex_F32elementSum(CMatrixD1 input, @Nullable Complex_F32 output) Computes the sum of all the elements in the matrix:
 
 sum(i=1:m , j=1:n ; aij)static CMatrixRMajextract(CMatrixRMaj src, int srcY0, int srcY1, int srcX0, int srcX1) Creates a new matrix which is the specified submatrix of 'src'static voidextract(CMatrixRMaj src, int srcY0, int srcY1, int srcX0, int srcX1, CMatrixRMaj dst, int dstY0, int dstX0) Extracts a submatrix from 'src' and inserts it in a submatrix in 'dst'.static voidextractDiag(CMatrixRMaj src, CMatrixRMaj dst) Extracts the diagonal elements 'src' write it to the 'dst' vector.static voidSets every element in the matrix to the specified value.
 
 aij = valuestatic CMatrixRMajidentity(int width) Creates an identity matrix of the specified size.
 
 aij = 0+0i if i ≠ j
 aij = 1+0i if i = jstatic CMatrixRMajidentity(int width, int height) Creates a matrix with diagonal elements set to 1 and the rest 0.
 
 aij = 0+0i if i ≠ j
 aij = 1+0i if i = jstatic FMatrixRMajimaginary(CMatrixD1 input, @Nullable FMatrixRMaj output) Places the imaginary component of the input matrix into the output matrix.static booleanPerforms a matrix inversion operation on the specified matrix and stores the results in the same matrix.
 
 a = a-1static booleaninvert(CMatrixRMaj input, CMatrixRMaj output) Performs a matrix inversion operation that does not modify the original and stores the results in another matrix.static FMatrixRMajmagnitude(CMatrixD1 input, @Nullable FMatrixRMaj output) Computes the magnitude of the complex number in the input matrix and stores the results in the output matrix.static voidmult(float realAlpha, float imgAlpha, CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation:
 
 c = α * a * b
 
 cij = α ∑k=1:n { * aik * bkj}static voidmult(CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation:
 
 c = a * b
 
 cij = ∑k=1:n { * aik * bkj}static voidmultAdd(float realAlpha, float imgAlpha, CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation:
 
 c = c + α * a * b
 cij = cij + α * ∑k=1:n { aik * bkj}static voidmultAdd(CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation:
 
 c = c + a * b
 cij = cij + ∑k=1:n { aik * bkj}static voidmultAddTransA(float realAlpha, float imagAlpha, CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation:
 
 c = c + α * aH * b
 cij =cij + α * ∑k=1:n { aki * bkj}static voidmultAddTransA(CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation:
 
 c = c + aH * b
 cij = cij + ∑k=1:n { aki * bkj}static voidmultAddTransAB(float realAlpha, float imagAlpha, CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation:
 
 c = c + α * aH * bH
 cij = cij + α * ∑k=1:n { aki * bjk}static voidmultAddTransAB(CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation:
 
 c = c + aH * bH
 cij = cij + ∑k=1:n { aki * bjk}static voidmultAddTransB(float realAlpha, float imagAlpha, CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation:
 
 c = c + α * a * bH
 cij = cij + α * ∑k=1:n { aik * bjk}static voidmultAddTransB(CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation:
 
 c = c + a * bH
 cij = cij + ∑k=1:n { aik * bjk}static voidmultTransA(float realAlpha, float imagAlpha, CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation:
 
 c = α * aH * b
 
 cij = α ∑k=1:n { aki * bkj}static voidmultTransA(CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation:
 
 c = aH * b
 
 cij = ∑k=1:n { aki * bkj}static voidmultTransAB(float realAlpha, float imagAlpha, CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation:
 
 c = α * aH * bH
 cij = α ∑k=1:n { aki * bjk}static voidmultTransAB(CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation:
 
 c = aT * bT
 cij = ∑k=1:n { aki * bjk}static voidmultTransB(float realAlpha, float imagAlpha, CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation:
 
 c = α * a * bH
 cij = α ∑k=1:n { aik * bjk}static voidmultTransB(CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation:
 
 c = a * bH
 cij = ∑k=1:n { aik * bjk}static FMatrixRMajreal(CMatrixD1 input, @Nullable FMatrixRMaj output) Places the real component of the input matrix into the output matrix.static voidPerforms an in-place element by element scalar multiplication.
 
 aij = α*aijstatic voidsetIdentity(CMatrixRMaj mat) Sets all the diagonal elements equal to one and everything else equal to zero.static booleansolve(CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj x) Solves for x in the following equation:
 
 A*x = bstatic voidPerforms the following operation:
 
 c = a - b
 cij = aij - bijstatic Complex_F32trace(CMatrixRMaj input, @Nullable Complex_F32 output) Computes the matrix trace:
 
 trace = ∑i=1:n { aii }
 where n = min(numRows,numCols)static voidtranspose(CMatrixRMaj mat) Performs an "in-place" transpose.static CMatrixRMajtranspose(CMatrixRMaj input, @Nullable CMatrixRMaj output) Transposes input matrix 'a' and stores the results in output matrix 'b':
 
 bij = aji
 where 'b' is the transpose of 'a'.static voidPerforms an "in-place" conjugate transpose.static CMatrixRMajtransposeConjugate(CMatrixRMaj input, @Nullable CMatrixRMaj output) Conjugate transposes input matrix 'a' and stores the results in output matrix 'b':
 
 b-reali,j = a-realj,i
 b-imaginaryi,j = -1*a-imaginaryj,i
 where 'b' is the transpose of 'a'.
- 
Method Details- 
identityCreates an identity matrix of the specified size. 
 
 aij = 0+0i if i ≠ j
 aij = 1+0i if i = j
 - Parameters:
- width- The width and height of the identity matrix.
- Returns:
- A new instance of an identity matrix.
 
- 
identityCreates a matrix with diagonal elements set to 1 and the rest 0. 
 
 aij = 0+0i if i ≠ j
 aij = 1+0i if i = j
 - Parameters:
- width- The width of the identity matrix.
- height- The height of the identity matrix.
- Returns:
- A new instance of an identity matrix.
 
- 
diagCreates a new square matrix whose diagonal elements are specified by data and all the other elements are zero. 
 
 aij = 0 if i ≤ j
 aij = diag[i] if i = j
 - Parameters:
- data- Contains the values of the diagonal elements of the resulting matrix.
- Returns:
- A new complex matrix.
 
- 
diag
- 
extractDiagExtracts the diagonal elements 'src' write it to the 'dst' vector. 'dst' can either be a row or column vector. - Parameters:
- src- Matrix whose diagonal elements are being extracted. Not modified.
- dst- A vector the results will be written into. Modified.
 
- 
convertConverts the real matrix into a complex matrix.- Parameters:
- input- Real matrix. Not modified.
- output- Complex matrix. Modified.
 
- 
realPlaces the real component of the input matrix into the output matrix.- Parameters:
- input- Complex matrix. Not modified.
- output- real matrix. Modified.
 
- 
imaginaryPlaces the imaginary component of the input matrix into the output matrix.- Parameters:
- input- Complex matrix. Not modified.
- output- real matrix. Modified.
 
- 
magnitudeComputes the magnitude of the complex number in the input matrix and stores the results in the output matrix. magnitude = sqrt(real^2 + imaginary^2)- Parameters:
- input- Complex matrix. Not modified.
- output- real matrix. Modified.
 
- 
conjugateComputes the complex conjugate of the input matrix. 
 
 reali,j = reali,j
 imaginaryi,j = -1*imaginaryi,j
 - Parameters:
- input- Input matrix. Not modified.
- output- The complex conjugate of the input matrix. Modified.
 
- 
fillSets every element in the matrix to the specified value. 
 
 aij = value- Parameters:
- a- A matrix whose elements are about to be set. Modified.
- real- The real component
- imaginary- The imaginary component
 
- 
addPerforms the following operation: 
 
 c = a + b
 cij = aij + bij
 Matrix C can be the same instance as Matrix A and/or B. - Parameters:
- a- A Matrix. Not modified.
- b- A Matrix. Not modified.
- c- A Matrix where the results are stored. Modified.
 
- 
subtractPerforms the following operation: 
 
 c = a - b
 cij = aij - bij
 Matrix C can be the same instance as Matrix A and/or B. - Parameters:
- a- A Matrix. Not modified.
- b- A Matrix. Not modified.
- c- A Matrix where the results are stored. Modified.
 
- 
scalePerforms an in-place element by element scalar multiplication. 
 
 aij = α*aij- Parameters:
- a- The matrix that is to be scaled. Modified.
- alphaReal- real component of scale factor
- alphaImag- imaginary component of scale factor
 
- 
multPerforms the following operation: 
 
 c = a * b
 
 cij = ∑k=1:n { * aik * bkj}- Parameters:
- a- The left matrix in the multiplication operation. Not modified.
- b- The right matrix in the multiplication operation. Not modified.
- c- Where the results of the operation are stored. Modified.
 
- 
multpublic static void mult(float realAlpha, float imgAlpha, CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation: 
 
 c = α * a * b
 
 cij = α ∑k=1:n { * aik * bkj}- Parameters:
- realAlpha- real component of scaling factor.
- imgAlpha- imaginary component of scaling factor.
- a- The left matrix in the multiplication operation. Not modified.
- b- The right matrix in the multiplication operation. Not modified.
- c- Where the results of the operation are stored. Modified.
 
- 
multAddPerforms the following operation: 
 
 c = c + a * b
 cij = cij + ∑k=1:n { aik * bkj}- Parameters:
- a- The left matrix in the multiplication operation. Not modified.
- b- The right matrix in the multiplication operation. Not modified.
- c- Where the results of the operation are stored. Modified.
 
- 
multAddpublic static void multAdd(float realAlpha, float imgAlpha, CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation: 
 
 c = c + α * a * b
 cij = cij + α * ∑k=1:n { aik * bkj}- Parameters:
- realAlpha- real component of scaling factor.
- imgAlpha- imaginary component of scaling factor.
- a- The left matrix in the multiplication operation. Not modified.
- b- The right matrix in the multiplication operation. Not modified.
- c- Where the results of the operation are stored. Modified.
 
- 
multTransAPerforms the following operation: 
 
 c = aH * b
 
 cij = ∑k=1:n { aki * bkj}- Parameters:
- a- The left matrix in the multiplication operation. Not modified.
- b- The right matrix in the multiplication operation. Not modified.
- c- Where the results of the operation are stored. Modified.
 
- 
multTransApublic static void multTransA(float realAlpha, float imagAlpha, CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation: 
 
 c = α * aH * b
 
 cij = α ∑k=1:n { aki * bkj}- Parameters:
- realAlpha- Real component of scaling factor.
- imagAlpha- Imaginary component of scaling factor.
- a- The left matrix in the multiplication operation. Not modified.
- b- The right matrix in the multiplication operation. Not modified.
- c- Where the results of the operation are stored. Modified.
 
- 
multTransBPerforms the following operation: 
 
 c = a * bH
 cij = ∑k=1:n { aik * bjk}- Parameters:
- a- The left matrix in the multiplication operation. Not modified.
- b- The right matrix in the multiplication operation. Not modified.
- c- Where the results of the operation are stored. Modified.
 
- 
multTransBpublic static void multTransB(float realAlpha, float imagAlpha, CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation: 
 
 c = α * a * bH
 cij = α ∑k=1:n { aik * bjk}- Parameters:
- realAlpha- Real component of scaling factor.
- imagAlpha- Imaginary component of scaling factor.
- a- The left matrix in the multiplication operation. Not modified.
- b- The right matrix in the multiplication operation. Not modified.
- c- Where the results of the operation are stored. Modified.
 
- 
multTransABPerforms the following operation: 
 
 c = aT * bT
 cij = ∑k=1:n { aki * bjk}- Parameters:
- a- The left matrix in the multiplication operation. Not modified.
- b- The right matrix in the multiplication operation. Not modified.
- c- Where the results of the operation are stored. Modified.
 
- 
multTransABpublic static void multTransAB(float realAlpha, float imagAlpha, CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation: 
 
 c = α * aH * bH
 cij = α ∑k=1:n { aki * bjk}- Parameters:
- realAlpha- Real component of scaling factor.
- imagAlpha- Imaginary component of scaling factor.
- a- The left matrix in the multiplication operation. Not modified.
- b- The right matrix in the multiplication operation. Not modified.
- c- Where the results of the operation are stored. Modified.
 
- 
multAddTransAPerforms the following operation: 
 
 c = c + aH * b
 cij = cij + ∑k=1:n { aki * bkj}- Parameters:
- a- The left matrix in the multiplication operation. Not modified.
- b- The right matrix in the multiplication operation. Not modified.
- c- Where the results of the operation are stored. Modified.
 
- 
multAddTransApublic static void multAddTransA(float realAlpha, float imagAlpha, CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation: 
 
 c = c + α * aH * b
 cij =cij + α * ∑k=1:n { aki * bkj}- Parameters:
- realAlpha- Real component of scaling factor.
- imagAlpha- Imaginary component of scaling factor.
- a- The left matrix in the multiplication operation. Not modified.
- b- The right matrix in the multiplication operation. Not modified.
- c- Where the results of the operation are stored. Modified.
 
- 
multAddTransBPerforms the following operation: 
 
 c = c + a * bH
 cij = cij + ∑k=1:n { aik * bjk}- Parameters:
- a- The left matrix in the multiplication operation. Not modified.
- b- The right matrix in the multiplication operation. Not modified.
- c- Where the results of the operation are stored. Modified.
 
- 
multAddTransBpublic static void multAddTransB(float realAlpha, float imagAlpha, CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation: 
 
 c = c + α * a * bH
 cij = cij + α * ∑k=1:n { aik * bjk}- Parameters:
- realAlpha- Real component of scaling factor.
- imagAlpha- Imaginary component of scaling factor.
- a- The left matrix in the multiplication operation. Not modified.
- b- The right matrix in the multiplication operation. Not modified.
- c- Where the results of the operation are stored. Modified.
 
- 
multAddTransABPerforms the following operation: 
 
 c = c + aH * bH
 cij = cij + ∑k=1:n { aki * bjk}- Parameters:
- a- The left matrix in the multiplication operation. Not Modified.
- b- The right matrix in the multiplication operation. Not Modified.
- c- Where the results of the operation are stored. Modified.
 
- 
multAddTransABpublic static void multAddTransAB(float realAlpha, float imagAlpha, CMatrixRMaj a, CMatrixRMaj b, CMatrixRMaj c) Performs the following operation: 
 
 c = c + α * aH * bH
 cij = cij + α * ∑k=1:n { aki * bjk}- Parameters:
- realAlpha- Real component of scaling factor.
- imagAlpha- Imaginary component of scaling factor.
- a- The left matrix in the multiplication operation. Not Modified.
- b- The right matrix in the multiplication operation. Not Modified.
- c- Where the results of the operation are stored. Modified.
 
- 
transposePerforms an "in-place" transpose. For square matrices the transpose is truly in-place and does not require additional memory. For non-square matrices, internally a temporary matrix is declared and transpose(CMatrixRMaj, CMatrixRMaj)is invoked.- Parameters:
- mat- The matrix that is to be transposed. Modified.
 
- 
transposeConjugatePerforms an "in-place" conjugate transpose. - Parameters:
- mat- The matrix that is to be transposed. Modified.
- See Also:
 
- 
transposeTransposes input matrix 'a' and stores the results in output matrix 'b': 
 
 bij = aji
 where 'b' is the transpose of 'a'.- Parameters:
- input- The original matrix. Not modified.
- output- Where the transpose is stored. If null a new matrix is created. Modified.
- Returns:
- The transposed matrix.
 
- 
transposeConjugatepublic static CMatrixRMaj transposeConjugate(CMatrixRMaj input, @Nullable @Nullable CMatrixRMaj output) Conjugate transposes input matrix 'a' and stores the results in output matrix 'b': 
 
 b-reali,j = a-realj,i
 b-imaginaryi,j = -1*a-imaginaryj,i
 where 'b' is the transpose of 'a'.- Parameters:
- input- The original matrix. Not modified.
- output- Where the transpose is stored. If null a new matrix is created. Modified.
- Returns:
- The transposed matrix.
 
- 
traceComputes the matrix trace: 
 
 trace = ∑i=1:n { aii }
 where n = min(numRows,numCols)- Parameters:
- input- (Input) A matrix
- output- (Output) Storage for the trace. Can be null.
- Returns:
- The trace's value
 
- 
invertPerforms a matrix inversion operation on the specified matrix and stores the results in the same matrix. 
 
 a = a-1If the algorithm could not invert the matrix then false is returned. If it returns true that just means the algorithm finished. The results could still be bad because the matrix is singular or nearly singular. - Parameters:
- A- The matrix that is to be inverted. Results are stored here. Modified.
- Returns:
- true if it could invert the matrix false if it could not.
 
- 
invertPerforms a matrix inversion operation that does not modify the original and stores the results in another matrix. The two matrices must have the same dimension. 
 
 b = a-1If the algorithm could not invert the matrix then false is returned. If it returns true that just means the algorithm finished. The results could still be bad because the matrix is singular or nearly singular. For medium to large matrices there might be a slight performance boost to using LinearSolverFactory_CDRMinstead.- Parameters:
- input- The matrix that is to be inverted. Not modified.
- output- Where the inverse matrix is stored. Modified.
- Returns:
- true if it could invert the matrix false if it could not.
 
- 
solveSolves for x in the following equation: 
 
 A*x = bIf the system could not be solved then false is returned. If it returns true that just means the algorithm finished operating, but the results could still be bad because 'A' is singular or nearly singular. If repeat calls to solve are being made then one should consider using LinearSolverFactory_CDRMinstead.It is ok for 'b' and 'x' to be the same matrix. - Parameters:
- a- A matrix that is m by n. Not modified.
- b- A matrix that is n by k. Not modified.
- x- A matrix that is m by k. Modified.
- Returns:
- true if it could invert the matrix false if it could not.
 
- 
detReturns the determinant of the matrix. If the inverse of the matrix is also needed, then usingLUDecompositionAlt_CDRMdirectly (or any similar algorithm) can be more efficient.- Parameters:
- mat- The matrix whose determinant is to be computed. Not modified.
- Returns:
- The determinant.
 
- 
elementMultiplypublic static CMatrixRMaj elementMultiply(CMatrixD1 input, float real, float imaginary, @Nullable @Nullable CMatrixRMaj output) Performs element by element multiplication operation with a complex number 
 
 outputij = inputij * (real + imaginary*i)
 - Parameters:
- input- The left matrix in the multiplication operation. Not modified.
- real- Real component of the number it is multiplied by
- imaginary- Imaginary component of the number it is multiplied by
- output- Where the results of the operation are stored. Modified.
 
- 
elementMultiplypublic static CMatrixRMaj elementMultiply(CMatrixD1 inputA, CMatrixD1 inputB, @Nullable @Nullable CMatrixRMaj output) Performs complex multiplication between two matrices with the same shape element by element. 
 
 outputij = inputAij * inputBij
 - Parameters:
- inputA- First input matrix. Not modified.
- inputB- Second input matrix. Not modified.
- output- Where the results of the operation are stored. Modified.
 
- 
elementDividepublic static CMatrixRMaj elementDivide(CMatrixD1 input, float real, float imaginary, @Nullable @Nullable CMatrixRMaj output) Performs element by element division operation with a complex number on the right 
 
 outputij = inputij / (real + imaginary*i)
 - Parameters:
- input- The left matrix in the multiplication operation. Not modified.
- real- Real component of the number it is multiplied by
- imaginary- Imaginary component of the number it is multiplied by
- output- Where the results of the operation are stored. Modified.
 
- 
elementDividepublic static CMatrixRMaj elementDivide(float real, float imaginary, CMatrixD1 input, @Nullable @Nullable CMatrixRMaj output) Performs element by element division operation with a complex number on the right 
 
 outputij = (real + imaginary*i) / inputij
 - Parameters:
- real- Real component of the number it is multiplied by
- imaginary- Imaginary component of the number it is multiplied by
- input- The right matrix in the multiplication operation. Not modified.
- output- Where the results of the operation are stored. Modified.
 
- 
elementDividepublic static CMatrixRMaj elementDivide(CMatrixD1 inputA, CMatrixD1 inputB, @Nullable @Nullable CMatrixRMaj output) Performs complex division between two matrices with the same shape element by element. 
 
 outputij = inputAij / inputBij
 - Parameters:
- inputA- First input matrix. Not modified.
- inputB- Second input matrix. Not modified.
- output- Where the results of the operation are stored. Modified.
 
- 
elementPowerpublic static CMatrixRMaj elementPower(CMatrixD1 input, float b, @Nullable @Nullable CMatrixRMaj output) Element by element complex power 
 
 outputij = inputAij / inputBij
 - Parameters:
- input- Input matrix. Not modified.
- b- Power
- output- Where the results of the operation are stored. Modified.
 
- 
elementSumComputes the sum of all the elements in the matrix: 
 
 sum(i=1:m , j=1:n ; aij)- Parameters:
- input- An m by n matrix. Not modified.
- output- (Output) Storage for the sum. Can be null.
- Returns:
- The sum of the elements.
 
- 
elementMinRealReturns the value of the real element in the matrix that has the minimum value. 
 
 Min{ aij } for all i and j
 - Parameters:
- a- A matrix. Not modified.
- Returns:
- The minimum value out of all the real values.
 
- 
elementMinImaginaryReturns the value of the imaginary element in the matrix that has the minimum value. 
 
 Min{ aij } for all i and j
 - Parameters:
- a- A matrix. Not modified.
- Returns:
- The minimum value out of all the real values.
 
- 
elementMaxRealReturns the value of the real element in the matrix that has the minimum value. 
 
 Min{ aij } for all i and j
 - Parameters:
- a- A matrix. Not modified.
- Returns:
- The minimum value out of all the real values.
 
- 
elementMaxImaginaryReturns the value of the imaginary element in the matrix that has the minimum value. 
 
 Min{ aij } for all i and j
 - Parameters:
- a- A matrix. Not modified.
- Returns:
- The minimum value out of all the real values.
 
- 
elementMaxMagnitude2Returns the magnitude squared of the complex element with the largest magnitude 
 
 Max{ |aij|^2 } for all i and j
 - Parameters:
- a- A matrix. Not modified.
- Returns:
- The max magnitude squared
 
- 
setIdentitySets all the diagonal elements equal to one and everything else equal to zero. If this is a square matrix then it will be an identity matrix.- Parameters:
- mat- A square matrix.
 
- 
extractCreates a new matrix which is the specified submatrix of 'src' si-y0 , j-x0 = oij for all y0 ≤ i < y1 and x0 ≤ j < x1 
 
 where 'sij' is an element in the submatrix and 'oij' is an element in the original matrix.- Parameters:
- src- The original matrix which is to be copied. Not modified.
- srcX0- Start column.
- srcX1- Stop column+1.
- srcY0- Start row.
- srcY1- Stop row+1.
- Returns:
- Extracted submatrix.
 
- 
extractpublic static void extract(CMatrixRMaj src, int srcY0, int srcY1, int srcX0, int srcX1, CMatrixRMaj dst, int dstY0, int dstX0) Extracts a submatrix from 'src' and inserts it in a submatrix in 'dst'. si-y0 , j-x0 = oij for all y0 ≤ i < y1 and x0 ≤ j < x1 
 
 where 'sij' is an element in the submatrix and 'oij' is an element in the original matrix.- Parameters:
- src- The original matrix which is to be copied. Not modified.
- srcX0- Start column.
- srcX1- Stop column+1.
- srcY0- Start row.
- srcY1- Stop row+1.
- dst- Where the submatrix are stored. Modified.
- dstY0- Start row in dst.
- dstX0- start column in dst.
 
- 
columnsToVectorConverts the columns in a matrix into a set of vectors.- Parameters:
- A- Matrix. Not modified.
- v- Optional storage for columns.
- Returns:
- An array of vectors.
 
- 
elementMaxAbsReturns the largest absolute value of any element in the matrix. 
 
 Max{ |aij| } for all i and j
 - Parameters:
- a- A matrix. Not modified.
- Returns:
- The max abs element value in the matrix.
 
- 
elementMinAbsReturns the smallest absolute value of any element in the matrix. 
 
 Min{ |aij| } for all i and j
 - Parameters:
- a- A matrix. Not modified.
- Returns:
- The min abs element value in the matrix.
 
 
-