Moved matrix equality tests to TestUtils.

git-svn-id: https://svn.apache.org/repos/asf/commons/proper/math/trunk@742120 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Phil Steitz 2009-02-08 15:26:09 +00:00
parent 94fcce51cd
commit 2f227a6314
2 changed files with 65 additions and 39 deletions

View File

@ -28,6 +28,7 @@ import junit.framework.AssertionFailedError;
import org.apache.commons.math.complex.Complex; import org.apache.commons.math.complex.Complex;
import org.apache.commons.math.complex.ComplexFormat; import org.apache.commons.math.complex.ComplexFormat;
import org.apache.commons.math.linear.RealMatrix;
/** /**
* @version $Revision$ $Date$ * @version $Revision$ $Date$
@ -252,4 +253,45 @@ public class TestUtils {
assertContains(null, values, x, epsilon); assertContains(null, values, x, epsilon);
} }
/** verifies that two matrices are close (1-norm) */
public static void assertEquals(String msg, RealMatrix expected, RealMatrix observed,
double tolerance) {
if (observed == null) {
Assert.fail(msg + "\nObserved is null");
}
if (expected.getColumnDimension() != observed.getColumnDimension() ||
expected.getRowDimension() != observed.getRowDimension()) {
StringBuffer messageBuffer = new StringBuffer(msg);
messageBuffer.append("\nObserved has incorrect dimensions.");
messageBuffer.append("\nobserved is " + observed.getRowDimension() +
" x " + observed.getColumnDimension());
messageBuffer.append("\nexpected " + expected.getRowDimension() +
" x " + expected.getColumnDimension());
Assert.fail(messageBuffer.toString());
}
RealMatrix delta = expected.subtract(observed);
if (delta.getNorm() >= tolerance) {
StringBuffer messageBuffer = new StringBuffer(msg);
messageBuffer.append("\nExpected: " + expected);
messageBuffer.append("\nObserved: " + observed);
messageBuffer.append("\nexpected - observed: " + delta);
Assert.fail(messageBuffer.toString());
}
}
/** verifies that two arrays are close (sup norm) */
public static void assertEquals(String msg, double[] m, double[] n,
double tolerance) {
if (m.length != n.length) {
Assert.fail("vectors not same length");
}
for (int i = 0; i < m.length; i++) {
Assert.assertEquals(msg + " " + i + " elements differ",
m[i],n[i],tolerance);
}
}
} }

View File

