[MATH-862] Correct fix for matrix dimension check in copySubMatrix.
git-svn-id: https://svn.apache.org/repos/asf/commons/proper/math/trunk@1459534 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
9c90639c10
commit
bd95671403
|
@ -353,6 +353,13 @@ public abstract class AbstractRealMatrix
|
|||
rowsCount, columnsCount);
|
||||
}
|
||||
|
||||
for (int i = 1; i < rowsCount; i++) {
|
||||
if (destination[i].length < columnsCount) {
|
||||
throw new MatrixDimensionMismatchException(destination.length, destination[i].length,
|
||||
rowsCount, columnsCount);
|
||||
}
|
||||
}
|
||||
|
||||
walkInOptimizedOrder(new DefaultRealMatrixPreservingVisitor() {
|
||||
|
||||
/** Initial row index. */
|
||||
|
@ -385,14 +392,19 @@ public abstract class AbstractRealMatrix
|
|||
throws OutOfRangeException, NullArgumentException, NoDataException,
|
||||
MatrixDimensionMismatchException {
|
||||
MatrixUtils.checkSubMatrixIndex(this, selectedRows, selectedColumns);
|
||||
final int nCols = selectedColumns.length;
|
||||
if ((destination.length < selectedRows.length) ||
|
||||
(destination[0].length < selectedColumns.length)) {
|
||||
(destination[0].length < nCols)) {
|
||||
throw new MatrixDimensionMismatchException(destination.length, destination[0].length,
|
||||
selectedRows.length, selectedColumns.length);
|
||||
}
|
||||
|
||||
for (int i = 0; i < selectedRows.length; i++) {
|
||||
final double[] destinationI = destination[i];
|
||||
if (destinationI.length < nCols) {
|
||||
throw new MatrixDimensionMismatchException(destination.length, destinationI.length,
|
||||
selectedRows.length, selectedColumns.length);
|
||||
}
|
||||
for (int j = 0; j < selectedColumns.length; j++) {
|
||||
destinationI[j] = getEntry(selectedRows[i], selectedColumns[j]);
|
||||
}
|
||||
|
|
|
@ -537,6 +537,11 @@ public final class Array2DRowRealMatrixTest {
|
|||
checkCopy(m, null, 1, 0, 2, 4, true);
|
||||
checkCopy(m, null, new int[] {}, new int[] { 0 }, true);
|
||||
checkCopy(m, null, new int[] { 0 }, new int[] { 4 }, true);
|
||||
|
||||
// rectangular check
|
||||
double[][] copy = new double[][] { { 0, 0, 0 }, { 0, 0 } };
|
||||
checkCopy(m, copy, 0, 1, 0, 2, true);
|
||||
checkCopy(m, copy, new int[] { 0, 1 }, new int[] { 0, 1, 2 }, true);
|
||||
}
|
||||
|
||||
private void checkCopy(RealMatrix m, double[][] reference,
|
||||
|
|
Loading…
Reference in New Issue