[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);
|
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() {
|
walkInOptimizedOrder(new DefaultRealMatrixPreservingVisitor() {
|
||||||
|
|
||||||
/** Initial row index. */
|
/** Initial row index. */
|
||||||
|
@ -385,14 +392,19 @@ public abstract class AbstractRealMatrix
|
||||||
throws OutOfRangeException, NullArgumentException, NoDataException,
|
throws OutOfRangeException, NullArgumentException, NoDataException,
|
||||||
MatrixDimensionMismatchException {
|
MatrixDimensionMismatchException {
|
||||||
MatrixUtils.checkSubMatrixIndex(this, selectedRows, selectedColumns);
|
MatrixUtils.checkSubMatrixIndex(this, selectedRows, selectedColumns);
|
||||||
|
final int nCols = selectedColumns.length;
|
||||||
if ((destination.length < selectedRows.length) ||
|
if ((destination.length < selectedRows.length) ||
|
||||||
(destination[0].length < selectedColumns.length)) {
|
(destination[0].length < nCols)) {
|
||||||
throw new MatrixDimensionMismatchException(destination.length, destination[0].length,
|
throw new MatrixDimensionMismatchException(destination.length, destination[0].length,
|
||||||
selectedRows.length, selectedColumns.length);
|
selectedRows.length, selectedColumns.length);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < selectedRows.length; i++) {
|
for (int i = 0; i < selectedRows.length; i++) {
|
||||||
final double[] destinationI = destination[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++) {
|
for (int j = 0; j < selectedColumns.length; j++) {
|
||||||
destinationI[j] = getEntry(selectedRows[i], selectedColumns[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, 1, 0, 2, 4, true);
|
||||||
checkCopy(m, null, new int[] {}, new int[] { 0 }, true);
|
checkCopy(m, null, new int[] {}, new int[] { 0 }, true);
|
||||||
checkCopy(m, null, new int[] { 0 }, new int[] { 4 }, 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,
|
private void checkCopy(RealMatrix m, double[][] reference,
|
||||||
|
|
Loading…
Reference in New Issue