Interface RealMatrix
- 
- All Superinterfaces:
- AnyMatrix
 - All Known Subinterfaces:
- SparseRealMatrix
 - All Known Implementing Classes:
- AbstractRealMatrix,- Array2DRowRealMatrix,- BlockRealMatrix,- DiagonalMatrix,- OpenMapRealMatrix
 
 public interface RealMatrix extends AnyMatrix Interface defining a real-valued matrix with basic algebraic operations.Matrix element indexing is 0-based -- e.g., getEntry(0, 0)returns the element in the first row, first column of the matrix.
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Modifier and Type Method Description RealMatrixadd(RealMatrix m)Returns the sum ofthisandm.voidaddToEntry(int row, int column, double increment)Adds (in place) the specified value to the specified entry ofthismatrix.RealMatrixcopy()Returns a (deep) copy of this.voidcopySubMatrix(int[] selectedRows, int[] selectedColumns, double[][] destination)Copy a submatrix.voidcopySubMatrix(int startRow, int endRow, int startColumn, int endColumn, double[][] destination)Copy a submatrix.RealMatrixcreateMatrix(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.RealMatrixgetColumnMatrix(int column)Get the entries at the given column index as a column matrix.RealVectorgetColumnVector(int column)Get the entries at the given column index as a vector.double[][]getData()Returns matrix entries as a two-dimensional array.doublegetEntry(int row, int column)Get the entry in the specified row and column.doublegetFrobeniusNorm()Returns the Frobenius norm of the matrix.doublegetNorm()Returns the maximum absolute row sum norm of the matrix.double[]getRow(int row)Get the entries at the given row index.RealMatrixgetRowMatrix(int row)Get the entries at the given row index as a row matrix.RealVectorgetRowVector(int row)Returns the entries in row numberrowas a vector.RealMatrixgetSubMatrix(int[] selectedRows, int[] selectedColumns)Gets a submatrix.RealMatrixgetSubMatrix(int startRow, int endRow, int startColumn, int endColumn)Gets a submatrix.doublegetTrace()Returns the trace of the matrix (the sum of the elements on the main diagonal).RealMatrixmultiply(RealMatrix m)Returns the result of postmultiplyingthisbym.voidmultiplyEntry(int row, int column, double factor)Multiplies (in place) the specified entry ofthismatrix by the specified value.double[]operate(double[] v)Returns the result of multiplying this by the vectorv.RealVectoroperate(RealVector v)Returns the result of multiplying this by the vectorv.RealMatrixpower(int p)Returns the result of multiplyingthiswith itselfptimes.double[]preMultiply(double[] v)Returns the (row) vector result of premultiplying this by the vectorv.RealMatrixpreMultiply(RealMatrix m)Returns the result of premultiplyingthisbym.RealVectorpreMultiply(RealVector v)Returns the (row) vector result of premultiplying this by the vectorv.RealMatrixscalarAdd(double d)Returns the result of addingdto each entry ofthis.RealMatrixscalarMultiply(double d)Returns the result of multiplying each entry ofthisbyd.voidsetColumn(int column, double[] array)Sets the specifiedcolumnofthismatrix to the entries of the specifiedarray.voidsetColumnMatrix(int column, RealMatrix matrix)Sets the specifiedcolumnofthismatrix to the entries of the specified columnmatrix.voidsetColumnVector(int column, RealVector vector)Sets the specifiedcolumnofthismatrix to the entries of the specifiedvector.voidsetEntry(int row, int column, double value)Set the entry in the specified row and column.voidsetRow(int row, double[] array)Sets the specifiedrowofthismatrix to the entries of the specifiedarray.voidsetRowMatrix(int row, RealMatrix matrix)Sets the specifiedrowofthismatrix to the entries of the specified rowmatrix.voidsetRowVector(int row, RealVector vector)Sets the specifiedrowofthismatrix to the entries of the specifiedvector.voidsetSubMatrix(double[][] subMatrix, int row, int column)Replace the submatrix starting atrow, columnusing data in the inputsubMatrixarray.RealMatrixsubtract(RealMatrix m)Returnsthisminusm.RealMatrixtranspose()Returns the transpose of this matrix.doublewalkInColumnOrder(RealMatrixChangingVisitor visitor)Visit (and possibly change) all matrix entries in column order.doublewalkInColumnOrder(RealMatrixChangingVisitor visitor, int startRow, int endRow, int startColumn, int endColumn)Visit (and possibly change) some matrix entries in column order.doublewalkInColumnOrder(RealMatrixPreservingVisitor visitor)Visit (but don't change) all matrix entries in column order.doublewalkInColumnOrder(RealMatrixPreservingVisitor visitor, int startRow, int endRow, int startColumn, int endColumn)Visit (but don't change) some matrix entries in column order.doublewalkInOptimizedOrder(RealMatrixChangingVisitor visitor)Visit (and possibly change) all matrix entries using the fastest possible order.doublewalkInOptimizedOrder(RealMatrixChangingVisitor visitor, int startRow, int endRow, int startColumn, int endColumn)Visit (and possibly change) some matrix entries using the fastest possible order.doublewalkInOptimizedOrder(RealMatrixPreservingVisitor visitor)Visit (but don't change) all matrix entries using the fastest possible order.doublewalkInOptimizedOrder(RealMatrixPreservingVisitor visitor, int startRow, int endRow, int startColumn, int endColumn)Visit (but don't change) some matrix entries using the fastest possible order.doublewalkInRowOrder(RealMatrixChangingVisitor visitor)Visit (and possibly change) all matrix entries in row order.doublewalkInRowOrder(RealMatrixChangingVisitor visitor, int startRow, int endRow, int startColumn, int endColumn)Visit (and possibly change) some matrix entries in row order.doublewalkInRowOrder(RealMatrixPreservingVisitor visitor)Visit (but don't change) all matrix entries in row order.doublewalkInRowOrder(RealMatrixPreservingVisitor 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.math4.legacy.linear.AnyMatrixcanAdd, canMultiply, checkAdd, checkMultiply, getColumnDimension, getRowDimension, isSquare
 
- 
 
- 
- 
- 
Method Detail- 
createMatrixRealMatrix createMatrix(int rowDimension, int columnDimension) throws NotStrictlyPositiveException Create a new RealMatrix of the same type as the instance with the supplied row and column dimensions.- Parameters:
- rowDimension- the number of rows in the new matrix
- columnDimension- the number of columns in the new matrix
- Returns:
- a new matrix of the same type as the instance
- Throws:
- NotStrictlyPositiveException- if row or column dimension is not positive.
- Since:
- 2.0
 
 - 
copyRealMatrix copy() Returns a (deep) copy of this.- Returns:
- matrix copy
 
 - 
addRealMatrix add(RealMatrix m) throws MatrixDimensionMismatchException Returns the sum ofthisandm.- Parameters:
- m- matrix to be added
- Returns:
- this + m
- Throws:
- MatrixDimensionMismatchException- if- mis not the same size as- this.
 
 - 
subtractRealMatrix subtract(RealMatrix m) throws MatrixDimensionMismatchException Returnsthisminusm.- Parameters:
- m- matrix to be subtracted
- Returns:
- this - m
- Throws:
- MatrixDimensionMismatchException- if- mis not the same size as- this.
 
 - 
scalarAddRealMatrix scalarAdd(double d) Returns the result of addingdto each entry ofthis.- Parameters:
- d- value to be added to each entry
- Returns:
- d + this
 
 - 
scalarMultiplyRealMatrix scalarMultiply(double d) Returns the result of multiplying each entry ofthisbyd.- Parameters:
- d- value to multiply all entries by
- Returns:
- d * this
 
 - 
multiplyRealMatrix multiply(RealMatrix m) throws DimensionMismatchException Returns the result of postmultiplyingthisbym.- Parameters:
- m- matrix to postmultiply by
- Returns:
- this * m
- Throws:
- DimensionMismatchException- if- columnDimension(this) != rowDimension(m)
 
 - 
preMultiplyRealMatrix preMultiply(RealMatrix m) throws DimensionMismatchException Returns the result of premultiplyingthisbym.- Parameters:
- m- matrix to premultiply by
- Returns:
- m * this
- Throws:
- DimensionMismatchException- if- rowDimension(this) != columnDimension(m)
 
 - 
powerRealMatrix power(int p) throws NotPositiveException, NonSquareMatrixException Returns the result of multiplyingthiswith itselfptimes. Depending on the underlying storage, instability for high powers might occur.- Parameters:
- p- raise- thisto power- p
- Returns:
- this^p
- Throws:
- NotPositiveException- if- p < 0
- NonSquareMatrixException- if the matrix is not square
 
 - 
getDatadouble[][] getData() Returns matrix entries as a two-dimensional array.- Returns:
- 2-dimensional array of entries
 
 - 
getNormdouble getNorm() Returns the maximum absolute row sum norm of the matrix.- Returns:
- norm
 
 - 
getFrobeniusNormdouble getFrobeniusNorm() Returns the Frobenius norm of the matrix.- Returns:
- norm
 
 - 
getSubMatrixRealMatrix getSubMatrix(int startRow, int endRow, int startColumn, int endColumn) throws OutOfRangeException, NumberIsTooSmallException Gets a submatrix. Rows and columns are indicated counting from 0 to n-1.- Parameters:
- startRow- Initial row index
- endRow- Final row index (inclusive)
- startColumn- Initial column index
- endColumn- Final column index (inclusive)
- Returns:
- The subMatrix containing the data of the specified rows and columns.
- Throws:
- OutOfRangeException- if the indices are not valid.
- NumberIsTooSmallException- if- endRow < startRowor- endColumn < startColumn.
 
 - 
getSubMatrixRealMatrix getSubMatrix(int[] selectedRows, int[] selectedColumns) throws NullArgumentException, NoDataException, OutOfRangeException 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:
- NullArgumentException- if the row or column selections are- null
- NoDataException- if the row or column selections are empty (zero length).
- OutOfRangeException- if the indices are not valid.
 
 - 
copySubMatrixvoid copySubMatrix(int startRow, int endRow, int startColumn, int endColumn, double[][] destination) throws OutOfRangeException, NumberIsTooSmallException, MatrixDimensionMismatchException Copy a submatrix. Rows and columns are indicated counting from 0 to n-1.- Parameters:
- startRow- Initial row index
- endRow- Final row index (inclusive)
- startColumn- Initial column index
- endColumn- 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:
- OutOfRangeException- if the indices are not valid.
- NumberIsTooSmallException- if- endRow < startRowor- endColumn < startColumn.
- MatrixDimensionMismatchException- if the destination array is too small.
 
 - 
copySubMatrixvoid copySubMatrix(int[] selectedRows, int[] selectedColumns, double[][] destination) throws OutOfRangeException, NullArgumentException, NoDataException, MatrixDimensionMismatchException 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:
- NullArgumentException- if the row or column selections are- null
- NoDataException- if the row or column selections are empty (zero length).
- OutOfRangeException- if the indices are not valid.
- MatrixDimensionMismatchException- if the destination array is too small.
 
 - 
setSubMatrixvoid setSubMatrix(double[][] subMatrix, int row, int column) throws NoDataException, OutOfRangeException, DimensionMismatchException, NullArgumentException Replace the submatrix starting atrow, columnusing data in the inputsubMatrixarray. 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 data
- row- row coordinate of the top, left element to be replaced
- column- column coordinate of the top, left element to be replaced
- Throws:
- NoDataException- if- subMatrixis empty.
- OutOfRangeException- if- subMatrixdoes not fit into this matrix from element in- (row, column).
- DimensionMismatchException- if- subMatrixis not rectangular (not all rows have the same length) or empty.
- NullArgumentException- if- subMatrixis- null.
- Since:
- 2.0
 
 - 
getRowMatrixRealMatrix getRowMatrix(int row) throws OutOfRangeException Get the entries at the given row index as a row matrix. Row indices start at 0.- Parameters:
- row- Row to be fetched.
- Returns:
- row Matrix.
- Throws:
- OutOfRangeException- if the specified row index is invalid.
 
 - 
setRowMatrixvoid setRowMatrix(int row, RealMatrix matrix) throws OutOfRangeException, MatrixDimensionMismatchException Sets the specifiedrowofthismatrix to the entries of the specified rowmatrix. Row indices start at 0.- Parameters:
- row- Row to be set.
- matrix- Row matrix to be copied (must have one row and the same number of columns as the instance).
- Throws:
- OutOfRangeException- if the specified row index is invalid.
- MatrixDimensionMismatchException- if the row dimension of the- matrixis not- 1, or the column dimensions of- thisand- matrixdo not match.
 
 - 
getColumnMatrixRealMatrix getColumnMatrix(int column) throws OutOfRangeException Get the entries at the given column index as a column matrix. Column indices start at 0.- Parameters:
- column- Column to be fetched.
- Returns:
- column Matrix.
- Throws:
- OutOfRangeException- if the specified column index is invalid.
 
 - 
setColumnMatrixvoid setColumnMatrix(int column, RealMatrix matrix) throws OutOfRangeException, MatrixDimensionMismatchException Sets the specifiedcolumnofthismatrix to the entries of the specified columnmatrix. Column indices start at 0.- Parameters:
- column- Column to be set.
- matrix- Column matrix to be copied (must have one column and the same number of rows as the instance).
- Throws:
- OutOfRangeException- if the specified column index is invalid.
- MatrixDimensionMismatchException- if the column dimension of the- matrixis not- 1, or the row dimensions of- thisand- matrixdo not match.
 
 - 
getRowVectorRealVector getRowVector(int row) throws OutOfRangeException Returns the entries in row numberrowas a vector. Row indices start at 0.- Parameters:
- row- Row to be fetched.
- Returns:
- a row vector.
- Throws:
- OutOfRangeException- if the specified row index is invalid.
 
 - 
setRowVectorvoid setRowVector(int row, RealVector vector) throws OutOfRangeException, MatrixDimensionMismatchException Sets the specifiedrowofthismatrix to the entries of the specifiedvector. Row indices start at 0.- Parameters:
- row- Row to be set.
- vector- row vector to be copied (must have the same number of column as the instance).
- Throws:
- OutOfRangeException- if the specified row index is invalid.
- MatrixDimensionMismatchException- if the- vectordimension does not match the column dimension of- thismatrix.
 
 - 
getColumnVectorRealVector getColumnVector(int column) throws OutOfRangeException Get the entries at the given column index as a vector. Column indices start at 0.- Parameters:
- column- Column to be fetched.
- Returns:
- a column vector.
- Throws:
- OutOfRangeException- if the specified column index is invalid
 
 - 
setColumnVectorvoid setColumnVector(int column, RealVector vector) throws OutOfRangeException, MatrixDimensionMismatchException Sets the specifiedcolumnofthismatrix to the entries of the specifiedvector. Column indices start at 0.- Parameters:
- column- Column to be set.
- vector- column vector to be copied (must have the same number of rows as the instance).
- Throws:
- OutOfRangeException- if the specified column index is invalid.
- MatrixDimensionMismatchException- if the- vectordimension does not match the row dimension of- thismatrix.
 
 - 
getRowdouble[] getRow(int row) throws OutOfRangeException Get the entries at the given row index. Row indices start at 0.- Parameters:
- row- Row to be fetched.
- Returns:
- the array of entries in the row.
- Throws:
- OutOfRangeException- if the specified row index is not valid.
 
 - 
setRowvoid setRow(int row, double[] array) throws OutOfRangeException, MatrixDimensionMismatchException Sets the specifiedrowofthismatrix to the entries of the specifiedarray. Row indices start at 0.- Parameters:
- row- Row to be set.
- array- Row matrix to be copied (must have the same number of columns as the instance)
- Throws:
- OutOfRangeException- if the specified row index is invalid.
- MatrixDimensionMismatchException- if the- arraylength does not match the column dimension of- thismatrix.
 
 - 
getColumndouble[] getColumn(int column) throws OutOfRangeException Get the entries at the given column index as an array. Column indices start at 0.- Parameters:
- column- Column to be fetched.
- Returns:
- the array of entries in the column.
- Throws:
- OutOfRangeException- if the specified column index is not valid.
 
 - 
setColumnvoid setColumn(int column, double[] array) throws OutOfRangeException, MatrixDimensionMismatchException Sets the specifiedcolumnofthismatrix to the entries of the specifiedarray. Column indices start at 0.- Parameters:
- column- Column to be set.
- array- Column array to be copied (must have the same number of rows as the instance).
- Throws:
- OutOfRangeException- if the specified column index is invalid.
- MatrixDimensionMismatchException- if the- arraylength does not match the row dimension of- thismatrix.
 
 - 
getEntrydouble getEntry(int row, int column) throws OutOfRangeException Get the entry in the specified row and column. Row and column indices start at 0.- Parameters:
- row- Row index of entry to be fetched.
- column- Column index of entry to be fetched.
- Returns:
- the matrix entry at (row, column).
- Throws:
- OutOfRangeException- if the row or column index is not valid.
 
 - 
setEntryvoid setEntry(int row, int column, double value) throws OutOfRangeException Set the entry in the specified row and column. Row and column indices start at 0.- Parameters:
- row- Row index of entry to be set.
- column- Column index of entry to be set.
- value- the new value of the entry.
- Throws:
- OutOfRangeException- if the row or column index is not valid
- Since:
- 2.0
 
 - 
addToEntryvoid addToEntry(int row, int column, double increment) throws OutOfRangeException Adds (in place) the specified value to the specified entry ofthismatrix. Row and column indices start at 0.- Parameters:
- 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.
- Throws:
- OutOfRangeException- if the row or column index is not valid.
- Since:
- 2.0
 
 - 
multiplyEntryvoid multiplyEntry(int row, int column, double factor) throws OutOfRangeException Multiplies (in place) the specified entry ofthismatrix by the specified value. Row and column indices start at 0.- Parameters:
- 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.
- Throws:
- OutOfRangeException- if the row or column index is not valid.
- Since:
- 2.0
 
 - 
transposeRealMatrix transpose() Returns the transpose of this matrix.- Returns:
- transpose matrix
 
 - 
getTracedouble getTrace() throws NonSquareMatrixException Returns the trace of the matrix (the sum of the elements on the main diagonal).- Returns:
- the trace.
- Throws:
- NonSquareMatrixException- if the matrix is not square.
 
 - 
operatedouble[] operate(double[] v) throws DimensionMismatchException Returns the result of multiplying this by the vectorv.- Parameters:
- v- the vector to operate on
- Returns:
- this * v
- Throws:
- DimensionMismatchException- if the length of- vdoes not match the column dimension of- this.
 
 - 
operateRealVector operate(RealVector v) throws DimensionMismatchException Returns the result of multiplying this by the vectorv.- Parameters:
- v- the vector to operate on
- Returns:
- this * v
- Throws:
- DimensionMismatchException- if the dimension of- vdoes not match the column dimension of- this.
 
 - 
preMultiplydouble[] preMultiply(double[] v) throws DimensionMismatchException Returns the (row) vector result of premultiplying this by the vectorv.- Parameters:
- v- the row vector to premultiply by
- Returns:
- v * this
- Throws:
- DimensionMismatchException- if the length of- vdoes not match the row dimension of- this.
 
 - 
preMultiplyRealVector preMultiply(RealVector v) throws DimensionMismatchException Returns the (row) vector result of premultiplying this by the vectorv.- Parameters:
- v- the row vector to premultiply by
- Returns:
- v * this
- Throws:
- DimensionMismatchException- if the dimension of- vdoes not match the row dimension of- this.
 
 - 
walkInRowOrderdouble walkInRowOrder(RealMatrixChangingVisitor visitor) 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 RealMatrixChangingVisitor.end()at the end of the walk
- See Also:
- walkInRowOrder(RealMatrixPreservingVisitor),- walkInRowOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInRowOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixChangingVisitor),- walkInColumnOrder(RealMatrixPreservingVisitor),- walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixChangingVisitor),- walkInOptimizedOrder(RealMatrixPreservingVisitor),- walkInOptimizedOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixPreservingVisitor, int, int, int, int)
 
 - 
