Class GeneralMatrix
Object
GeneralMatrix
- All Implemented Interfaces:
- Serializable,- Cloneable,- Matrix,- Cloneable,- XMatrix
- Direct Known Subclasses:
- Matrix4
A two dimensional array of numbers. Row and column numbering begins with zero.
- Since:
- 2.2
- Author:
- Martin Desruisseaux (IRD), Simone Giannecchini
- See Also:
- 
Constructor SummaryConstructorsConstructorDescriptionGeneralMatrix(double[][] matrix) Constructs a new matrix from a two-dimensional array of doubles.GeneralMatrix(int size) Constructs a square identity matrix of sizesize×size.GeneralMatrix(int numRow, int numCol) Creates a matrix of sizenumRow×numCol.GeneralMatrix(int numRow, int numCol, double... matrix) Constructs anumRow×numColmatrix initialized to the values in thematrixarray.GeneralMatrix(int numRow, int numCol, Matrix matrix) Constructs anumRow×numColmatrix initialized to the values in thematrixarray.GeneralMatrix(AffineTransform transform) Constructs a 3×3 matrix from the specified affine transform.GeneralMatrix(Bounds srcRegion, Bounds dstRegion) Constructs a transform that maps a source region to a destination region.GeneralMatrix(Bounds srcRegion, AxisDirection[] srcAxis, Bounds dstRegion, AxisDirection[] dstAxis) Constructs a transform mapping a source region to a destination region.GeneralMatrix(AxisDirection[] srcAxis, AxisDirection[] dstAxis) Constructs a transform changing axis order and/or direction.GeneralMatrix(Matrix matrix) Constructs a new matrix and copies the initial values from the parameter matrix.GeneralMatrix(GeneralMatrix matrix) Constructs a new matrix and copies the initial values from the parameter matrix.
- 
Method SummaryModifier and TypeMethodDescriptionvoidadd(double scalar) Performs an in-place scalar addition.voidSet to the scalar addition ofscalar+matrixvoidSet to the matrix addition ofthis+matrix.voidSet to the matrix addition ofmatrix1+matrix2.clone()Returns a clone of this matrix.voidcopySubMatrix(int rowSource, int colSource, int numRows, int numCol, int rowDest, int colDest, GeneralMatrix target) Extract a subMatrix to the provided targetdoubleComputes the determinantbooleanbooleanCompares the element values.voidgetColumn(int col, double[] array) Extract col to provided array.doublegetElement(int row, int column) Returns the value at the row, column position in the matrix.final double[][]Retrieves the specifiable values in the transformation matrix into a 2-dimensional array of double precision values.static double[][]getElements(Matrix matrix) Retrieves the specifiable values in the transformation matrix into a 2-dimensional array of double precision values.intGets the number of columns in the matrix.intGets the number of rows in the matrix.voidgetRow(int row, double[] array) Extract row to provided arrayinthashCode()voidinvert()Inverts this matrix in place.voidSet to the inverse of the provided matrix.final booleanisAffine()Returnstrueif this matrix is an affine transform.final booleanReturnstrueif this matrix is an identity matrix.final booleanisIdentity(double tolerance) Returnstrueif this matrix is an identity matrix using the provided tolerance.static GeneralMatrixload(BufferedReader in, Locale locale) Loads data from the specified streal until the first blank line or end of stream.static GeneralMatrixLoads data from the specified file until the first blank line or end of file.voidmul(double scalar) Sets this matrix to the result of multiplying itself with the provided scalar.voidSets the value of this matrix to the result of multiplying the provided scalar and matrix.final voidIn-place multiply with provided matrix.voidIn-place update from matrix1 * matrix2.final voidSets the value of this matrix to the result of multiplying itself with the specified matrix.voidnegate()Changes the sign of each element in the matrix.voidNegates the value of this matrix:this = -matrix.voidset(double[] matrix) Update in place to the provided matrix (row-order).voidsetColumn(int column, double... values) Sets the value of the column using an array of values.voidsetElement(int row, int column, double value) Sets the value of the row, column position in the matrix.voidSets the main diagonal of this matrix to be 1.0.voidsetRow(int row, double... values) Sets the value of the row using an array of values.voidsetSize(int numRows, int numCols) Resize the matrix to the specified number of rows and columns (preserving remaining elements).voidsetZero()Sets each value of the matrix to 0.0.voidsub(double scalar) In-place matrix subtraction:this - scalar.voidSet to the difference ofscalar - matrix2.voidIn-place matrix subtraction:this - matrix.voidSet to the difference ofmatrix1 - matrix2.final AffineTransformReturns an affine transform for this matrix.toString()Returns a string representation of this matrix.voidTransposes the matrix.voidSet to the transpose of the provided matrix.
- 
Constructor Details- 
GeneralMatrixpublic GeneralMatrix(int size) Constructs a square identity matrix of sizesize×size.- Parameters:
- size- The number of rows and columns.
 
