Interface FieldMatrix<T extends FieldElement<T>>
- Type Parameters:
T
- the type of the field elements
- All Superinterfaces:
AnyMatrix
- All Known Implementing Classes:
AbstractFieldMatrix
,Array2DRowFieldMatrix
,BlockFieldMatrix
,SparseFieldMatrix
Matrix element indexing is 0-based -- e.g., getEntry(0, 0)
returns the element in the first row, first column of the matrix.
-
Method Summary
Modifier and TypeMethodDescriptionadd
(FieldMatrix<T> m) Compute the sum of this and m.void
addToEntry
(int row, int column, T increment) Change an entry in the specified row and column.copy()
Returns a (deep) copy of this.void
copySubMatrix
(int[] selectedRows, int[] selectedColumns, T[][] destination) Copy a submatrix.void
copySubMatrix
(int startRow, int endRow, int startColumn, int endColumn, T[][] destination) Copy a submatrix.createMatrix
(int rowDimension, int columnDimension) Create a new FieldMatrixof the same type as the instance with the supplied row and column dimensions. T[]
getColumn
(int column) Returns the entries in column numbercol
as an array.getColumnMatrix
(int column) Returns the entries in column numbercolumn
as a column matrix.getColumnVector
(int column) Returns the entries in column numbercolumn
as a vector.T[][]
getData()
Returns matrix entries as a two-dimensional array.getEntry
(int row, int column) Returns the entry in the specified row and column.getField()
Get the type of field elements of the matrix.T[]
getRow
(int row) Returns the entries in row numberrow
as an array.getRowMatrix
(int row) Returns the entries in row numberrow
as a row matrix.getRowVector
(int row) Returns the entries in row numberrow
as a vector.getSubMatrix
(int[] selectedRows, int[] selectedColumns) Gets a submatrix.getSubMatrix
(int startRow, int endRow, int startColumn, int endColumn) Gets a submatrix.getTrace()
Returns the trace of the matrix (the sum of the elements on the main diagonal).multiply
(FieldMatrix<T> m) Returns the result of postmultiplying this by m.void
multiplyEntry
(int row, int column, T factor) Change an entry in the specified row and column.operate
(FieldVector<T> v) Returns the result of multiplying this by the vectorv
.T[]
Returns the result of multiplying this by the vectorv
.preMultiply
(FieldMatrix<T> m) Returns the result premultiplying this bym
.preMultiply
(FieldVector<T> v) Returns the (row) vector result of premultiplying this by the vectorv
.T[]
preMultiply
(T[] v) Returns the (row) vector result of premultiplying this by the vectorv
.Returns the result of adding d to each entry of this.scalarMultiply
(T d) Returns the result multiplying each entry of this by d.void
Sets the entries in column numbercolumn
as a column matrix.void
setColumnMatrix
(int column, FieldMatrix<T> matrix) Sets the entries in column numbercolumn
as a column matrix.void
setColumnVector
(int column, FieldVector<T> vector) Sets the entries in column numbercolumn
as a vector.void
Set the entry in the specified row and column.void
Sets the entries in row numberrow
as a row matrix.void
setRowMatrix
(int row, FieldMatrix<T> matrix) Sets the entries in row numberrow
as a row matrix.void
setRowVector
(int row, FieldVector<T> vector) Sets the entries in row numberrow
as a vector.void
setSubMatrix
(T[][] subMatrix, int row, int column) Replace the submatrix starting atrow, column
using data in the inputsubMatrix
array.subtract
(FieldMatrix<T> m) Compute this minus m.Returns the transpose of this matrix.walkInColumnOrder
(FieldMatrixChangingVisitor<T> visitor) Visit (and possibly change) all matrix entries in column order.walkInColumnOrder
(FieldMatrixChangingVisitor<T> visitor, int startRow, int endRow, int startColumn, int endColumn) Visit (and possibly change) some matrix entries in column order.walkInColumnOrder
(FieldMatrixPreservingVisitor<T> visitor) Visit (but don't change) all matrix entries in column order.walkInColumnOrder
(FieldMatrixPreservingVisitor<T> visitor, int startRow, int endRow, int startColumn, int endColumn) Visit (but don't change) some matrix entries in column order.walkInOptimizedOrder
(FieldMatrixChangingVisitor<T> visitor) Visit (and possibly change) all matrix entries using the fastest possible order.walkInOptimizedOrder
(FieldMatrixChangingVisitor<T> visitor, int startRow, int endRow, int startColumn, int endColumn) Visit (and possibly change) some matrix entries using the fastest possible order.Visit (but don't change) all matrix entries using the fastest possible order.walkInOptimizedOrder
(FieldMatrixPreservingVisitor<T> visitor, int startRow, int endRow, int startColumn, int endColumn) Visit (but don't change) some matrix entries using the fastest possible order.walkInRowOrder
(FieldMatrixChangingVisitor<T> visitor) Visit (and possibly change) all matrix entries in row order.walkInRowOrder
(FieldMatrixChangingVisitor<T> visitor, int startRow, int endRow, int startColumn, int endColumn) Visit (and possibly change) some matrix entries in row order.walkInRowOrder
(FieldMatrixPreservingVisitor<T> visitor) Visit (but don't change) all matrix entries in row order.walkInRowOrder
(FieldMatrixPreservingVisitor<T> visitor, int startRow, int endRow, int startColumn, int endColumn) Visit (but don't change) some matrix entries in row order.Methods inherited from interface org.apache.commons.math.linear.AnyMatrix
getColumnDimension, getRowDimension, isSquare
-
Method Details
-
getField
Get the type of field elements of the matrix.- Returns:
- type of field elements of the matrix
-
createMatrix
Create a new FieldMatrixof the same type as the instance with the supplied row and column dimensions. - Parameters:
rowDimension
- the number of rows in the new matrixcolumnDimension
- the number of columns in the new matrix- Returns:
- a new matrix of the same type as the instance
- Throws:
IllegalArgumentException
- if row or column dimension is not positive- Since:
- 2.0
-
copy
FieldMatrix<T> copy()Returns a (deep) copy of this.- Returns:
- matrix copy
-
add
Compute the sum of this and m.- Parameters:
m
- matrix to be added- Returns:
- this + m
- Throws:
IllegalArgumentException
- if m is not the same size as this
-
subtract
Compute this minus m.- Parameters:
m
- matrix to be subtracted- Returns:
- this + m
- Throws:
IllegalArgumentException
- if m is not the same size as this
-
scalarAdd
Returns the result of adding d to each entry of this.- Parameters:
d
- value to be added to each entry- Returns:
- d + this
-
scalarMultiply
Returns the result multiplying each entry of this by d.- Parameters:
d
- value to multiply all entries by- Returns:
- d * this
-
multiply
Returns the result of postmultiplying this by m.- Parameters:
m
- matrix to postmultiply by- Returns:
- this * m
- Throws:
IllegalArgumentException
- if columnDimension(this) != rowDimension(m)
-
preMultiply
Returns the result premultiplying this bym
.- Parameters:
m
- matrix to premultiply by- Returns:
- m * this
- Throws:
IllegalArgumentException
- if rowDimension(this) != columnDimension(m)
-
getData
T[][] getData()Returns matrix entries as a two-dimensional array.- Returns:
- 2-dimensional array of entries
-
getSubMatrix
FieldMatrix<T> getSubMatrix(int startRow, int endRow, int startColumn, int endColumn) throws MatrixIndexException Gets a submatrix. Rows and columns are indicated counting from 0 to n-1.- Parameters:
startRow
- Initial row indexendRow
- Final row index (inclusive)startColumn
- Initial column indexendColumn
- Final column index (inclusive)- Returns:
- The subMatrix containing the data of the specified rows and columns
- Throws:
MatrixIndexException
- if the indices are not valid
-
getSubMatrix
Gets a submatrix. Rows and columns are indicated counting from 0 to n-1.- Parameters:
selectedRows
- Array of row indices.selectedColumns
- Array of column indices.- Returns:
- The subMatrix containing the data in the specified rows and columns
- Throws:
MatrixIndexException
- if row or column selections are not valid
-
copySubMatrix
void copySubMatrix(int startRow, int endRow, int startColumn, int endColumn, T[][] destination) throws MatrixIndexException, IllegalArgumentException Copy a submatrix. Rows and columns are indicated counting from 0 to n-1.- Parameters:
startRow
- Initial row indexendRow
- Final row index (inclusive)startColumn
- Initial column indexendColumn
- Final column index (inclusive)destination
- The arrays where the submatrix data should be copied (if larger than rows/columns counts, only the upper-left part will be used)- Throws:
MatrixIndexException
- if the indices are not validIllegalArgumentException
- if the destination array is too small
-
copySubMatrix
void copySubMatrix(int[] selectedRows, int[] selectedColumns, T[][] destination) throws MatrixIndexException, IllegalArgumentException Copy a submatrix. Rows and columns are indicated counting from 0 to n-1.- Parameters:
selectedRows
- Array of row indices.selectedColumns
- Array of column indices.destination
- The arrays where the submatrix data should be copied (if larger than rows/columns counts, only the upper-left part will be used)- Throws:
MatrixIndexException
- if the indices are not validIllegalArgumentException
- if the destination array is too small
-
setSubMatrix
Replace the submatrix starting atrow, column
using data in the inputsubMatrix
array. Indexes are 0-based.Example:
Starting with1 2 3 4 5 6 7 8 9 0 1 2
andsubMatrix = {{3, 4} {5,6}}
, invokingsetSubMatrix(subMatrix,1,1))
will result in1 2 3 4 5 3 4 8 9 5 6 2
- Parameters:
subMatrix
- array containing the submatrix replacement datarow
- row coordinate of the top, left element to be replacedcolumn
- column coordinate of the top, left element to be replaced- Throws:
MatrixIndexException
- if subMatrix does not fit into this matrix from element in (row, column)IllegalArgumentException
- ifsubMatrix
is not rectangular (not all rows have the same length) or emptyNullPointerException
- ifsubMatrix
is null- Since:
- 2.0
-
getRowMatrix
Returns the entries in row numberrow
as a row matrix. Row indices start at 0.- Parameters:
row
- the row to be fetched- Returns:
- row matrix
- Throws:
MatrixIndexException
- if the specified row index is invalid
-
setRowMatrix
void setRowMatrix(int row, FieldMatrix<T> matrix) throws MatrixIndexException, InvalidMatrixException Sets the entries in row numberrow
as a row matrix. Row indices start at 0.- Parameters:
row
- the row to be setmatrix
- row matrix (must have one row and the same number of columns as the instance)- Throws:
MatrixIndexException
- if the specified row index is invalidInvalidMatrixException
- if the matrix dimensions do not match one instance row
-
getColumnMatrix
Returns the entries in column numbercolumn
as a column matrix. Column indices start at 0.- Parameters:
column
- the column to be fetched- Returns:
- column matrix
- Throws:
MatrixIndexException
- if the specified column index is invalid
-
setColumnMatrix
void setColumnMatrix(int column, FieldMatrix<T> matrix) throws MatrixIndexException, InvalidMatrixException Sets the entries in column numbercolumn
as a column matrix. Column indices start at 0.- Parameters:
column
- the column to be setmatrix
- column matrix (must have one column and the same number of rows as the instance)- Throws:
MatrixIndexException
- if the specified column index is invalidInvalidMatrixException
- if the matrix dimensions do not match one instance column
-
getRowVector
Returns the entries in row numberrow
as a vector. Row indices start at 0.- Parameters:
row
- the row to be fetched- Returns:
- row vector
- Throws:
MatrixIndexException
- if the specified row index is invalid
-
setRowVector
void setRowVector(int row, FieldVector<T> vector) throws MatrixIndexException, InvalidMatrixException Sets the entries in row numberrow
as a vector. Row indices start at 0.- Parameters:
row
- the row to be setvector
- row vector (must have the same number of columns as the instance)- Throws:
MatrixIndexException
- if the specified row index is invalidInvalidMatrixException
- if the vector dimension does not match one instance row
-
getColumnVector
Returns the entries in column numbercolumn
as a vector. Column indices start at 0.- Parameters:
column
- the column to be fetched- Returns:
- column vector
- Throws:
MatrixIndexException
- if the specified column index is invalid
-
setColumnVector
void setColumnVector(int column, FieldVector<T> vector) throws MatrixIndexException, InvalidMatrixException Sets the entries in column numbercolumn
as a vector. Column indices start at 0.- Parameters:
column
- the column to be setvector
- column vector (must have the same number of rows as the instance)- Throws:
MatrixIndexException
- if the specified column index is invalidInvalidMatrixException
- if the vector dimension does not match one instance column
-
getRow
Returns the entries in row numberrow
as an array.Row indices start at 0. A
MatrixIndexException
is thrown unless0 invalid input: '<'= row invalid input: '<' rowDimension.
- Parameters:
row
- the row to be fetched- Returns:
- array of entries in the row
- Throws:
MatrixIndexException
- if the specified row index is not valid
-
setRow
Sets the entries in row numberrow
as a row matrix. Row indices start at 0.- Parameters:
row
- the row to be setarray
- row matrix (must have the same number of columns as the instance)- Throws:
MatrixIndexException
- if the specified row index is invalidInvalidMatrixException
- if the array size does not match one instance row
-
getColumn
Returns the entries in column numbercol
as an array.Column indices start at 0. A
MatrixIndexException
is thrown unless0 invalid input: '<'= column invalid input: '<' columnDimension.
- Parameters:
column
- the column to be fetched- Returns:
- array of entries in the column
- Throws:
MatrixIndexException
- if the specified column index is not valid
-
setColumn
Sets the entries in column numbercolumn
as a column matrix. Column indices start at 0.- Parameters:
column
- the column to be setarray
- column array (must have the same number of rows as the instance)- Throws:
MatrixIndexException
- if the specified column index is invalidInvalidMatrixException
- if the array size does not match one instance column
-
getEntry
Returns the entry in the specified row and column.Row and column indices start at 0 and must satisfy
0 invalid input: '<'= row invalid input: '<' rowDimension
0 invalid input: '<'= column invalid input: '<' columnDimension
MatrixIndexException
is thrown.- Parameters:
row
- row location of entry to be fetchedcolumn
- column location of entry to be fetched- Returns:
- matrix entry in row,column
- Throws:
MatrixIndexException
- if the row or column index is not valid
-
setEntry
Set the entry in the specified row and column.Row and column indices start at 0 and must satisfy
0 invalid input: '<'= row invalid input: '<' rowDimension
0 invalid input: '<'= column invalid input: '<' columnDimension
MatrixIndexException
is thrown.- Parameters:
row
- row location of entry to be setcolumn
- column location of entry to be setvalue
- matrix entry to be set in row,column- Throws:
MatrixIndexException
- if the row or column index is not valid- Since:
- 2.0
-
addToEntry
Change an entry in the specified row and column.Row and column indices start at 0 and must satisfy
0 invalid input: '<'= row invalid input: '<' rowDimension
0 invalid input: '<'= column invalid input: '<' columnDimension
MatrixIndexException
is thrown.- Parameters:
row
- row location of entry to be setcolumn
- column location of entry to be setincrement
- value to add to the current matrix entry in row,column- Throws:
MatrixIndexException
- if the row or column index is not valid- Since:
- 2.0
-
multiplyEntry
Change an entry in the specified row and column.Row and column indices start at 0 and must satisfy
0 invalid input: '<'= row invalid input: '<' rowDimension
0 invalid input: '<'= column invalid input: '<' columnDimension
MatrixIndexException
is thrown.- Parameters:
row
- row location of entry to be setcolumn
- column location of entry to be setfactor
- multiplication factor for the current matrix entry in row,column- Throws:
MatrixIndexException
- if the row or column index is not valid- Since:
- 2.0
-
transpose
FieldMatrix<T> transpose()Returns the transpose of this matrix.- Returns:
- transpose matrix
-
getTrace
Returns the trace of the matrix (the sum of the elements on the main diagonal).- Returns:
- trace
- Throws:
NonSquareMatrixException
- if the matrix is not square
-
operate
Returns the result of multiplying this by the vectorv
.- Parameters:
v
- the vector to operate on- Returns:
- this*v
- Throws:
IllegalArgumentException
- if columnDimension != v.size()
-
operate
Returns the result of multiplying this by the vectorv
.- Parameters:
v
- the vector to operate on- Returns:
- this*v
- Throws:
IllegalArgumentException
- if columnDimension != v.size()
-
preMultiply
Returns the (row) vector result of premultiplying this by the vectorv
.- Parameters:
v
- the row vector to premultiply by- Returns:
- v*this
- Throws:
IllegalArgumentException
- if rowDimension != v.size()
-
preMultiply
Returns the (row) vector result of premultiplying this by the vectorv
.- Parameters:
v
- the row vector to premultiply by- Returns:
- v*this
- Throws:
IllegalArgumentException
- if rowDimension != v.size()
-
walkInRowOrder
Visit (and possibly change) all matrix entries in row order.Row order starts at upper left and iterating through all elements of a row from left to right before going to the leftmost element of the next row.
- Parameters:
visitor
- visitor used to process all matrix entries- Returns:
- the value returned by
FieldMatrixChangingVisitor.end()
at the end of the walk - Throws:
MatrixVisitorException
- if the visitor cannot process an entry- See Also:
-
walkInRowOrder
Visit (but don't change) all matrix entries in row order.Row order starts at upper left and iterating through all elements of a row from left to right before going to the leftmost element of the next row.
- Parameters:
visitor
- visitor used to process all matrix entries- Returns:
- the value returned by
FieldMatrixPreservingVisitor.end()
at the end of the walk - Throws:
MatrixVisitorException
- if the visitor cannot process an entry- See Also:
-
walkInRowOrder
T walkInRowOrder(FieldMatrixChangingVisitor<T> visitor, int startRow, int endRow, int startColumn, int endColumn) throws MatrixIndexException, MatrixVisitorException Visit (and possibly change) some matrix entries in row order.Row order starts at upper left and iterating through all elements of a row from left to right before going to the leftmost element of the next row.
- Parameters:
visitor
- visitor used to process all matrix entriesstartRow
- Initial row indexendRow
- Final row index (inclusive)startColumn
- Initial column indexendColumn
- Final column index- Returns:
- the value returned by
FieldMatrixChangingVisitor.end()
at the end of the walk - Throws:
MatrixVisitorException
- if the visitor cannot process an entryMatrixIndexException
- if the indices are not valid- See Also:
-
walkInRowOrder
T walkInRowOrder(FieldMatrixPreservingVisitor<T> visitor, int startRow, int endRow, int startColumn, int endColumn) throws MatrixIndexException, MatrixVisitorException Visit (but don't change) some matrix entries in row order.Row order starts at upper left and iterating through all elements of a row from left to right before going to the leftmost element of the next row.
- Parameters:
visitor
- visitor used to process all matrix entriesstartRow
- Initial row indexendRow
- Final row index (inclusive)startColumn
- Initial column indexendColumn
- Final column index- Returns:
- the value returned by
FieldMatrixPreservingVisitor.end()
at the end of the walk - Throws:
MatrixVisitorException
- if the visitor cannot process an entryMatrixIndexException
- if the indices are not valid- See Also:
-
walkInColumnOrder
Visit (and possibly change) all matrix entries in column order.Column order starts at upper left and iterating through all elements of a column from top to bottom before going to the topmost element of the next column.
- Parameters:
visitor
- visitor used to process all matrix entries- Returns:
- the value returned by
FieldMatrixChangingVisitor.end()
at the end of the walk - Throws:
MatrixVisitorException
- if the visitor cannot process an entry- See Also:
-
walkInColumnOrder
Visit (but don't change) all matrix entries in column order.Column order starts at upper left and iterating through all elements of a column from top to bottom before going to the topmost element of the next column.
- Parameters:
visitor
- visitor used to process all matrix entries- Returns:
- the value returned by
FieldMatrixPreservingVisitor.end()
at the end of the walk - Throws:
MatrixVisitorException
- if the visitor cannot process an entry- See Also:
-
walkInColumnOrder
T walkInColumnOrder(FieldMatrixChangingVisitor<T> visitor, int startRow, int endRow, int startColumn, int endColumn) throws MatrixIndexException, MatrixVisitorException Visit (and possibly change) some matrix entries in column order.Column order starts at upper left and iterating through all elements of a column from top to bottom before going to the topmost element of the next column.
- Parameters:
visitor
- visitor used to process all matrix entriesstartRow
- Initial row indexendRow
- Final row index (inclusive)startColumn
- Initial column indexendColumn
- Final column index- Returns:
- the value returned by
FieldMatrixChangingVisitor.end()
at the end of the walk - Throws:
MatrixVisitorException
- if the visitor cannot process an entryMatrixIndexException
- if the indices are not valid- See Also:
-
walkInColumnOrder
T walkInColumnOrder(FieldMatrixPreservingVisitor<T> visitor, int startRow, int endRow, int startColumn, int endColumn) throws MatrixIndexException, MatrixVisitorException Visit (but don't change) some matrix entries in column order.Column order starts at upper left and iterating through all elements of a column from top to bottom before going to the topmost element of the next column.
- Parameters:
visitor
- visitor used to process all matrix entriesstartRow
- Initial row indexendRow
- Final row index (inclusive)startColumn
- Initial column indexendColumn
- Final column index- Returns:
- the value returned by
FieldMatrixPreservingVisitor.end()
at the end of the walk - Throws:
MatrixVisitorException
- if the visitor cannot process an entryMatrixIndexException
- if the indices are not valid- See Also:
-
walkInOptimizedOrder
Visit (and possibly change) all matrix entries using the fastest possible order.The fastest walking order depends on the exact matrix class. It may be different from traditional row or column orders.
- Parameters:
visitor
- visitor used to process all matrix entries- Returns:
- the value returned by
FieldMatrixChangingVisitor.end()
at the end of the walk - Throws:
MatrixVisitorException
- if the visitor cannot process an entry- See Also:
-
walkInOptimizedOrder
Visit (but don't change) all matrix entries using the fastest possible order.The fastest walking order depends on the exact matrix class. It may be different from traditional row or column orders.
- Parameters:
visitor
- visitor used to process all matrix entries- Returns:
- the value returned by
FieldMatrixPreservingVisitor.end()
at the end of the walk - Throws:
MatrixVisitorException
- if the visitor cannot process an entry- See Also:
-
walkInOptimizedOrder
T walkInOptimizedOrder(FieldMatrixChangingVisitor<T> visitor, int startRow, int endRow, int startColumn, int endColumn) throws MatrixIndexException, MatrixVisitorException Visit (and possibly change) some matrix entries using the fastest possible order.The fastest walking order depends on the exact matrix class. It may be different from traditional row or column orders.
- Parameters:
visitor
- visitor used to process all matrix entriesstartRow
- Initial row indexendRow
- Final row index (inclusive)startColumn
- Initial column indexendColumn
- Final column index (inclusive)- Returns:
- the value returned by
FieldMatrixChangingVisitor.end()
at the end of the walk - Throws:
MatrixVisitorException
- if the visitor cannot process an entryMatrixIndexException
- if the indices are not valid- See Also:
-
walkInOptimizedOrder
T walkInOptimizedOrder(FieldMatrixPreservingVisitor<T> visitor, int startRow, int endRow, int startColumn, int endColumn) throws MatrixIndexException, MatrixVisitorException Visit (but don't change) some matrix entries using the fastest possible order.The fastest walking order depends on the exact matrix class. It may be different from traditional row or column orders.
- Parameters:
visitor
- visitor used to process all matrix entriesstartRow
- Initial row indexendRow
- Final row index (inclusive)startColumn
- Initial column indexendColumn
- Final column index (inclusive)- Returns:
- the value returned by
FieldMatrixPreservingVisitor.end()
at the end of the walk - Throws:
MatrixVisitorException
- if the visitor cannot process an entryMatrixIndexException
- if the indices are not valid- See Also:
-