walkInRowOrderdouble walkInRowOrder(RealMatrixPreservingVisitor visitor) 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 RealMatrixPreservingVisitor.end()at the end of the walk
- See Also:
- walkInRowOrder(RealMatrixChangingVisitor),- walkInRowOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInRowOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixChangingVisitor),- walkInColumnOrder(RealMatrixPreservingVisitor),- walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixChangingVisitor),- walkInOptimizedOrder(RealMatrixPreservingVisitor),- walkInOptimizedOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixPreservingVisitor, int, int, int, int)
 
 - 
walkInRowOrderdouble walkInRowOrder(RealMatrixChangingVisitor visitor, int startRow, int endRow, int startColumn, int endColumn) throws OutOfRangeException, NumberIsTooSmallException 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 entries
- startRow- Initial row index
- endRow- Final row index (inclusive)
- startColumn- Initial column index
- endColumn- Final column index
- Returns:
- the value returned by RealMatrixChangingVisitor.end()at the end of the walk
- Throws:
- OutOfRangeException- if the indices are not valid.
- NumberIsTooSmallException- if- endRow < startRowor- endColumn < startColumn.
- See Also:
- walkInRowOrder(RealMatrixChangingVisitor),- walkInRowOrder(RealMatrixPreservingVisitor),- walkInRowOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixChangingVisitor),- walkInColumnOrder(RealMatrixPreservingVisitor),- walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixChangingVisitor),- walkInOptimizedOrder(RealMatrixPreservingVisitor),- walkInOptimizedOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixPreservingVisitor, int, int, int, int)
 
 - 
