Changed matrix indexing to be 0-based.

git-svn-id: https://svn.apache.org/repos/asf/jakarta/commons/proper/math/trunk@141442 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Phil Steitz 2004-09-05 01:19:23 +00:00
parent b1b111d8bd
commit 1f0fde531a
6 changed files with 137 additions and 121 deletions

View File

@ -21,8 +21,11 @@ import java.math.BigDecimal;
/** /**
* Interface defining a real-valued matrix with basic algebraic operations, using * Interface defining a real-valued matrix with basic algebraic operations, using
* BigDecimal representations for the entries. * BigDecimal representations for the entries.
* <p>
* Matrix element indexing is 0-based -- e.g., <code>getEntry(0, 0)</code>
* returns the element in the first row, first column of the matrix.
* *
* @version $Revision: 1.6 $ $Date: 2004/09/01 21:26:11 $ * @version $Revision: 1.7 $ $Date: 2004/09/05 01:19:23 $
*/ */
public interface BigMatrix { public interface BigMatrix {
@ -151,8 +154,8 @@ public interface BigMatrix {
/** /**
* Returns the entries in row number <code>row</code> as an array. * Returns the entries in row number <code>row</code> as an array.
* <p> * <p>
* Row indices start at 1. A <code>MatrixIndexException</code> is thrown * Row indices start at 0. A <code>MatrixIndexException</code> is thrown
* unless <code>0 < row <= rowDimension.</code> * unless <code>0 <= row < rowDimension.</code>
* *
* @param row the row to be fetched * @param row the row to be fetched
* @return array of entries in the row * @return array of entries in the row
@ -164,8 +167,8 @@ public interface BigMatrix {
* Returns the entries in row number <code>row</code> as an array * Returns the entries in row number <code>row</code> as an array
* of double values. * of double values.
* <p> * <p>
* Row indices start at 1. A <code>MatrixIndexException</code> is thrown * Row indices start at 0. A <code>MatrixIndexException</code> is thrown
* unless <code>0 < row <= rowDimension.</code> * unless <code>0 <= row < rowDimension.</code>
* *
* @param row the row to be fetched * @param row the row to be fetched
* @return array of entries in the row * @return array of entries in the row
@ -176,8 +179,8 @@ public interface BigMatrix {
/** /**
* Returns the entries in column number <code>col</code> as an array. * Returns the entries in column number <code>col</code> as an array.
* <p> * <p>
* Column indices start at 1. A <code>MatrixIndexException</code> is thrown * Column indices start at 0. A <code>MatrixIndexException</code> is thrown
* unless <code>0 < column <= columnDimension.</code> * unless <code>0 <= column < columnDimension.</code>
* *
* @param col the column to be fetched * @param col the column to be fetched
* @return array of entries in the column * @return array of entries in the column
@ -189,8 +192,8 @@ public interface BigMatrix {
* Returns the entries in column number <code>col</code> as an array * Returns the entries in column number <code>col</code> as an array
* of double values. * of double values.
* <p> * <p>
* Column indices start at 1. A <code>MatrixIndexException</code> is thrown * Column indices start at 0. A <code>MatrixIndexException</code> is thrown
* unless <code>0 < column <= columnDimension.</code> * unless <code>0 <= column < columnDimension.</code>
* *
* @param col the column to be fetched * @param col the column to be fetched
* @return array of entries in the column * @return array of entries in the column
@ -201,10 +204,10 @@ public interface BigMatrix {
/** /**
* Returns the entry in the specified row and column. * Returns the entry in the specified row and column.
* <p> * <p>
* Row and column indices start at 1 and must satisfy * Row and column indices start at 0 and must satisfy
* <ul> * <ul>
* <li><code>0 < row <= rowDimension</code></li> * <li><code>0 <= row < rowDimension</code></li>
* <li><code> 0 < column <= columnDimension</code></li> * <li><code> 0 <= column < columnDimension</code></li>
* </ul> * </ul>
* otherwise a <code>MatrixIndexException</code> is thrown. * otherwise a <code>MatrixIndexException</code> is thrown.
* *
@ -218,10 +221,10 @@ public interface BigMatrix {
/** /**
* Returns the entry in the specified row and column as a double. * Returns the entry in the specified row and column as a double.
* <p> * <p>
* Row and column indices start at 1 and must satisfy * Row and column indices start at 0 and must satisfy
* <ul> * <ul>
* <li><code>0 < row <= rowDimension</code></li> * <li><code>0 <= row < rowDimension</code></li>
* <li><code> 0 < column <= columnDimension</code></li> * <li><code> 0 <= column < columnDimension</code></li>
* </ul> * </ul>
* otherwise a <code>MatrixIndexException</code> is thrown. * otherwise a <code>MatrixIndexException</code> is thrown.
* *
@ -235,10 +238,10 @@ public interface BigMatrix {
/** /**
* Sets the entry in the specified row and column to the specified value. * Sets the entry in the specified row and column to the specified value.
* <p> * <p>
* Row and column indices start at 1 and must satisfy * Row and column indices start at 0 and must satisfy
* <ul> * <ul>
* <li><code>0 < row <= rowDimension</code></li> * <li><code>0 <= row < rowDimension</code></li>
* <li><code> 0 < column <= columnDimension</code></li> * <li><code> 0 <= column < columnDimension</code></li>
* </ul> * </ul>
* otherwise a <code>MatrixIndexException</code> is thrown. * otherwise a <code>MatrixIndexException</code> is thrown.
* *
@ -254,10 +257,10 @@ public interface BigMatrix {
/** /**
* Sets the entry in the specified row and column to the specified value. * Sets the entry in the specified row and column to the specified value.
* <p> * <p>
* Row and column indices start at 1 and must satisfy * Row and column indices start at 0 and must satisfy
* <ul> * <ul>
* <li><code>0 < row <= rowDimension</code></li> * <li><code>0 <= row < rowDimension</code></li>
* <li><code> 0 < column <= columnDimension</code></li> * <li><code> 0 <= column < columnDimension</code></li>
* </ul> * </ul>
* otherwise a <code>MatrixIndexException</code> is thrown. * otherwise a <code>MatrixIndexException</code> is thrown.
* *
@ -274,10 +277,10 @@ public interface BigMatrix {
* Sets the entry in the specified row and column to the * Sets the entry in the specified row and column to the
* <code>BigDecimal</code> value represented by the input string. * <code>BigDecimal</code> value represented by the input string.
* <p> * <p>
* Row and column indices start at 1 and must satisfy * Row and column indices start at 0 and must satisfy
* <ul> * <ul>
* <li><code>0 < row <= rowDimension</code></li> * <li><code>0 <= row < rowDimension</code></li>
* <li><code> 0 < column <= columnDimension</code></li> * <li><code> 0 <= column < columnDimension</code></li>
* </ul> * </ul>
* otherwise a <code>MatrixIndexException</code> is thrown. * otherwise a <code>MatrixIndexException</code> is thrown.
* *

View File

@ -30,16 +30,20 @@ import java.math.BigDecimal;
* <li>getDeterminant</li> * <li>getDeterminant</li>
* <li>inverse</li> </ul> * <li>inverse</li> </ul>
* <p> * <p>
* <strong>Usage note</strong>:<br> * <strong>Usage notes</strong>:<br>
* <ul><li>
* The LU decomposition is stored and reused on subsequent calls. If matrix * The LU decomposition is stored and reused on subsequent calls. If matrix
* data are modified using any of the public setXxx methods, the saved * data are modified using any of the public setXxx methods, the saved
* decomposition is discarded. If data are modified via references to the * decomposition is discarded. If data are modified via references to the
* underlying array obtained using <code>getDataRef()</code>, then the stored * underlying array obtained using <code>getDataRef()</code>, then the stored
* LU decomposition will not be discarded. In this case, you need to * LU decomposition will not be discarded. In this case, you need to
* explicitly invoke <code>LUDecompose()</code> to recompute the decomposition * explicitly invoke <code>LUDecompose()</code> to recompute the decomposition
* before using any of the methods above. * before using any of the methods above.</li>
* * <li>
* @version $Revision: 1.5 $ $Date: 2004/09/01 21:26:11 $ * As specified in the {@link BigMatrix} interface, matrix element indexing
* is 0-based -- e.g., <code>getEntry(0, 0)</code>
* returns the element in the first row, first column of the matrix.</li></ul>
* @version $Revision: 1.6 $ $Date: 2004/09/05 01:19:23 $
*/ */
public class BigMatrixImpl implements BigMatrix, Serializable { public class BigMatrixImpl implements BigMatrix, Serializable {
@ -428,20 +432,20 @@ public class BigMatrixImpl implements BigMatrix, Serializable {
/** /**
* Returns the entries in row number <code>row</code> as an array. * Returns the entries in row number <code>row</code> as an array.
* <p> * <p>
* Row indices start at 1. A <code>MatrixIndexException</code> is thrown * Row indices start at 0. A <code>MatrixIndexException</code> is thrown
* unless <code>0 < row <= rowDimension.</code> * unless <code>0 <= row < rowDimension.</code>
* *
* @param row the row to be fetched * @param row the row to be fetched
* @return array of entries in the row * @return array of entries in the row
* @throws MatrixIndexException if the specified row index is not valid * @throws MatrixIndexException if the specified row index is not valid
*/ */
public BigDecimal[] getRow(int row) throws MatrixIndexException { public BigDecimal[] getRow(int row) throws MatrixIndexException {
if ( !isValidCoordinate( row, 1 ) ) { if ( !isValidCoordinate( row, 0 ) ) {
throw new MatrixIndexException("illegal row argument"); throw new MatrixIndexException("illegal row argument");
} }
int ncols = this.getColumnDimension(); int ncols = this.getColumnDimension();
BigDecimal[] out = new BigDecimal[ncols]; BigDecimal[] out = new BigDecimal[ncols];
System.arraycopy(data[row - 1], 0, out, 0, ncols); System.arraycopy(data[row], 0, out, 0, ncols);
return out; return out;
} }
@ -449,21 +453,21 @@ public class BigMatrixImpl implements BigMatrix, Serializable {
* Returns the entries in row number <code>row</code> as an array * Returns the entries in row number <code>row</code> as an array
* of double values. * of double values.
* <p> * <p>
* Row indices start at 1. A <code>MatrixIndexException</code> is thrown * Row indices start at 0. A <code>MatrixIndexException</code> is thrown
* unless <code>0 < row <= rowDimension.</code> * unless <code>0 <= row < rowDimension.</code>
* *
* @param row the row to be fetched * @param row the row to be fetched
* @return array of entries in the row * @return array of entries in the row
* @throws MatrixIndexException if the specified row index is not valid * @throws MatrixIndexException if the specified row index is not valid
*/ */
public double[] getRowAsDoubleArray(int row) throws MatrixIndexException { public double[] getRowAsDoubleArray(int row) throws MatrixIndexException {
if ( !isValidCoordinate( row, 1 ) ) { if ( !isValidCoordinate( row, 0 ) ) {
throw new MatrixIndexException("illegal row argument"); throw new MatrixIndexException("illegal row argument");
} }
int ncols = this.getColumnDimension(); int ncols = this.getColumnDimension();
double[] out = new double[ncols]; double[] out = new double[ncols];
for (int i=0;i<ncols;i++) { for (int i=0;i<ncols;i++) {
out[i] = data[row-1][i].doubleValue(); out[i] = data[row][i].doubleValue();
} }
return out; return out;
} }
@ -471,21 +475,21 @@ public class BigMatrixImpl implements BigMatrix, Serializable {
/** /**
* Returns the entries in column number <code>col</code> as an array. * Returns the entries in column number <code>col</code> as an array.
* <p> * <p>
* Column indices start at 1. A <code>MatrixIndexException</code> is thrown * Column indices start at 0. A <code>MatrixIndexException</code> is thrown
* unless <code>0 < column <= columnDimension.</code> * unless <code>0 <= column < columnDimension.</code>
* *
* @param col the column to be fetched * @param col the column to be fetched
* @return array of entries in the column * @return array of entries in the column
* @throws MatrixIndexException if the specified column index is not valid * @throws MatrixIndexException if the specified column index is not valid
*/ */
public BigDecimal[] getColumn(int col) throws MatrixIndexException { public BigDecimal[] getColumn(int col) throws MatrixIndexException {
if ( !isValidCoordinate(1, col) ) { if ( !isValidCoordinate(0, col) ) {
throw new MatrixIndexException("illegal column argument"); throw new MatrixIndexException("illegal column argument");
} }
int nRows = this.getRowDimension(); int nRows = this.getRowDimension();
BigDecimal[] out = new BigDecimal[nRows]; BigDecimal[] out = new BigDecimal[nRows];
for (int i = 0; i < nRows; i++) { for (int i = 0; i < nRows; i++) {
out[i] = data[i][col - 1]; out[i] = data[i][col];
} }
return out; return out;
} }
@ -494,21 +498,21 @@ public class BigMatrixImpl implements BigMatrix, Serializable {
* Returns the entries in column number <code>col</code> as an array * Returns the entries in column number <code>col</code> as an array
* of double values. * of double values.
* <p> * <p>
* Column indices start at 1. A <code>MatrixIndexException</code> is thrown * Column indices start at 0. A <code>MatrixIndexException</code> is thrown
* unless <code>0 < column <= columnDimension.</code> * unless <code>0 <= column < columnDimension.</code>
* *
* @param col the column to be fetched * @param col the column to be fetched
* @return array of entries in the column * @return array of entries in the column
* @throws MatrixIndexException if the specified column index is not valid * @throws MatrixIndexException if the specified column index is not valid
*/ */
public double[] getColumnAsDoubleArray(int col) throws MatrixIndexException { public double[] getColumnAsDoubleArray(int col) throws MatrixIndexException {
if ( !isValidCoordinate( 1, col ) ) { if ( !isValidCoordinate( 0, col ) ) {
throw new MatrixIndexException("illegal column argument"); throw new MatrixIndexException("illegal column argument");
} }
int nrows = this.getRowDimension(); int nrows = this.getRowDimension();
double[] out = new double[nrows]; double[] out = new double[nrows];
for (int i=0;i<nrows;i++) { for (int i=0;i<nrows;i++) {
out[i] = data[i][col-1].doubleValue(); out[i] = data[i][col].doubleValue();
} }
return out; return out;
} }
@ -516,10 +520,10 @@ public class BigMatrixImpl implements BigMatrix, Serializable {
/** /**
* Returns the entry in the specified row and column. * Returns the entry in the specified row and column.
* <p> * <p>
* Row and column indices start at 1 and must satisfy * Row and column indices start at 0 and must satisfy
* <ul> * <ul>
* <li><code>0 < row <= rowDimension</code></li> * <li><code>0 <= row < rowDimension</code></li>
* <li><code> 0 < column <= columnDimension</code></li> * <li><code> 0 <= column < columnDimension</code></li>
* </ul> * </ul>
* otherwise a <code>MatrixIndexException</code> is thrown. * otherwise a <code>MatrixIndexException</code> is thrown.
* *
@ -533,16 +537,16 @@ public class BigMatrixImpl implements BigMatrix, Serializable {
if (!isValidCoordinate(row,column)) { if (!isValidCoordinate(row,column)) {
throw new MatrixIndexException("matrix entry does not exist"); throw new MatrixIndexException("matrix entry does not exist");
} }
return data[row - 1][column - 1]; return data[row][column];
} }
/** /**
* Returns the entry in the specified row and column as a double. * Returns the entry in the specified row and column as a double.
* <p> * <p>
* Row and column indices start at 1 and must satisfy * Row and column indices start at 0 and must satisfy
* <ul> * <ul>
* <li><code>0 < row <= rowDimension</code></li> * <li><code>0 <= row < rowDimension</code></li>
* <li><code> 0 < column <= columnDimension</code></li> * <li><code> 0 <= column < columnDimension</code></li>
* </ul> * </ul>
* otherwise a <code>MatrixIndexException</code> is thrown. * otherwise a <code>MatrixIndexException</code> is thrown.
* *
@ -559,10 +563,10 @@ public class BigMatrixImpl implements BigMatrix, Serializable {
/** /**
* Sets the entry in the specified row and column to the specified value. * Sets the entry in the specified row and column to the specified value.
* <p> * <p>
* Row and column indices start at 1 and must satisfy * Row and column indices start at 0 and must satisfy
* <ul> * <ul>
* <li><code>0 < row <= rowDimension</code></li> * <li><code>0 <= row < rowDimension</code></li>
* <li><code> 0 < column <= columnDimension</code></li> * <li><code> 0 <= column < columnDimension</code></li>
* </ul> * </ul>
* otherwise a <code>MatrixIndexException</code> is thrown. * otherwise a <code>MatrixIndexException</code> is thrown.
* *
@ -576,17 +580,17 @@ public class BigMatrixImpl implements BigMatrix, Serializable {
if (!isValidCoordinate(row,column)) { if (!isValidCoordinate(row,column)) {
throw new MatrixIndexException("matrix entry does not exist"); throw new MatrixIndexException("matrix entry does not exist");
} }
data[row - 1][column - 1] = value; data[row][column] = value;
lu = null; lu = null;
} }
/** /**
* Sets the entry in the specified row and column to the specified value. * Sets the entry in the specified row and column to the specified value.
* <p> * <p>
* Row and column indices start at 1 and must satisfy * Row and column indices start at 0 and must satisfy
* <ul> * <ul>
* <li><code>0 < row <= rowDimension</code></li> * <li><code>0 <= row < rowDimension</code></li>
* <li><code> 0 < column <= columnDimension</code></li> * <li><code> 0 <= column < columnDimension</code></li>
* </ul> * </ul>
* otherwise a <code>MatrixIndexException</code> is thrown. * otherwise a <code>MatrixIndexException</code> is thrown.
* *
@ -603,10 +607,10 @@ public class BigMatrixImpl implements BigMatrix, Serializable {
* Sets the entry in the specified row and column to the * Sets the entry in the specified row and column to the
* <code>BigDecimal</code> value represented by the input string. * <code>BigDecimal</code> value represented by the input string.
* <p> * <p>
* Row and column indices start at 1 and must satisfy * Row and column indices start at 0 and must satisfy
* <ul> * <ul>
* <li><code>0 < row <= rowDimension</code></li> * <li><code>0 <= row < rowDimension</code></li>
* <li><code> 0 < column <= columnDimension</code></li> * <li><code> 0 <= column < columnDimension</code></li>
* </ul> * </ul>
* otherwise a <code>MatrixIndexException</code> is thrown. * otherwise a <code>MatrixIndexException</code> is thrown.
* *
@ -1166,7 +1170,7 @@ public class BigMatrixImpl implements BigMatrix, Serializable {
int nRows = this.getRowDimension(); int nRows = this.getRowDimension();
int nCols = this.getColumnDimension(); int nCols = this.getColumnDimension();
return !(row < 1 || row > nRows || col < 1 || col > nCols); return !(row < 0 || row >= nRows || col < 0 || col >= nCols);
} }
} }

View File

@ -17,8 +17,12 @@
package org.apache.commons.math.linear; package org.apache.commons.math.linear;
/** /**
* Interface defining a real-valued matrix with basic algebraic operations * Interface defining a real-valued matrix with basic algebraic operations.
* @version $Revision: 1.21 $ $Date: 2004/09/01 21:26:11 $ * <p>
* Matrix element indexing is 0-based -- e.g., <code>getEntry(0, 0)</code>
* returns the element in the first row, first column of the matrix.
*
* @version $Revision: 1.22 $ $Date: 2004/09/05 01:19:23 $
*/ */
public interface RealMatrix { public interface RealMatrix {
@ -108,8 +112,8 @@ public interface RealMatrix {
/** /**
* Returns the entries in row number <code>row</code> as an array. * Returns the entries in row number <code>row</code> as an array.
* <p> * <p>
* Row indices start at 1. A <code>MatrixIndexException</code> is thrown * Row indices start at 0. A <code>MatrixIndexException</code> is thrown
* unless <code>0 < row <= rowDimension.</code> * unless <code>0 <= row < rowDimension.</code>
* *
* @param row the row to be fetched * @param row the row to be fetched
* @return array of entries in the row * @return array of entries in the row
@ -120,8 +124,8 @@ public interface RealMatrix {
/** /**
* Returns the entries in column number <code>col</code> as an array. * Returns the entries in column number <code>col</code> as an array.
* <p> * <p>
* Column indices start at 1. A <code>MatrixIndexException</code> is thrown * Column indices start at 0. A <code>MatrixIndexException</code> is thrown
* unless <code>0 < column <= columnDimension.</code> * unless <code>0 <= column < columnDimension.</code>
* *
* @param col the column to be fetched * @param col the column to be fetched
* @return array of entries in the column * @return array of entries in the column
@ -132,10 +136,10 @@ public interface RealMatrix {
/** /**
* Returns the entry in the specified row and column. * Returns the entry in the specified row and column.
* <p> * <p>
* Row and column indices start at 1 and must satisfy * Row and column indices start at 0 and must satisfy
* <ul> * <ul>
* <li><code>0 < row <= rowDimension</code></li> * <li><code>0 <= row < rowDimension</code></li>
* <li><code> 0 < column <= columnDimension</code></li> * <li><code> 0 <= column < columnDimension</code></li>
* </ul> * </ul>
* otherwise a <code>MatrixIndexException</code> is thrown. * otherwise a <code>MatrixIndexException</code> is thrown.
* *
@ -149,10 +153,10 @@ public interface RealMatrix {
/** /**
* Sets the entry in the specified row and column to the specified value. * Sets the entry in the specified row and column to the specified value.
* <p> * <p>
* Row and column indices start at 1 and must satisfy * Row and column indices start at 0 and must satisfy
* <ul> * <ul>
* <li><code>0 < row <= rowDimension</code></li> * <li><code>0 <= row < rowDimension</code></li>
* <li><code> 0 < column <= columnDimension</code></li> * <li><code> 0 <= column < columnDimension</code></li>
* </ul> * </ul>
* otherwise a <code>MatrixIndexException</code> is thrown. * otherwise a <code>MatrixIndexException</code> is thrown.
* *

View File

@ -29,16 +29,21 @@ import java.io.Serializable;
* <li>getDeterminant</li> * <li>getDeterminant</li>
* <li>inverse</li> </ul> * <li>inverse</li> </ul>
* <p> * <p>
* <strong>Usage note</strong>:<br> * <strong>Usage notes</strong>:<br>
* <ul><li>
* The LU decomposition is stored and reused on subsequent calls. If matrix * The LU decomposition is stored and reused on subsequent calls. If matrix
* data are modified using any of the public setXxx methods, the saved * data are modified using any of the public setXxx methods, the saved
* decomposition is discarded. If data are modified via references to the * decomposition is discarded. If data are modified via references to the
* underlying array obtained using <code>getDataRef()</code>, then the stored * underlying array obtained using <code>getDataRef()</code>, then the stored
* LU decomposition will not be discarded. In this case, you need to * LU decomposition will not be discarded. In this case, you need to
* explicitly invoke <code>LUDecompose()</code> to recompute the decomposition * explicitly invoke <code>LUDecompose()</code> to recompute the decomposition
* before using any of the methods above. * before using any of the methods above.</li>
* <li>
* As specified in the {@link RealMatrix} interface, matrix element indexing
* is 0-based -- e.g., <code>getEntry(0, 0)</code>
* returns the element in the first row, first column of the matrix.</li></ul>
* *
* @version $Revision: 1.27 $ $Date: 2004/09/01 21:26:11 $ * @version $Revision: 1.28 $ $Date: 2004/09/05 01:19:23 $
*/ */
public class RealMatrixImpl implements RealMatrix, Serializable { public class RealMatrixImpl implements RealMatrix, Serializable {
@ -306,41 +311,41 @@ public class RealMatrixImpl implements RealMatrix, Serializable {
/** /**
* Returns the entries in row number <code>row</code> as an array. * Returns the entries in row number <code>row</code> as an array.
* <p> * <p>
* Row indices start at 1. A <code>MatrixIndexException</code> is thrown * Row indices start at 0. A <code>MatrixIndexException</code> is thrown
* unless <code>0 < row <= rowDimension.</code> * unless <code>0 <= row < rowDimension.</code>
* *
* @param row the row to be fetched * @param row the row to be fetched
* @return array of entries in the row * @return array of entries in the row
* @throws MatrixIndexException if the specified row index is not valid * @throws MatrixIndexException if the specified row index is not valid
*/ */
public double[] getRow(int row) throws MatrixIndexException { public double[] getRow(int row) throws MatrixIndexException {
if ( !isValidCoordinate( row, 1 ) ) { if ( !isValidCoordinate( row, 0 ) ) {
throw new MatrixIndexException("illegal row argument"); throw new MatrixIndexException("illegal row argument");
} }
int ncols = this.getColumnDimension(); int ncols = this.getColumnDimension();
double[] out = new double[ncols]; double[] out = new double[ncols];
System.arraycopy(data[row - 1], 0, out, 0, ncols); System.arraycopy(data[row], 0, out, 0, ncols);
return out; return out;
} }
/** /**
* Returns the entries in column number <code>col</code> as an array. * Returns the entries in column number <code>col</code> as an array.
* <p> * <p>
* Column indices start at 1. A <code>MatrixIndexException</code> is thrown * Column indices start at 0. A <code>MatrixIndexException</code> is thrown
* unless <code>0 < column <= columnDimension.</code> * unless <code>0 <= column < columnDimension.</code>
* *
* @param col the column to be fetched * @param col the column to be fetched
* @return array of entries in the column * @return array of entries in the column
* @throws MatrixIndexException if the specified column index is not valid * @throws MatrixIndexException if the specified column index is not valid
*/ */
public double[] getColumn(int col) throws MatrixIndexException { public double[] getColumn(int col) throws MatrixIndexException {
if ( !isValidCoordinate(1, col) ) { if ( !isValidCoordinate(0, col) ) {
throw new MatrixIndexException("illegal column argument"); throw new MatrixIndexException("illegal column argument");
} }
int nRows = this.getRowDimension(); int nRows = this.getRowDimension();
double[] out = new double[nRows]; double[] out = new double[nRows];
for (int row = 0; row < nRows; row++) { for (int row = 0; row < nRows; row++) {
out[row] = data[row][col - 1]; out[row] = data[row][col];
} }
return out; return out;
} }
@ -348,10 +353,10 @@ public class RealMatrixImpl implements RealMatrix, Serializable {
/** /**
* Returns the entry in the specified row and column. * Returns the entry in the specified row and column.
* <p> * <p>
* Row and column indices start at 1 and must satisfy * Row and column indices start at 0 and must satisfy
* <ul> * <ul>
* <li><code>0 < row <= rowDimension</code></li> * <li><code>0 <= row < rowDimension</code></li>
* <li><code> 0 < column <= columnDimension</code></li> * <li><code> 0 <= column < columnDimension</code></li>
* </ul> * </ul>
* otherwise a <code>MatrixIndexException</code> is thrown. * otherwise a <code>MatrixIndexException</code> is thrown.
* *
@ -365,16 +370,16 @@ public class RealMatrixImpl implements RealMatrix, Serializable {
if (!isValidCoordinate(row,column)) { if (!isValidCoordinate(row,column)) {
throw new MatrixIndexException("matrix entry does not exist"); throw new MatrixIndexException("matrix entry does not exist");
} }
return data[row - 1][column - 1]; return data[row][column];
} }
/** /**
* Sets the entry in the specified row and column to the specified value. * Sets the entry in the specified row and column to the specified value.
* <p> * <p>
* Row and column indices start at 1 and must satisfy * Row and column indices start at 0 and must satisfy
* <ul> * <ul>
* <li><code>0 < row <= rowDimension</code></li> * <li><code>0 <= row < rowDimension</code></li>
* <li><code> 0 < column <= columnDimension</code></li> * <li><code> 0 <= column < columnDimension</code></li>
* </ul> * </ul>
* otherwise a <code>MatrixIndexException</code> is thrown. * otherwise a <code>MatrixIndexException</code> is thrown.
* *
@ -388,7 +393,7 @@ public class RealMatrixImpl implements RealMatrix, Serializable {
if (!isValidCoordinate(row,column)) { if (!isValidCoordinate(row,column)) {
throw new MatrixIndexException("matrix entry does not exist"); throw new MatrixIndexException("matrix entry does not exist");
} }
data[row - 1][column - 1] = value; data[row][column] = value;
lu = null; lu = null;
} }
@ -850,7 +855,7 @@ public class RealMatrixImpl implements RealMatrix, Serializable {
int nRows = this.getRowDimension(); int nRows = this.getRowDimension();
int nCols = this.getColumnDimension(); int nCols = this.getColumnDimension();
return !(row < 1 || row > nRows || col < 1 || col > nCols); return !(row < 0 || row > nRows - 1 || col < 0 || col > nCols -1);
} }
} }

View File

@ -24,7 +24,7 @@ import java.math.BigDecimal;
/** /**
* Test cases for the {@link BigMatrixImpl} class. * Test cases for the {@link BigMatrixImpl} class.
* *
* @version $Revision: 1.2 $ $Date: 2004/07/11 04:49:24 $ * @version $Revision: 1.3 $ $Date: 2004/09/05 01:19:23 $
*/ */
public final class BigMatrixImplTest extends TestCase { public final class BigMatrixImplTest extends TestCase {
@ -425,8 +425,8 @@ public final class BigMatrixImplTest extends TestCase {
public void testGetVectors() { public void testGetVectors() {
BigMatrix m = new BigMatrixImpl(testData); BigMatrix m = new BigMatrixImpl(testData);
assertClose("get row",m.getRowAsDoubleArray(1),testDataRow1,entryTolerance); assertClose("get row",m.getRowAsDoubleArray(0),testDataRow1,entryTolerance);
assertClose("get col",m.getColumnAsDoubleArray(3),testDataCol3,entryTolerance); assertClose("get col",m.getColumnAsDoubleArray(2),testDataCol3,entryTolerance);
try { try {
double[] x = m.getRowAsDoubleArray(10); double[] x = m.getRowAsDoubleArray(10);
fail("expecting MatrixIndexException"); fail("expecting MatrixIndexException");
@ -443,17 +443,17 @@ public final class BigMatrixImplTest extends TestCase {
public void testEntryMutators() { public void testEntryMutators() {
BigMatrix m = new BigMatrixImpl(testData); BigMatrix m = new BigMatrixImpl(testData);
assertEquals("get entry",m.getEntry(1,2).doubleValue(),2d,entryTolerance); assertEquals("get entry",m.getEntry(0,1).doubleValue(),2d,entryTolerance);
m.setEntry(1,2,100d); m.setEntry(0,1,100d);
assertEquals("get entry",m.getEntry(1,2).doubleValue(),100d,entryTolerance); assertEquals("get entry",m.getEntry(0,1).doubleValue(),100d,entryTolerance);
try { try {
double x = m.getEntry(0,2).doubleValue(); double x = m.getEntry(-1,2).doubleValue();
fail("expecting MatrixIndexException"); fail("expecting MatrixIndexException");
} catch (MatrixIndexException ex) { } catch (MatrixIndexException ex) {
; ;
} }
try { try {
m.setEntry(1,4,200d); m.setEntry(1,3,200d);
fail("expecting MatrixIndexException"); fail("expecting MatrixIndexException");
} catch (MatrixIndexException ex) { } catch (MatrixIndexException ex) {
; ;
@ -529,8 +529,8 @@ public final class BigMatrixImplTest extends TestCase {
throw new InvalidMatrixException("incorrect dimensions"); throw new InvalidMatrixException("incorrect dimensions");
} }
int n = lu.getRowDimension(); int n = lu.getRowDimension();
for (int i = 1; i <= n; i++) { for (int i = 0; i < n; i++) {
for (int j = 1; j <= n; j++) { for (int j = 0; j < n; j++) {
if (j < i) { if (j < i) {
lower.setEntry(i, j, lu.getEntry(i, j)); lower.setEntry(i, j, lu.getEntry(i, j));
upper.setEntry(i, j, 0d); upper.setEntry(i, j, 0d);
@ -552,9 +552,9 @@ public final class BigMatrixImplTest extends TestCase {
} }
int n = matrix.getRowDimension(); int n = matrix.getRowDimension();
BigMatrix out = new BigMatrixImpl(n, n); BigMatrix out = new BigMatrixImpl(n, n);
for (int i =1; i <= n; i++) { for (int i = 0; i < n; i++) {
for (int j = 1; j <= n; j++) { for (int j = 0; j < n; j++) {
out.setEntry(i, j, matrix.getEntry(permutation[i -1] + 1, j)); out.setEntry(i, j, matrix.getEntry(permutation[i], j));
} }
} }
return out; return out;
@ -577,7 +577,7 @@ public final class BigMatrixImplTest extends TestCase {
for (int i = 0; i < m.getRowDimension(); i++) { for (int i = 0; i < m.getRowDimension(); i++) {
String os = ""; String os = "";
for (int j = 0; j < m.getColumnDimension(); j++) { for (int j = 0; j < m.getColumnDimension(); j++) {
os += m.getEntry(i+1, j+1) + " "; os += m.getEntry(i, j) + " ";
} }
System.out.println(os); System.out.println(os);
} }

View File

@ -22,7 +22,7 @@ import junit.framework.TestSuite;
/** /**
* Test cases for the {@link RealMatrixImpl} class. * Test cases for the {@link RealMatrixImpl} class.
* *
* @version $Revision: 1.14 $ $Date: 2004/05/18 04:08:38 $ * @version $Revision: 1.15 $ $Date: 2004/09/05 01:19:23 $
*/ */
public final class RealMatrixImplTest extends TestCase { public final class RealMatrixImplTest extends TestCase {
@ -369,8 +369,8 @@ public final class RealMatrixImplTest extends TestCase {
public void testGetVectors() { public void testGetVectors() {
RealMatrix m = new RealMatrixImpl(testData); RealMatrix m = new RealMatrixImpl(testData);
assertClose("get row",m.getRow(1),testDataRow1,entryTolerance); assertClose("get row",m.getRow(0),testDataRow1,entryTolerance);
assertClose("get col",m.getColumn(3),testDataCol3,entryTolerance); assertClose("get col",m.getColumn(2),testDataCol3,entryTolerance);
try { try {
double[] x = m.getRow(10); double[] x = m.getRow(10);
fail("expecting MatrixIndexException"); fail("expecting MatrixIndexException");
@ -387,11 +387,11 @@ public final class RealMatrixImplTest extends TestCase {
public void testEntryMutators() { public void testEntryMutators() {
RealMatrix m = new RealMatrixImpl(testData); RealMatrix m = new RealMatrixImpl(testData);
assertEquals("get entry",m.getEntry(1,2),2d,entryTolerance); assertEquals("get entry",m.getEntry(0,1),2d,entryTolerance);
m.setEntry(1,2,100d); m.setEntry(1,2,100d);
assertEquals("get entry",m.getEntry(1,2),100d,entryTolerance); assertEquals("get entry",m.getEntry(1,2),100d,entryTolerance);
try { try {
double x = m.getEntry(0,2); double x = m.getEntry(-1,2);
fail("expecting MatrixIndexException"); fail("expecting MatrixIndexException");
} catch (MatrixIndexException ex) { } catch (MatrixIndexException ex) {
; ;
@ -492,8 +492,8 @@ public final class RealMatrixImplTest extends TestCase {
throw new InvalidMatrixException("incorrect dimensions"); throw new InvalidMatrixException("incorrect dimensions");
} }
int n = lu.getRowDimension(); int n = lu.getRowDimension();
for (int i = 1; i <= n; i++) { for (int i = 0; i < n; i++) {
for (int j = 1; j <= n; j++) { for (int j = 0; j < n; j++) {
if (j < i) { if (j < i) {
lower.setEntry(i, j, lu.getEntry(i, j)); lower.setEntry(i, j, lu.getEntry(i, j));
upper.setEntry(i, j, 0d); upper.setEntry(i, j, 0d);
@ -515,9 +515,9 @@ public final class RealMatrixImplTest extends TestCase {
} }
int n = matrix.getRowDimension(); int n = matrix.getRowDimension();
RealMatrix out = new RealMatrixImpl(n, n); RealMatrix out = new RealMatrixImpl(n, n);
for (int i =1; i <= n; i++) { for (int i = 0; i < n; i++) {
for (int j = 1; j <= n; j++) { for (int j = 0; j < n; j++) {
out.setEntry(i, j, matrix.getEntry(permutation[i -1] + 1, j)); out.setEntry(i, j, matrix.getEntry(permutation[i], j));
} }
} }
return out; return out;
@ -540,7 +540,7 @@ public final class RealMatrixImplTest extends TestCase {
for (int i = 0; i < m.getRowDimension(); i++) { for (int i = 0; i < m.getRowDimension(); i++) {
String os = ""; String os = "";
for (int j = 0; j < m.getColumnDimension(); j++) { for (int j = 0; j < m.getColumnDimension(); j++) {
os += m.getEntry(i+1, j+1) + " "; os += m.getEntry(i, j) + " ";
} }
System.out.println(os); System.out.println(os);
} }