- 
GeneralMatrixpublic GeneralMatrix(int numRow, int numCol) Creates a matrix of sizenumRow×numCol. Elements on the diagonal j==i are set to 1.- Parameters:
- numRow- Number of rows.
- numCol- Number of columns.
 
- 
GeneralMatrixpublic GeneralMatrix(int numRow, int numCol, double... matrix) Constructs anumRow×numColmatrix initialized to the values in thematrixarray. The array values are copied in one row at a time in row major fashion. The array should be exactlynumRow*numColin length. Note that because row and column numbering begins with zero,numRowandnumColwill be one larger than the maximum possible matrix index values.- Parameters:
- numRow- Number of rows.
- numCol- Number of columns.
- matrix- Initial values in row order
 
- 
GeneralMatrixConstructs anumRow×numColmatrix initialized to the values in thematrixarray. The array values are copied in one row at a time in row major fashion. The array should be exactlynumRow*numColin length. Note that because row and column numbering begins with zero,numRowandnumColwill be one larger than the maximum possible matrix index values.- Parameters:
- numRow- Number of rows.
- numCol- Number of columns.
- matrix- Initial values in row order
 
- 
GeneralMatrixConstructs a new matrix from a two-dimensional array of doubles.- Parameters:
- matrix- Array of rows. Each row must have the same length.
- Throws:
- IllegalArgumentException- if the specified matrix is not regular (i.e. if all rows doesn't have the same length).
 
- 
GeneralMatrixConstructs a new matrix and copies the initial values from the parameter matrix.- Parameters:
- matrix- The matrix to copy.
 
- 
GeneralMatrixConstructs a new matrix and copies the initial values from the parameter matrix.- Parameters:
- matrix- The matrix to copy.
 
- 
GeneralMatrixConstructs a 3×3 matrix from the specified affine transform.- Parameters:
- transform- The matrix to copy.
 
- 
GeneralMatrixConstructs a transform that maps a source region to a destination region. Axis order and direction are left unchanged.If the source dimension is equals to the destination dimension, then the transform is affine. However, the following special cases are also handled: - If the target dimension is smaller than the source dimension, then extra dimensions are dropped.
- If the target dimension is greater than the source dimension, then the coordinates in the new dimensions are set to 0.
 - Parameters:
- srcRegion- The source region.
- dstRegion- The destination region.
 
- 
GeneralMatrixConstructs a transform changing axis order and/or direction. For example, the transform may converts (NORTH,WEST) coordinates into (EAST,NORTH). Axis direction can be inversed only. For example, it is illegal to transform (NORTH,WEST) coordinates into (NORTH,DOWN).If the source dimension is equals to the destination dimension, then the transform is affine. However, the following special cases are also handled: 
 - If the target dimension is smaller than the source dimension, extra axis are dropped. An exception is thrown if the target contains some axis not found in the source.
 - Parameters:
- srcAxis- The set of axis direction for source coordinate system.
- dstAxis- The set of axis direction for destination coordinate system.
- Throws:
- IllegalArgumentException- If- dstAxiscontains some axis not found in- srcAxis, or if some colinear axis were found.
 
- 
GeneralMatrixpublic GeneralMatrix(Bounds srcRegion, AxisDirection[] srcAxis, Bounds dstRegion, AxisDirection[] dstAxis) Constructs a transform mapping a source region to a destination region. Axis order and/or direction can be changed during the process. For example, the transform may convert (NORTH,WEST) coordinates into (EAST,NORTH). Axis direction can be inversed only. For example, it is illegal to transform (NORTH,WEST) coordinates into (NORTH,DOWN).If the source dimension is equals to the destination dimension, then the transform is affine. However, the following special cases are also handled: 
 - If the target dimension is smaller than the source dimension, extra axis are dropped. An exception is thrown if the target contains some axis not found in the source.
 - Parameters:
- srcRegion- The source region.
- srcAxis- Axis direction for each dimension of the source region.
- dstRegion- The destination region.
- dstAxis- Axis direction for each dimension of the destination region.
- Throws:
- MismatchedDimensionException- if the envelope dimension doesn't matches the axis direction array length.
- IllegalArgumentException- If- dstAxiscontains some axis not found in- srcAxis, or if some colinear axis were found.
 
 
- 
- 
Method Details- 
getElementsRetrieves the specifiable values in the transformation matrix into a 2-dimensional array of double precision values. The values are stored into the 2-dimensional array using the row index as the first subscript and the column index as the second. Values are copied; changes to the returned array will not change this matrix.- Parameters:
- matrix- The matrix to extract elements from.
- Returns:
- The matrix elements.
 
- 
getElementspublic final double[][] getElements()Retrieves the specifiable values in the transformation matrix into a 2-dimensional array of double precision values. The values are stored into the 2-dimensional array using the row index as the first subscript and the column index as the second. Values are copied; changes to the returned array will not change this matrix.- Returns:
- The matrix elements.
 
- 
isAffinepublic final boolean isAffine()Returnstrueif this matrix is an affine transform. A transform is affine if the matrix is square and last row contains only zeros, except in the last column which contains 1.
- 
negatepublic void negate()Changes the sign of each element in the matrix.
- 
negateDescription copied from interface:XMatrixNegates the value of this matrix:this = -matrix.
- 
transposepublic void transpose()Transposes the matrix.
- 
transposeDescription copied from interface:XMatrixSet to the transpose of the provided matrix.
- 
invertpublic void invert()Description copied from interface:XMatrixInverts this matrix in place.
- 
invertDescription copied from interface:XMatrixSet to the inverse of the provided matrix.- Specified by:
- invertin interface- XMatrix
- Parameters:
- matrix- The matrix that is to be inverted. Not modified.
- Throws:
- SingularMatrixException- if this matrix is not invertible.
 
- 
getNumRowpublic int getNumRow()Gets the number of rows in the matrix.
- 
getNumColpublic int getNumCol()Gets the number of columns in the matrix.
- 
getElementpublic double getElement(int row, int column) Returns the value at the row, column position in the matrix.- Specified by:
- getElementin interface- Matrix
- Specified by:
- getElementin interface- XMatrix
- Parameters:
- row- The row number to be retrieved (zero indexed).
- column- The column number to be retrieved (zero indexed).
- Returns:
- Matrix value at the given row and column.
 
- 
setColumnpublic void setColumn(int column, double... values) Description copied from interface:XMatrixSets the value of the column using an array of values.
- 
setRowpublic void setRow(int row, double... values) Description copied from interface:XMatrixSets the value of the row using an array of values.
- 
setElementpublic void setElement(int row, int column, double value) Sets the value of the row, column position in the matrix.- Specified by:
- setElementin interface- Matrix
- Parameters:
- row- The row number to be retrieved (zero indexed).
- column- The column number to be retrieved (zero indexed).
- value- The new matrix element value.
 
- 
setZeropublic void setZero()Sets each value of the matrix to 0.0.
- 
setIdentitypublic void setIdentity()Sets the main diagonal of this matrix to be 1.0.- Specified by:
- setIdentityin interface- XMatrix
 
- 
isIdentitypublic final boolean isIdentity()Returnstrueif this matrix is an identity matrix.- Specified by:
- isIdentityin interface- Matrix
- Returns:
- trueif this matrix is an identity matrix.
 
- 
isIdentitypublic final boolean isIdentity(double tolerance) Returnstrueif this matrix is an identity matrix using the provided tolerance. This method is equivalent to computing the difference between this matrix and an identity matrix of identical size, and returningtrueif and only if all differences are smaller than or equal totolerance.- Specified by:
- isIdentityin interface- XMatrix
- Parameters:
- tolerance- The tolerance value.
- Returns:
- trueif this matrix is close enough to the identity matrix given the tolerance value.
- Since:
- 2.3.1
 
- 
multiplySets the value of this matrix to the result of multiplying itself with the specified matrix. In other words, performsthis=this×matrix. In the context of coordinate transformations, this is equivalent toAffineTransform.concatenate: first transforms by the supplied transform and then transform the result by the original transform.
- 
hashCodepublic int hashCode()
- 
equals
- 
equalsDescription copied from interface:XMatrixCompares the element values.
- 
toAffineTransform2DReturns an affine transform for this matrix. This is a convenience method for interoperability with Java2D.- Returns:
- The affine transform for this matrix.
- Throws:
- IllegalStateException- if this matrix is not 3×3, or if the last row is not- [0 0 1].
 
- 
loadLoads data from the specified file until the first blank line or end of file.- Parameters:
- file- The file to read.
- Returns:
- The matrix parsed from the file.
- Throws:
- IOException- if an error occured while reading the file.
- Since:
- 2.2
 
- 
loadLoads data from the specified streal until the first blank line or end of stream.- Parameters:
- in- The stream to read.
- locale- The locale for the numbers to be parsed.
- Returns:
- The matrix parsed from the stream.
- Throws:
- IOException- if an error occured while reading the stream.
- Since:
- 2.2
 
- 
toStringReturns a string representation of this matrix. The returned string is implementation dependent. It is usually provided for debugging purposes only.
- 
cloneReturns a clone of this matrix.
- 
copySubMatrixpublic void copySubMatrix(int rowSource, int colSource, int numRows, int numCol, int rowDest, int colDest, GeneralMatrix target) Extract a subMatrix to the provided target
- 
getColumnpublic void getColumn(int col, double[] array) Extract col to provided array.
- 
mulpublic void mul(double scalar) Description copied from interface:XMatrixSets this matrix to the result of multiplying itself with the provided scalar.
- 
mulDescription copied from interface:XMatrixSets the value of this matrix to the result of multiplying the provided scalar and matrix.
- 
getRowpublic void getRow(int row, double[] array) Extract row to provided array
- 
mulIn-place multiply with provided matrix.
- 
mulIn-place update from matrix1 * matrix2.
- 
subpublic void sub(double scalar) Description copied from interface:XMatrixIn-place matrix subtraction:this - scalar.
- 
subDescription copied from interface:XMatrixSet to the difference ofscalar - matrix2.
- 
subDescription copied from interface:XMatrixIn-place matrix subtraction:this - matrix.
- 
subDescription copied from interface:XMatrixSet to the difference ofmatrix1 - matrix2.
- 
setpublic void set(double[] matrix) Update in place to the provided matrix (row-order).
- 
setSizepublic void setSize(int numRows, int numCols) Resize the matrix to the specified number of rows and columns (preserving remaining elements).- Parameters:
- numRows- The new number of rows in the matrix.
- numCols- The new number of columns in the matrix.
 
- 
addpublic void add(double scalar) Description copied from interface:XMatrixPerforms an in-place scalar addition.
- 
addDescription copied from interface:XMatrixSet to the scalar addition ofscalar+matrix
- 
addDescription copied from interface:XMatrixSet to the matrix addition ofthis+matrix.
- 
addDescription copied from interface:XMatrixSet to the matrix addition ofmatrix1+matrix2.
- 
determinatepublic double determinate()Description copied from interface:XMatrixComputes the determinant- Specified by:
- determinatein interface- XMatrix
 
 
-