walkInRowOrderdouble walkInRowOrder(RealMatrixPreservingVisitor visitor, int startRow, int endRow, int startColumn, int endColumn) throws OutOfRangeException, NumberIsTooSmallException 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 entries
- startRow- Initial row index
- endRow- Final row index (inclusive)
- startColumn- Initial column index
- endColumn- Final column index
- Returns:
- the value returned by RealMatrixPreservingVisitor.end()at the end of the walk
- Throws:
- OutOfRangeException- if the indices are not valid.
- NumberIsTooSmallException- if- endRow < startRowor- endColumn < startColumn.
- See Also:
- walkInRowOrder(RealMatrixChangingVisitor),- walkInRowOrder(RealMatrixPreservingVisitor),- walkInRowOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixChangingVisitor),- walkInColumnOrder(RealMatrixPreservingVisitor),- walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixChangingVisitor),- walkInOptimizedOrder(RealMatrixPreservingVisitor),- walkInOptimizedOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixPreservingVisitor, int, int, int, int)
 
 - 
walkInColumnOrderdouble walkInColumnOrder(RealMatrixChangingVisitor visitor) 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 RealMatrixChangingVisitor.end()at the end of the walk
- See Also:
- walkInRowOrder(RealMatrixChangingVisitor),- walkInRowOrder(RealMatrixPreservingVisitor),- walkInRowOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInRowOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixPreservingVisitor),- walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixChangingVisitor),- walkInOptimizedOrder(RealMatrixPreservingVisitor),- walkInOptimizedOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixPreservingVisitor, int, int, int, int)
 
 - 