@ -20,6 +20,8 @@ import junit.framework.Test;
import junit.framework.TestCase; import junit.framework.TestCase;
import junit.framework.TestSuite; import junit.framework.TestSuite;
import org.apache.commons.math.TestUtils;
/** /**
* Test cases for the {@link RealMatrixImpl} class. * Test cases for the {@link RealMatrixImpl} class.
* *
@ -171,7 +173,7 @@ public final class RealMatrixImplTest extends TestCase {
public void testPlusMinus() { public void testPlusMinus() {
RealMatrixImpl m = new RealMatrixImpl(testData); RealMatrixImpl m = new RealMatrixImpl(testData);
RealMatrixImpl m2 = new RealMatrixImpl(testDataInv); RealMatrixImpl m2 = new RealMatrixImpl(testDataInv);
assertClose("m-n = m + -n",m.subtract(m2), TestUtils.assertEquals("m-n = m + -n",m.subtract(m2),
m2.scalarMultiply(-1d).add(m),entryTolerance); m2.scalarMultiply(-1d).add(m),entryTolerance);
try { try {
m.subtract(new RealMatrixImpl(testData2)); m.subtract(new RealMatrixImpl(testData2));
@ -187,15 +189,15 @@ public final class RealMatrixImplTest extends TestCase {
RealMatrixImpl mInv = new RealMatrixImpl(testDataInv); RealMatrixImpl mInv = new RealMatrixImpl(testDataInv);
RealMatrixImpl identity = new RealMatrixImpl(id); RealMatrixImpl identity = new RealMatrixImpl(id);
RealMatrixImpl m2 = new RealMatrixImpl(testData2); RealMatrixImpl m2 = new RealMatrixImpl(testData2);
assertClose("inverse multiply",m.multiply(mInv), TestUtils.assertEquals("inverse multiply",m.multiply(mInv),
identity,entryTolerance); identity,entryTolerance);
assertClose("inverse multiply",mInv.multiply(m), TestUtils.assertEquals("inverse multiply",mInv.multiply(m),
identity,entryTolerance); identity,entryTolerance);
assertClose("identity multiply",m.multiply(identity), TestUtils.assertEquals("identity multiply",m.multiply(identity),
m,entryTolerance); m,entryTolerance);
assertClose("identity multiply",identity.multiply(mInv), TestUtils.assertEquals("identity multiply",identity.multiply(mInv),
mInv,entryTolerance); mInv,entryTolerance);
assertClose("identity multiply",m2.multiply(identity), TestUtils.assertEquals("identity multiply",m2.multiply(identity),
m2,entryTolerance); m2,entryTolerance);
try { try {
m.multiply(new RealMatrixImpl(bigSingular)); m.multiply(new RealMatrixImpl(bigSingular));
@ -215,7 +217,7 @@ public final class RealMatrixImplTest extends TestCase {
RealMatrix m3 = new RealMatrixImpl(d3); RealMatrix m3 = new RealMatrixImpl(d3);
RealMatrix m4 = new RealMatrixImpl(d4); RealMatrix m4 = new RealMatrixImpl(d4);
RealMatrix m5 = new RealMatrixImpl(d5); RealMatrix m5 = new RealMatrixImpl(d5);
assertClose("m3*m4=m5", m3.multiply(m4), m5, entryTolerance); TestUtils.assertEquals("m3*m4=m5", m3.multiply(m4), m5, entryTolerance);
} }
/** test trace */ /** test trace */
@ -234,16 +236,16 @@ public final class RealMatrixImplTest extends TestCase {
/** test sclarAdd */ /** test sclarAdd */
public void testScalarAdd() { public void testScalarAdd() {
RealMatrix m = new RealMatrixImpl(testData); RealMatrix m = new RealMatrixImpl(testData);
assertClose("scalar add",new RealMatrixImpl(testDataPlus2), TestUtils.assertEquals("scalar add",new RealMatrixImpl(testDataPlus2),
m.scalarAdd(2d),entryTolerance); m.scalarAdd(2d),entryTolerance);
} }
/** test operate */ /** test operate */
public void testOperate() { public void testOperate() {
RealMatrix m = new RealMatrixImpl(id); RealMatrix m = new RealMatrixImpl(id);
assertClose("identity operate", testVector, TestUtils.assertEquals("identity operate", testVector,
m.operate(testVector), entryTolerance); m.operate(testVector), entryTolerance);
assertClose("identity operate", testVector, TestUtils.assertEquals("identity operate", testVector,
m.operate(new RealVectorImpl(testVector)).getData(), entryTolerance); m.operate(new RealVectorImpl(testVector)).getData(), entryTolerance);
m = new RealMatrixImpl(bigSingular); m = new RealMatrixImpl(bigSingular);
try { try {
@ -271,18 +273,18 @@ public final class RealMatrixImplTest extends TestCase {
RealMatrix m = new RealMatrixImpl(testData); RealMatrix m = new RealMatrixImpl(testData);
RealMatrix mIT = new LUDecompositionImpl(m).getSolver().getInverse().transpose(); RealMatrix mIT = new LUDecompositionImpl(m).getSolver().getInverse().transpose();
RealMatrix mTI = new LUDecompositionImpl(m.transpose()).getSolver().getInverse(); RealMatrix mTI = new LUDecompositionImpl(m.transpose()).getSolver().getInverse();
assertClose("inverse-transpose", mIT, mTI, normTolerance); TestUtils.assertEquals("inverse-transpose", mIT, mTI, normTolerance);
m = new RealMatrixImpl(testData2); m = new RealMatrixImpl(testData2);
RealMatrix mt = new RealMatrixImpl(testData2T); RealMatrix mt = new RealMatrixImpl(testData2T);
assertClose("transpose",mt,m.transpose(),normTolerance); TestUtils.assertEquals("transpose",mt,m.transpose(),normTolerance);
} }
/** test preMultiply by vector */ /** test preMultiply by vector */
public void testPremultiplyVector() { public void testPremultiplyVector() {
RealMatrix m = new RealMatrixImpl(testData); RealMatrix m = new RealMatrixImpl(testData);
assertClose("premultiply", m.preMultiply(testVector), TestUtils.assertEquals("premultiply", m.preMultiply(testVector),
preMultTest, normTolerance); preMultTest, normTolerance);
assertClose("premultiply", m.preMultiply(new RealVectorImpl(testVector).getData()), TestUtils.assertEquals("premultiply", m.preMultiply(new RealVectorImpl(testVector).getData()),
preMultTest, normTolerance); preMultTest, normTolerance);
m = new RealMatrixImpl(bigSingular); m = new RealMatrixImpl(bigSingular);
try { try {
@ -297,18 +299,18 @@ public final class RealMatrixImplTest extends TestCase {
RealMatrix m3 = new RealMatrixImpl(d3); RealMatrix m3 = new RealMatrixImpl(d3);
RealMatrix m4 = new RealMatrixImpl(d4); RealMatrix m4 = new RealMatrixImpl(d4);
RealMatrix m5 = new RealMatrixImpl(d5); RealMatrix m5 = new RealMatrixImpl(d5);
assertClose("m3*m4=m5", m4.preMultiply(m3), m5, entryTolerance); TestUtils.assertEquals("m3*m4=m5", m4.preMultiply(m3), m5, entryTolerance);
RealMatrixImpl m = new RealMatrixImpl(testData); RealMatrixImpl m = new RealMatrixImpl(testData);
RealMatrixImpl mInv = new RealMatrixImpl(testDataInv); RealMatrixImpl mInv = new RealMatrixImpl(testDataInv);
RealMatrixImpl identity = new RealMatrixImpl(id); RealMatrixImpl identity = new RealMatrixImpl(id);
assertClose("inverse multiply",m.preMultiply(mInv), TestUtils.assertEquals("inverse multiply",m.preMultiply(mInv),
identity,entryTolerance); identity,entryTolerance);
assertClose("inverse multiply",mInv.preMultiply(m), TestUtils.assertEquals("inverse multiply",mInv.preMultiply(m),
identity,entryTolerance); identity,entryTolerance);
assertClose("identity multiply",m.preMultiply(identity), TestUtils.assertEquals("identity multiply",m.preMultiply(identity),
m,entryTolerance); m,entryTolerance);
assertClose("identity multiply",identity.preMultiply(mInv), TestUtils.assertEquals("identity multiply",identity.preMultiply(mInv),
mInv,entryTolerance); mInv,entryTolerance);
try { try {
m.preMultiply(new RealMatrixImpl(bigSingular)); m.preMultiply(new RealMatrixImpl(bigSingular));
@ -320,8 +322,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(0),testDataRow1,entryTolerance); TestUtils.assertEquals("get row",m.getRow(0),testDataRow1,entryTolerance);
assertClose("get col",m.getColumn(2),testDataCol3,entryTolerance); TestUtils.assertEquals("get col",m.getColumn(2),testDataCol3,entryTolerance);
try { try {
m.getRow(10); m.getRow(10);
fail("expecting MatrixIndexException"); fail("expecting MatrixIndexException");
@ -955,24 +957,6 @@ public final class RealMatrixImplTest extends TestCase {
//--------------- -----------------Protected methods //--------------- -----------------Protected methods
/** verifies that two matrices are close (1-norm) */
protected void assertClose(String msg, RealMatrix m, RealMatrix n,
double tolerance) {
assertTrue(msg,m.subtract(n).getNorm() < tolerance);
}
/** verifies that two vectors are close (sup norm) */
protected void assertClose(String msg, double[] m, double[] n,
double tolerance) {
if (m.length != n.length) {
fail("vectors not same length");
}
for (int i = 0; i < m.length; i++) {
assertEquals(msg + " " + i + " elements differ",
m[i],n[i],tolerance);
}
}
/** extracts the l and u matrices from compact lu representation */ /** extracts the l and u matrices from compact lu representation */
protected void splitLU(RealMatrix lu, double[][] lowerData, double[][] upperData) throws InvalidMatrixException { protected void splitLU(RealMatrix lu, double[][] lowerData, double[][] upperData) throws InvalidMatrixException {
if (!lu.isSquare() || lowerData.length != lowerData[0].length || upperData.length != upperData[0].length || if (!lu.isSquare() || lowerData.length != lowerData[0].length || upperData.length != upperData[0].length ||