From 2f227a6314bbc71f5a9a91c3c39f4b9a1c2c9ae8 Mon Sep 17 00:00:00 2001 From: Phil Steitz Date: Sun, 8 Feb 2009 15:26:09 +0000 Subject: [PATCH] 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 --- .../org/apache/commons/math/TestUtils.java | 42 +++++++++++++ .../math/linear/RealMatrixImplTest.java | 62 +++++++------------ 2 files changed, 65 insertions(+), 39 deletions(-) diff --git a/src/test/org/apache/commons/math/TestUtils.java b/src/test/org/apache/commons/math/TestUtils.java index cf6a7af51..3289230ad 100644 --- a/src/test/org/apache/commons/math/TestUtils.java +++ b/src/test/org/apache/commons/math/TestUtils.java @@ -28,6 +28,7 @@ import junit.framework.AssertionFailedError; import org.apache.commons.math.complex.Complex; import org.apache.commons.math.complex.ComplexFormat; +import org.apache.commons.math.linear.RealMatrix; /** * @version $Revision$ $Date$ @@ -252,4 +253,45 @@ public class TestUtils { 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); + } + } + } diff --git a/src/test/org/apache/commons/math/linear/RealMatrixImplTest.java b/src/test/org/apache/commons/math/linear/RealMatrixImplTest.java index 154d0ab76..982114419 100644 --- a/src/test/org/apache/commons/math/linear/RealMatrixImplTest.java +++ b/src/test/org/apache/commons/math/linear/RealMatrixImplTest.java @@ -20,6 +20,8 @@ import junit.framework.Test; import junit.framework.TestCase; import junit.framework.TestSuite; +import org.apache.commons.math.TestUtils; + /** * Test cases for the {@link RealMatrixImpl} class. * @@ -171,7 +173,7 @@ public final class RealMatrixImplTest extends TestCase { public void testPlusMinus() { RealMatrixImpl m = new RealMatrixImpl(testData); 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); try { m.subtract(new RealMatrixImpl(testData2)); @@ -187,15 +189,15 @@ public final class RealMatrixImplTest extends TestCase { RealMatrixImpl mInv = new RealMatrixImpl(testDataInv); RealMatrixImpl identity = new RealMatrixImpl(id); RealMatrixImpl m2 = new RealMatrixImpl(testData2); - assertClose("inverse multiply",m.multiply(mInv), + TestUtils.assertEquals("inverse multiply",m.multiply(mInv), identity,entryTolerance); - assertClose("inverse multiply",mInv.multiply(m), + TestUtils.assertEquals("inverse multiply",mInv.multiply(m), identity,entryTolerance); - assertClose("identity multiply",m.multiply(identity), + TestUtils.assertEquals("identity multiply",m.multiply(identity), m,entryTolerance); - assertClose("identity multiply",identity.multiply(mInv), + TestUtils.assertEquals("identity multiply",identity.multiply(mInv), mInv,entryTolerance); - assertClose("identity multiply",m2.multiply(identity), + TestUtils.assertEquals("identity multiply",m2.multiply(identity), m2,entryTolerance); try { m.multiply(new RealMatrixImpl(bigSingular)); @@ -215,7 +217,7 @@ public final class RealMatrixImplTest extends TestCase { RealMatrix m3 = new RealMatrixImpl(d3); RealMatrix m4 = new RealMatrixImpl(d4); 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 */ @@ -234,16 +236,16 @@ public final class RealMatrixImplTest extends TestCase { /** test sclarAdd */ public void testScalarAdd() { RealMatrix m = new RealMatrixImpl(testData); - assertClose("scalar add",new RealMatrixImpl(testDataPlus2), + TestUtils.assertEquals("scalar add",new RealMatrixImpl(testDataPlus2), m.scalarAdd(2d),entryTolerance); } /** test operate */ public void testOperate() { RealMatrix m = new RealMatrixImpl(id); - assertClose("identity operate", testVector, + TestUtils.assertEquals("identity operate", testVector, m.operate(testVector), entryTolerance); - assertClose("identity operate", testVector, + TestUtils.assertEquals("identity operate", testVector, m.operate(new RealVectorImpl(testVector)).getData(), entryTolerance); m = new RealMatrixImpl(bigSingular); try { @@ -271,18 +273,18 @@ public final class RealMatrixImplTest extends TestCase { RealMatrix m = new RealMatrixImpl(testData); RealMatrix mIT = new LUDecompositionImpl(m).getSolver().getInverse().transpose(); 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); RealMatrix mt = new RealMatrixImpl(testData2T); - assertClose("transpose",mt,m.transpose(),normTolerance); + TestUtils.assertEquals("transpose",mt,m.transpose(),normTolerance); } /** test preMultiply by vector */ public void testPremultiplyVector() { RealMatrix m = new RealMatrixImpl(testData); - assertClose("premultiply", m.preMultiply(testVector), + TestUtils.assertEquals("premultiply", m.preMultiply(testVector), preMultTest, normTolerance); - assertClose("premultiply", m.preMultiply(new RealVectorImpl(testVector).getData()), + TestUtils.assertEquals("premultiply", m.preMultiply(new RealVectorImpl(testVector).getData()), preMultTest, normTolerance); m = new RealMatrixImpl(bigSingular); try { @@ -297,18 +299,18 @@ public final class RealMatrixImplTest extends TestCase { RealMatrix m3 = new RealMatrixImpl(d3); RealMatrix m4 = new RealMatrixImpl(d4); 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 mInv = new RealMatrixImpl(testDataInv); RealMatrixImpl identity = new RealMatrixImpl(id); - assertClose("inverse multiply",m.preMultiply(mInv), + TestUtils.assertEquals("inverse multiply",m.preMultiply(mInv), identity,entryTolerance); - assertClose("inverse multiply",mInv.preMultiply(m), + TestUtils.assertEquals("inverse multiply",mInv.preMultiply(m), identity,entryTolerance); - assertClose("identity multiply",m.preMultiply(identity), + TestUtils.assertEquals("identity multiply",m.preMultiply(identity), m,entryTolerance); - assertClose("identity multiply",identity.preMultiply(mInv), + TestUtils.assertEquals("identity multiply",identity.preMultiply(mInv), mInv,entryTolerance); try { m.preMultiply(new RealMatrixImpl(bigSingular)); @@ -320,8 +322,8 @@ public final class RealMatrixImplTest extends TestCase { public void testGetVectors() { RealMatrix m = new RealMatrixImpl(testData); - assertClose("get row",m.getRow(0),testDataRow1,entryTolerance); - assertClose("get col",m.getColumn(2),testDataCol3,entryTolerance); + TestUtils.assertEquals("get row",m.getRow(0),testDataRow1,entryTolerance); + TestUtils.assertEquals("get col",m.getColumn(2),testDataCol3,entryTolerance); try { m.getRow(10); fail("expecting MatrixIndexException"); @@ -954,24 +956,6 @@ public final class RealMatrixImplTest extends TestCase { }; //--------------- -----------------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 */ protected void splitLU(RealMatrix lu, double[][] lowerData, double[][] upperData) throws InvalidMatrixException {