walkInColumnOrderdouble walkInColumnOrder(RealMatrixPreservingVisitor visitor) 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 RealMatrixPreservingVisitor.end()at the end of the walk
- See Also:
- walkInRowOrder(RealMatrixChangingVisitor),- walkInRowOrder(RealMatrixPreservingVisitor),- walkInRowOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInRowOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixChangingVisitor),- walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixChangingVisitor),- walkInOptimizedOrder(RealMatrixPreservingVisitor),- walkInOptimizedOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixPreservingVisitor, int, int, int, int)
 
 - 
walkInColumnOrderdouble walkInColumnOrder(RealMatrixChangingVisitor visitor, int startRow, int endRow, int startColumn, int endColumn) throws OutOfRangeException, NumberIsTooSmallException 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 entries
- startRow- Initial row index
- endRow- Final row index (inclusive)
- startColumn- Initial column index
- endColumn- Final column index
- Returns:
- the value returned by RealMatrixChangingVisitor.end()at the end of the walk
- Throws:
- OutOfRangeException- if the indices are not valid.
- NumberIsTooSmallException- if- endRow < startRowor- endColumn < startColumn.
- See Also:
- walkInRowOrder(RealMatrixChangingVisitor),- walkInRowOrder(RealMatrixPreservingVisitor),- walkInRowOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInRowOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixChangingVisitor),- walkInColumnOrder(RealMatrixPreservingVisitor),- walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixChangingVisitor),- walkInOptimizedOrder(RealMatrixPreservingVisitor),- walkInOptimizedOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixPreservingVisitor, int, int, int, int)
 
 - 
