public class BlockRealMatrix extends AbstractRealMatrix implements Serializable
This implementation is specially designed to be cache-friendly. Square blocks are stored as small arrays and allow efficient traversal of data both in row major direction and columns major direction, one block at a time. This greatly increases performances for algorithms that use crossed directions loops like multiplication or transposition.
The size of square blocks is a static parameter. It may be tuned according to the cache size of the target computer processor. As a rule of thumbs, it should be the largest value that allows three blocks to be simultaneously cached (this is necessary for example for matrix multiplication). The default value is to use 52x52 blocks which is well suited for processors with 64k L1 cache (one block holds 2704 values or 21632 bytes). This value could be lowered to 36x36 for processors with 32k L1 cache.
The regular blocks represent BLOCK_SIZE
x BLOCK_SIZE
squares. Blocks
at right hand side and bottom side may be smaller to fit matrix dimensions. The square
blocks are flattened in row major order in single dimension arrays which are therefore
BLOCK_SIZE
2 elements long for regular blocks. The blocks are themselves
organized in row major order.
As an example, for a block size of 52x52, a 100x60 matrix would be stored in 4 blocks.
Block 0 would be a double[2704]
array holding the upper left 52x52 square, block 1
would be a double[416]
array holding the upper right 52x8 rectangle, block 2 would
be a double[2496]
array holding the lower left 48x52 rectangle and block 3 would
be a double[384]
array holding the lower right 48x8 rectangle.
The layout complexity overhead versus simple mapping of matrices to java arrays is negligible for small matrices (about 1%). The gain from cache efficiency leads to up to 3-fold improvements for matrices of moderate to large size.
Modifier and Type | Field and Description |
---|---|
static int |
BLOCK_SIZE
Block size.
|
Constructor and Description |
---|
BlockRealMatrix(double[][] rawData)
Create a new dense matrix copying entries from raw layout data.
|
BlockRealMatrix(int rows,
int columns)
Create a new matrix with the supplied row and column dimensions.
|
BlockRealMatrix(int rows,
int columns,
double[][] blockData,
boolean copyArray)
Create a new dense matrix copying entries from block layout data.
|
Modifier and Type | Method and Description |
---|---|
BlockRealMatrix |
add(BlockRealMatrix m)
Compute the sum of this matrix and
m . |
BlockRealMatrix |
add(RealMatrix m)
Returns the sum of
this and m . |
void |
addToEntry(int row,
int column,
double increment)
Adds (in place) the specified value to the specified entry of
this matrix. |
BlockRealMatrix |
copy()
Returns a (deep) copy of this.
|
static double[][] |
createBlocksLayout(int rows,
int columns)
Create a data array in blocks layout.
|
BlockRealMatrix |
createMatrix(int rowDimension,
int columnDimension)
Create a new RealMatrix of the same type as the instance with the
supplied
row and column dimensions.
|
double[] |
getColumn(int column)
Get the entries at the given column index as an array.
|
int |
getColumnDimension()
Returns the number of columns of this matrix.
|
BlockRealMatrix |
getColumnMatrix(int column)
Get the entries at the given column index as a column matrix.
|
RealVector |
getColumnVector(int column)
Get the entries at the given column index as a vector.
|
double[][] |
getData()
Returns matrix entries as a two-dimensional array.
|
double |
getEntry(int row,
int column)
Get the entry in the specified row and column.
|
double |
getFrobeniusNorm()
Returns the
Frobenius norm of the matrix.
|
double |
getNorm1()
Returns the
maximum absolute column sum norm (L1) of the matrix.
|
double |
getNormInfty()
Returns the
maximum absolute row sum norm (L∞) of the matrix.
|
double[] |
getRow(int row)
Get the entries at the given row index.
|
int |
getRowDimension()
Returns the number of rows of this matrix.
|
BlockRealMatrix |
getRowMatrix(int row)
Get the entries at the given row index as a row matrix.
|
RealVector |
getRowVector(int row)
Returns the entries in row number
row as a vector. |
BlockRealMatrix |
getSubMatrix(int startRow,
int endRow,
int startColumn,
int endColumn)
Gets a submatrix.
|
BlockRealMatrix |
multiply(BlockRealMatrix m)
Returns the result of postmultiplying this by
m . |
BlockRealMatrix |
multiply(RealMatrix m)
Returns the result of postmultiplying
this by m . |
void |
multiplyEntry(int row,
int column,
double factor)
Multiplies (in place) the specified entry of
this matrix by the
specified value. |
BlockRealMatrix |
multiplyTransposed(BlockRealMatrix m)
Returns the result of postmultiplying
this by m^T . |
BlockRealMatrix |
multiplyTransposed(RealMatrix m)
Returns the result of postmultiplying
this by m^T . |
double[] |
operate(double[] v)
Returns the result of multiplying this by the vector
v . |
double[] |
preMultiply(double[] v)
Returns the (row) vector result of premultiplying this by the vector
v . |
BlockRealMatrix |
scalarAdd(double d)
Returns the result of adding
d to each entry of this . |
RealMatrix |
scalarMultiply(double d)
Returns the result of multiplying each entry of
this by
d . |
void |
setColumn(int column,
double[] array)
Sets the specified
column of this matrix to the entries
of the specified array . |
void |
setColumnMatrix(int column,
RealMatrix matrix)
Sets the specified
column of this matrix to the entries
of the specified column matrix . |
void |
setColumnVector(int column,
RealVector vector)
Sets the specified
column of this matrix to the entries
of the specified vector . |
void |
setEntry(int row,
int column,
double value)
Set the entry in the specified row and column.
|
void |
setRow(int row,
double[] array)
Sets the specified
row of this matrix to the entries
of the specified array . |
void |
setRowMatrix(int row,
BlockRealMatrix matrix)
Sets the entries in row number
row
as a row matrix. |
void |
setRowMatrix(int row,
RealMatrix matrix)
Sets the specified
row of this matrix to the entries of
the specified row matrix . |
void |
setRowVector(int row,
RealVector vector)
Sets the specified
row of this matrix to the entries of
the specified vector . |
void |
setSubMatrix(double[][] subMatrix,
int row,
int column)
Replace the submatrix starting at
row, column using data in the
input subMatrix array. |
BlockRealMatrix |
subtract(BlockRealMatrix m)
Subtract
m from this matrix. |
BlockRealMatrix |
subtract(RealMatrix m)
Returns
this minus m . |
static double[][] |
toBlocksLayout(double[][] rawData)
Convert a data array from raw layout to blocks layout.
|
BlockRealMatrix |
transpose()
Returns the transpose of this matrix.
|
BlockRealMatrix |
transposeMultiply(BlockRealMatrix m)
Returns the result of postmultiplying
this^T by m . |
BlockRealMatrix |
transposeMultiply(RealMatrix m)
Returns the result of postmultiplying
this^T by m . |
double |
walkInOptimizedOrder(RealMatrixChangingVisitor visitor)
Visit (and possibly change) all matrix entries using the fastest possible order.
|
double |
walkInOptimizedOrder(RealMatrixChangingVisitor visitor,
int startRow,
int endRow,
int startColumn,
int endColumn)
Visit (and possibly change) some matrix entries using the fastest possible order.
|
double |
walkInOptimizedOrder(RealMatrixPreservingVisitor visitor)
Visit (but don't change) all matrix entries using the fastest possible order.
|
double |
walkInOptimizedOrder(RealMatrixPreservingVisitor visitor,
int startRow,
int endRow,
int startColumn,
int endColumn)
Visit (but don't change) some matrix entries using the fastest possible order.
|
double |
walkInRowOrder(RealMatrixChangingVisitor visitor)
Visit (and possibly change) all matrix entries in row order.
|
double |
walkInRowOrder(RealMatrixChangingVisitor visitor,
int startRow,
int endRow,
int startColumn,
int endColumn)
Visit (and possibly change) some matrix entries in row order.
|
double |
walkInRowOrder(RealMatrixPreservingVisitor visitor)
Visit (but don't change) all matrix entries in row order.
|
double |
walkInRowOrder(RealMatrixPreservingVisitor visitor,
int startRow,
int endRow,
int startColumn,
int endColumn)
Visit (but don't change) some matrix entries in row order.
|
copySubMatrix, copySubMatrix, equals, getSubMatrix, getTrace, hashCode, isSquare, operate, power, preMultiply, preMultiply, toString, walkInColumnOrder, walkInColumnOrder, walkInColumnOrder, walkInColumnOrder
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
getNorm, map, mapToSelf
isTransposable, operateTranspose
public static final int BLOCK_SIZE
public BlockRealMatrix(int rows, int columns) throws MathIllegalArgumentException
rows
- the number of rows in the new matrixcolumns
- the number of columns in the new matrixMathIllegalArgumentException
- if row or column dimension is not
positive.public BlockRealMatrix(double[][] rawData) throws MathIllegalArgumentException
The input array must already be in raw layout.
Calling this constructor is equivalent to call:
matrix = new BlockRealMatrix(rawData.length, rawData[0].length, toBlocksLayout(rawData), false);
rawData
- data for new matrix, in raw layoutMathIllegalArgumentException
- if the shape of blockData
is
inconsistent with block layout.MathIllegalArgumentException
- if row or column dimension is not
positive.BlockRealMatrix(int, int, double[][], boolean)
public BlockRealMatrix(int rows, int columns, double[][] blockData, boolean copyArray) throws MathIllegalArgumentException
The input array must already be in blocks layout.
rows
- Number of rows in the new matrix.columns
- Number of columns in the new matrix.blockData
- data for new matrixcopyArray
- Whether the input array will be copied or referenced.MathIllegalArgumentException
- if the shape of blockData
is
inconsistent with block layout.MathIllegalArgumentException
- if row or column dimension is not
positive.createBlocksLayout(int, int)
,
toBlocksLayout(double[][])
,
BlockRealMatrix(double[][])
public static double[][] toBlocksLayout(double[][] rawData) throws MathIllegalArgumentException
Raw layout is the straightforward layout where element at row i and
column j is in array element rawData[i][j]
. Blocks layout
is the layout used in BlockRealMatrix
instances, where the matrix
is split in square blocks (except at right and bottom side where blocks may
be rectangular to fit matrix size) and each block is stored in a flattened
one-dimensional array.
This method creates an array in blocks layout from an input array in raw layout.
It can be used to provide the array argument of the BlockRealMatrix(int, int, double[][], boolean)
constructor.
rawData
- Data array in raw layout.MathIllegalArgumentException
- if rawData
is not rectangular.createBlocksLayout(int, int)
,
BlockRealMatrix(int, int, double[][], boolean)
public static double[][] createBlocksLayout(int rows, int columns)
This method can be used to create the array argument of the BlockRealMatrix(int, int, double[][], boolean)
constructor.
rows
- Number of rows in the new matrix.columns
- Number of columns in the new matrix.toBlocksLayout(double[][])
,
BlockRealMatrix(int, int, double[][], boolean)
public BlockRealMatrix createMatrix(int rowDimension, int columnDimension) throws MathIllegalArgumentException
createMatrix
in interface RealMatrix
createMatrix
in class AbstractRealMatrix
rowDimension
- the number of rows in the new matrixcolumnDimension
- the number of columns in the new matrixMathIllegalArgumentException
- if row or column dimension is not
positive.public BlockRealMatrix copy()
copy
in interface RealMatrix
copy
in class AbstractRealMatrix
public BlockRealMatrix add(RealMatrix m) throws MathIllegalArgumentException
this
and m
.add
in interface RealMatrix
add
in class AbstractRealMatrix
m
- matrix to be addedthis + m
MathIllegalArgumentException
- if m
is not the same
size as this
.public BlockRealMatrix add(BlockRealMatrix m) throws MathIllegalArgumentException
m
.m
- Matrix to be added.this
+ m.MathIllegalArgumentException
- if m
is not the same
size as this matrix.public BlockRealMatrix subtract(RealMatrix m) throws MathIllegalArgumentException
this
minus m
.subtract
in interface RealMatrix
subtract
in class AbstractRealMatrix
m
- matrix to be subtractedthis - m
MathIllegalArgumentException
- if m
is not the same
size as this
.public BlockRealMatrix subtract(BlockRealMatrix m) throws MathIllegalArgumentException
m
from this matrix.m
- Matrix to be subtracted.this
- m.MathIllegalArgumentException
- if m
is not the
same size as this matrix.public BlockRealMatrix scalarAdd(double d)
d
to each entry of this
.scalarAdd
in interface RealMatrix
scalarAdd
in class AbstractRealMatrix
d
- value to be added to each entryd + this
public RealMatrix scalarMultiply(double d)
this
by
d
.scalarMultiply
in interface RealMatrix
scalarMultiply
in class AbstractRealMatrix
d
- value to multiply all entries byd * this
public BlockRealMatrix multiply(RealMatrix m) throws MathIllegalArgumentException
this
by m
.multiply
in interface RealMatrix
multiply
in class AbstractRealMatrix
m
- matrix to postmultiply bythis * m
MathIllegalArgumentException
- if
columnDimension(this) != rowDimension(m)
public BlockRealMatrix multiply(BlockRealMatrix m) throws MathIllegalArgumentException
m
.m
- Matrix to postmultiply by.this
* m.MathIllegalArgumentException
- if the matrices are not compatible.public BlockRealMatrix multiplyTransposed(BlockRealMatrix m) throws MathIllegalArgumentException
this
by m^T
.m
- matrix to first transpose and second postmultiply bythis * m^T
MathIllegalArgumentException
- if
columnDimension(this) != columnDimension(m)
public BlockRealMatrix multiplyTransposed(RealMatrix m) throws MathIllegalArgumentException
this
by m^T
.
This is equivalent to call multiply
(m.RealMatrix.transpose()
),
but some implementations may avoid building the intermediate transposed matrix.
multiplyTransposed
in interface RealMatrix
m
- matrix to first transpose and second postmultiply bythis * m^T
MathIllegalArgumentException
- if
columnDimension(this) != columnDimension(m)
public BlockRealMatrix transposeMultiply(BlockRealMatrix m) throws MathIllegalArgumentException
this^T
by m
.m
- matrix to postmultiply bythis^T * m
MathIllegalArgumentException
- if
columnDimension(this) != columnDimension(m)
public BlockRealMatrix transposeMultiply(RealMatrix m) throws MathIllegalArgumentException
this^T
by m
.
This is equivalent to call RealMatrix.transpose()
.multiply(m)
,
but some implementations may avoid building the intermediate transposed matrix.
transposeMultiply
in interface RealMatrix
m
- matrix to postmultiply bythis^T * m
MathIllegalArgumentException
- if
columnDimension(this) != columnDimension(m)
public double[][] getData()
getData
in interface RealMatrix
getData
in class AbstractRealMatrix
public double getNorm1()
getNorm1
in interface RealMatrix
public double getNormInfty()
getNormInfty
in interface RealMatrix
public double getFrobeniusNorm()
getFrobeniusNorm
in interface RealMatrix
getFrobeniusNorm
in class AbstractRealMatrix
public BlockRealMatrix getSubMatrix(int startRow, int endRow, int startColumn, int endColumn) throws MathIllegalArgumentException
getSubMatrix
in interface RealMatrix
getSubMatrix
in class AbstractRealMatrix
startRow
- Initial row indexendRow
- Final row index (inclusive)startColumn
- Initial column indexendColumn
- Final column index (inclusive)MathIllegalArgumentException
- if the indices are not valid.public void setSubMatrix(double[][] subMatrix, int row, int column) throws MathIllegalArgumentException, NullArgumentException
row, column
using data in the
input subMatrix
array. Indexes are 0-based.
Example:
Starting with
1 2 3 4 5 6 7 8 9 0 1 2and
subMatrix = {{3, 4} {5,6}}
, invoking
setSubMatrix(subMatrix,1,1))
will result in 1 2 3 4 5 3 4 8 9 5 6 2
setSubMatrix
in interface RealMatrix
setSubMatrix
in class AbstractRealMatrix
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 replacedMathIllegalArgumentException
- if subMatrix
is empty.NullArgumentException
- if subMatrix
is null
.public BlockRealMatrix getRowMatrix(int row) throws MathIllegalArgumentException
getRowMatrix
in interface RealMatrix
getRowMatrix
in class AbstractRealMatrix
row
- Row to be fetched.MathIllegalArgumentException
- if the specified row index is invalid.public void setRowMatrix(int row, RealMatrix matrix) throws MathIllegalArgumentException
row
of this
matrix to the entries of
the specified row matrix
. Row indices start at 0.setRowMatrix
in interface RealMatrix
setRowMatrix
in class AbstractRealMatrix
row
- Row to be set.matrix
- Row matrix to be copied (must have one row and the same
number of columns as the instance).MathIllegalArgumentException
- if the specified row index is invalid.public void setRowMatrix(int row, BlockRealMatrix matrix) throws MathIllegalArgumentException
row
as a row matrix. Row indices start at 0.row
- the row to be setmatrix
- row matrix (must have one row and the same number of columns
as the instance)MathIllegalArgumentException
- if the specified row index is invalid.MathIllegalArgumentException
- if the matrix dimensions do
not match one instance row.public BlockRealMatrix getColumnMatrix(int column) throws MathIllegalArgumentException
getColumnMatrix
in interface RealMatrix
getColumnMatrix
in class AbstractRealMatrix
column
- Column to be fetched.MathIllegalArgumentException
- if the specified column index is invalid.public void setColumnMatrix(int column, RealMatrix matrix) throws MathIllegalArgumentException
column
of this
matrix to the entries
of the specified column matrix
. Column indices start at 0.setColumnMatrix
in interface RealMatrix
setColumnMatrix
in class AbstractRealMatrix
column
- Column to be set.matrix
- Column matrix to be copied (must have one column and the
same number of rows as the instance).MathIllegalArgumentException
- if the specified column index is invalid.public RealVector getRowVector(int row) throws MathIllegalArgumentException
row
as a vector. Row indices
start at 0.getRowVector
in interface RealMatrix
getRowVector
in class AbstractRealMatrix
row
- Row to be fetched.MathIllegalArgumentException
- if the specified row index is invalid.public void setRowVector(int row, RealVector vector) throws MathIllegalArgumentException
row
of this
matrix to the entries of
the specified vector
. Row indices start at 0.setRowVector
in interface RealMatrix
setRowVector
in class AbstractRealMatrix
row
- Row to be set.vector
- row vector to be copied (must have the same number of
column as the instance).MathIllegalArgumentException
- if the specified row index is invalid.public RealVector getColumnVector(int column) throws MathIllegalArgumentException
getColumnVector
in interface RealMatrix
getColumnVector
in class AbstractRealMatrix
column
- Column to be fetched.MathIllegalArgumentException
- if the specified column index is invalidpublic void setColumnVector(int column, RealVector vector) throws MathIllegalArgumentException
column
of this
matrix to the entries
of the specified vector
. Column indices start at 0.setColumnVector
in interface RealMatrix
setColumnVector
in class AbstractRealMatrix
column
- Column to be set.vector
- column vector to be copied (must have the same number of
rows as the instance).MathIllegalArgumentException
- if the specified column index is invalid.public double[] getRow(int row) throws MathIllegalArgumentException
getRow
in interface RealMatrix
getRow
in class AbstractRealMatrix
row
- Row to be fetched.MathIllegalArgumentException
- if the specified row index is not valid.public void setRow(int row, double[] array) throws MathIllegalArgumentException
row
of this
matrix to the entries
of the specified array
. Row indices start at 0.setRow
in interface RealMatrix
setRow
in class AbstractRealMatrix
row
- Row to be set.array
- Row matrix to be copied (must have the same number of
columns as the instance)MathIllegalArgumentException
- if the specified row index is invalid.public double[] getColumn(int column) throws MathIllegalArgumentException
getColumn
in interface RealMatrix
getColumn
in class AbstractRealMatrix
column
- Column to be fetched.MathIllegalArgumentException
- if the specified column index is not valid.public void setColumn(int column, double[] array) throws MathIllegalArgumentException
column
of this
matrix to the entries
of the specified array
. Column indices start at 0.setColumn
in interface RealMatrix
setColumn
in class AbstractRealMatrix
column
- Column to be set.array
- Column array to be copied (must have the same number of
rows as the instance).MathIllegalArgumentException
- if the specified column index is invalid.public double getEntry(int row, int column) throws MathIllegalArgumentException
getEntry
in interface RealMatrix
getEntry
in class AbstractRealMatrix
row
- Row index of entry to be fetched.column
- Column index of entry to be fetched.(row, column)
.MathIllegalArgumentException
- if the row or column index is not valid.public void setEntry(int row, int column, double value) throws MathIllegalArgumentException
setEntry
in interface RealMatrix
setEntry
in class AbstractRealMatrix
row
- Row index of entry to be set.column
- Column index of entry to be set.value
- the new value of the entry.MathIllegalArgumentException
- if the row or column index is not validpublic void addToEntry(int row, int column, double increment) throws MathIllegalArgumentException
this
matrix. Row and column indices start at 0.addToEntry
in interface RealMatrix
addToEntry
in class AbstractRealMatrix
row
- Row index of the entry to be modified.column
- Column index of the entry to be modified.increment
- value to add to the matrix entry.MathIllegalArgumentException
- if the row or column index is not valid.public void multiplyEntry(int row, int column, double factor) throws MathIllegalArgumentException
this
matrix by the
specified value. Row and column indices start at 0.multiplyEntry
in interface RealMatrix
multiplyEntry
in class AbstractRealMatrix
row
- Row index of the entry to be modified.column
- Column index of the entry to be modified.factor
- Multiplication factor for the matrix entry.MathIllegalArgumentException
- if the row or column index is not valid.public BlockRealMatrix transpose()
transpose
in interface RealMatrix
transpose
in class AbstractRealMatrix
public int getRowDimension()
getRowDimension
in interface AnyMatrix
getRowDimension
in interface RealLinearOperator
getRowDimension
in class AbstractRealMatrix
public int getColumnDimension()
getColumnDimension
in interface AnyMatrix
getColumnDimension
in interface RealLinearOperator
getColumnDimension
in class AbstractRealMatrix
public double[] operate(double[] v) throws MathIllegalArgumentException
v
.operate
in interface RealMatrix
operate
in class AbstractRealMatrix
v
- the vector to operate onthis * v
MathIllegalArgumentException
- if the length of v
does not
match the column dimension of this
.public double[] preMultiply(double[] v) throws MathIllegalArgumentException
v
.preMultiply
in interface RealMatrix
preMultiply
in class AbstractRealMatrix
v
- the row vector to premultiply byv * this
MathIllegalArgumentException
- if the length of v
does not
match the row dimension of this
.public double walkInRowOrder(RealMatrixChangingVisitor visitor)
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.
walkInRowOrder
in interface RealMatrix
walkInRowOrder
in class AbstractRealMatrix
visitor
- visitor used to process all matrix entriesRealMatrixChangingVisitor.end()
at the end
of the walkRealMatrix.walkInRowOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInRowOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInRowOrder(RealMatrixPreservingVisitor, int, int, int, int)
,
RealMatrix.walkInColumnOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInColumnOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int)
,
RealMatrix.walkInOptimizedOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInOptimizedOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInOptimizedOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInOptimizedOrder(RealMatrixPreservingVisitor, int, int, int, int)
public double walkInRowOrder(RealMatrixPreservingVisitor visitor)
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.
walkInRowOrder
in interface RealMatrix
walkInRowOrder
in class AbstractRealMatrix
visitor
- visitor used to process all matrix entriesRealMatrixPreservingVisitor.end()
at the end
of the walkRealMatrix.walkInRowOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInRowOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInRowOrder(RealMatrixPreservingVisitor, int, int, int, int)
,
RealMatrix.walkInColumnOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInColumnOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int)
,
RealMatrix.walkInOptimizedOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInOptimizedOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInOptimizedOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInOptimizedOrder(RealMatrixPreservingVisitor, int, int, int, int)
public double walkInRowOrder(RealMatrixChangingVisitor visitor, int startRow, int endRow, int startColumn, int endColumn) throws MathIllegalArgumentException
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.
walkInRowOrder
in interface RealMatrix
walkInRowOrder
in class AbstractRealMatrix
visitor
- visitor used to process all matrix entriesstartRow
- Initial row indexendRow
- Final row index (inclusive)startColumn
- Initial column indexendColumn
- Final column indexRealMatrixChangingVisitor.end()
at the end
of the walkMathIllegalArgumentException
- if the indices are not valid.RealMatrix.walkInRowOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInRowOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInRowOrder(RealMatrixPreservingVisitor, int, int, int, int)
,
RealMatrix.walkInColumnOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInColumnOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int)
,
RealMatrix.walkInOptimizedOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInOptimizedOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInOptimizedOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInOptimizedOrder(RealMatrixPreservingVisitor, int, int, int, int)
public double walkInRowOrder(RealMatrixPreservingVisitor visitor, int startRow, int endRow, int startColumn, int endColumn) throws MathIllegalArgumentException
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.
walkInRowOrder
in interface RealMatrix
walkInRowOrder
in class AbstractRealMatrix
visitor
- visitor used to process all matrix entriesstartRow
- Initial row indexendRow
- Final row index (inclusive)startColumn
- Initial column indexendColumn
- Final column indexRealMatrixPreservingVisitor.end()
at the end
of the walkMathIllegalArgumentException
- if the indices are not valid.RealMatrix.walkInRowOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInRowOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInRowOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInColumnOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInColumnOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int)
,
RealMatrix.walkInOptimizedOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInOptimizedOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInOptimizedOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInOptimizedOrder(RealMatrixPreservingVisitor, int, int, int, int)
public double walkInOptimizedOrder(RealMatrixChangingVisitor visitor)
The fastest walking order depends on the exact matrix class. It may be different from traditional row or column orders.
walkInOptimizedOrder
in interface RealMatrix
walkInOptimizedOrder
in class AbstractRealMatrix
visitor
- visitor used to process all matrix entriesRealMatrixChangingVisitor.end()
at the end
of the walkRealMatrix.walkInRowOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInRowOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInRowOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInRowOrder(RealMatrixPreservingVisitor, int, int, int, int)
,
RealMatrix.walkInColumnOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInColumnOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int)
,
RealMatrix.walkInOptimizedOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInOptimizedOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInOptimizedOrder(RealMatrixPreservingVisitor, int, int, int, int)
public double walkInOptimizedOrder(RealMatrixPreservingVisitor visitor)
The fastest walking order depends on the exact matrix class. It may be different from traditional row or column orders.
walkInOptimizedOrder
in interface RealMatrix
walkInOptimizedOrder
in class AbstractRealMatrix
visitor
- visitor used to process all matrix entriesRealMatrixPreservingVisitor.end()
at the end
of the walkRealMatrix.walkInRowOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInRowOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInRowOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInRowOrder(RealMatrixPreservingVisitor, int, int, int, int)
,
RealMatrix.walkInColumnOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInColumnOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int)
,
RealMatrix.walkInOptimizedOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInOptimizedOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInOptimizedOrder(RealMatrixPreservingVisitor, int, int, int, int)
public double walkInOptimizedOrder(RealMatrixChangingVisitor visitor, int startRow, int endRow, int startColumn, int endColumn) throws MathIllegalArgumentException
The fastest walking order depends on the exact matrix class. It may be different from traditional row or column orders.
walkInOptimizedOrder
in interface RealMatrix
walkInOptimizedOrder
in class AbstractRealMatrix
visitor
- visitor used to process all matrix entriesstartRow
- Initial row indexendRow
- Final row index (inclusive)startColumn
- Initial column indexendColumn
- Final column index (inclusive)RealMatrixChangingVisitor.end()
at the end
of the walkMathIllegalArgumentException
- if the indices are not valid.RealMatrix.walkInRowOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInRowOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInRowOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInRowOrder(RealMatrixPreservingVisitor, int, int, int, int)
,
RealMatrix.walkInColumnOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInColumnOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int)
,
RealMatrix.walkInOptimizedOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInOptimizedOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInOptimizedOrder(RealMatrixPreservingVisitor, int, int, int, int)
public double walkInOptimizedOrder(RealMatrixPreservingVisitor visitor, int startRow, int endRow, int startColumn, int endColumn) throws MathIllegalArgumentException
The fastest walking order depends on the exact matrix class. It may be different from traditional row or column orders.
walkInOptimizedOrder
in interface RealMatrix
walkInOptimizedOrder
in class AbstractRealMatrix
visitor
- visitor used to process all matrix entriesstartRow
- Initial row indexendRow
- Final row index (inclusive)startColumn
- Initial column indexendColumn
- Final column index (inclusive)RealMatrixPreservingVisitor.end()
at the end
of the walkMathIllegalArgumentException
- if the indices are not valid.RealMatrix.walkInRowOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInRowOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInRowOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInRowOrder(RealMatrixPreservingVisitor, int, int, int, int)
,
RealMatrix.walkInColumnOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInColumnOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int)
,
RealMatrix.walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int)
,
RealMatrix.walkInOptimizedOrder(RealMatrixChangingVisitor)
,
RealMatrix.walkInOptimizedOrder(RealMatrixPreservingVisitor)
,
RealMatrix.walkInOptimizedOrder(RealMatrixChangingVisitor, int, int, int, int)
Copyright © 2016–2020 Hipparchus.org. All rights reserved.