walkInColumnOrderdouble walkInColumnOrder(RealMatrixPreservingVisitor visitor, int startRow, int endRow, int startColumn, int endColumn) throws OutOfRangeException, NumberIsTooSmallException 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 entries
- startRow- Initial row index
- endRow- Final row index (inclusive)
- startColumn- Initial column index
- endColumn- Final column index
- Returns:
- the value returned by RealMatrixPreservingVisitor.end()at the end of the walk
- Throws:
- OutOfRangeException- if the indices are not valid.
- NumberIsTooSmallException- if- endRow < startRowor- endColumn < startColumn.
- See Also:
- walkInRowOrder(RealMatrixChangingVisitor),- walkInRowOrder(RealMatrixPreservingVisitor),- walkInRowOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInRowOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixChangingVisitor),- walkInColumnOrder(RealMatrixPreservingVisitor),- walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixChangingVisitor),- walkInOptimizedOrder(RealMatrixPreservingVisitor),- walkInOptimizedOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixPreservingVisitor, int, int, int, int)
 
 - 
walkInOptimizedOrderdouble walkInOptimizedOrder(RealMatrixChangingVisitor visitor) 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 RealMatrixChangingVisitor.end()at the end of the walk
- See Also:
- walkInRowOrder(RealMatrixChangingVisitor),- walkInRowOrder(RealMatrixPreservingVisitor),- walkInRowOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInRowOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixChangingVisitor),- walkInColumnOrder(RealMatrixPreservingVisitor),- walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixPreservingVisitor),- walkInOptimizedOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixPreservingVisitor, int, int, int, int)
 
 - 
walkInOptimizedOrderdouble walkInOptimizedOrder(RealMatrixPreservingVisitor visitor) 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 RealMatrixPreservingVisitor.end()at the end of the walk
- See Also:
- walkInRowOrder(RealMatrixChangingVisitor),- walkInRowOrder(RealMatrixPreservingVisitor),- walkInRowOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInRowOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixChangingVisitor),- walkInColumnOrder(RealMatrixPreservingVisitor),- walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixChangingVisitor),- walkInOptimizedOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixPreservingVisitor, int, int, int, int)
 
 - 
walkInOptimizedOrderdouble walkInOptimizedOrder(RealMatrixChangingVisitor visitor, int startRow, int endRow, int startColumn, int endColumn) throws OutOfRangeException, NumberIsTooSmallException 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 entries
- startRow- Initial row index
- endRow- Final row index (inclusive)
- startColumn- Initial column index
- endColumn- Final column index (inclusive)
- Returns:
- the value returned by RealMatrixChangingVisitor.end()at the end of the walk
- Throws:
- OutOfRangeException- if the indices are not valid.
- NumberIsTooSmallException- if- endRow < startRowor- endColumn < startColumn.
- See Also:
- walkInRowOrder(RealMatrixChangingVisitor),- walkInRowOrder(RealMatrixPreservingVisitor),- walkInRowOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInRowOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixChangingVisitor),- walkInColumnOrder(RealMatrixPreservingVisitor),- walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixChangingVisitor),- walkInOptimizedOrder(RealMatrixPreservingVisitor),- walkInOptimizedOrder(RealMatrixPreservingVisitor, int, int, int, int)
 
 - 
walkInOptimizedOrderdouble walkInOptimizedOrder(RealMatrixPreservingVisitor visitor, int startRow, int endRow, int startColumn, int endColumn) throws OutOfRangeException, NumberIsTooSmallException 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 entries
- startRow- Initial row index
- endRow- Final row index (inclusive)
- startColumn- Initial column index
- endColumn- Final column index (inclusive)
- Returns:
- the value returned by RealMatrixPreservingVisitor.end()at the end of the walk
- Throws:
- OutOfRangeException- if the indices are not valid.
- NumberIsTooSmallException- if- endRow < startRowor- endColumn < startColumn.
- See Also:
- walkInRowOrder(RealMatrixChangingVisitor),- walkInRowOrder(RealMatrixPreservingVisitor),- walkInRowOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInRowOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixChangingVisitor),- walkInColumnOrder(RealMatrixPreservingVisitor),- walkInColumnOrder(RealMatrixChangingVisitor, int, int, int, int),- walkInColumnOrder(RealMatrixPreservingVisitor, int, int, int, int),- walkInOptimizedOrder(RealMatrixChangingVisitor),- walkInOptimizedOrder(RealMatrixPreservingVisitor),- walkInOptimizedOrder(RealMatrixChangingVisitor, int, int, int, int)
 
 
- 
 
-