00001 /**************************************************************************** 00002 Copyright (C)2002 David Jung <opensim@pobox.com> 00003 00004 This program/file is free software; you can redistribute it and/or modify 00005 it under the terms of the GNU General Public License as published by 00006 the Free Software Foundation; either version 2 of the License, or 00007 (at your option) any later version. 00008 00009 This program is distributed in the hope that it will be useful, 00010 but WITHOUT ANY WARRANTY; without even the implied warranty of 00011 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00012 GNU General Public License for more details. (http://www.gnu.org) 00013 00014 You should have received a copy of the GNU General Public License 00015 along with this program; if not, write to the Free Software 00016 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 00017 00018 $Id: MathTest 1029 2004-02-11 20:45:54Z jungd $ 00019 $Revision: 1.7 $ 00020 $Date: 2004-02-11 15:45:54 -0500 (Wed, 11 Feb 2004) $ 00021 $Author: jungd $ 00022 00023 ****************************************************************************/ 00024 00025 #ifndef _BASE_MATHTEST_ 00026 #define _BASE_MATHTEST_ 00027 00028 #include <cppunit/extensions/HelperMacros.h> 00029 00030 #include <base/Math> 00031 00032 namespace base { 00033 00034 00035 class MathTest : public CppUnit::TestFixture 00036 { 00037 static const Int numOfTests = 7; 00038 00039 CPPUNIT_TEST_SUITE( MathTest ); 00040 00041 CPPUNIT_TEST( testMatrixVector ); 00042 CPPUNIT_TEST( testNullSpace ); 00043 CPPUNIT_TEST( testInverse ); 00044 CPPUNIT_TEST_EXCEPTION( testInverseSingular, std::invalid_argument ); 00045 CPPUNIT_TEST( testSVD ); 00046 CPPUNIT_TEST( testPseudoInverse ); 00047 CPPUNIT_TEST( testExpression ); 00048 CPPUNIT_TEST( testPath ); 00049 00050 CPPUNIT_TEST_SUITE_END(); 00051 00052 protected: 00053 Matrix I, A, S, P; 00054 Vector b, x; 00055 00056 public: 00057 MathTest(); 00058 00059 int countTestCases () const { return numOfTests; } 00060 00061 void setUp(); 00062 void tearDown(); 00063 00064 void testMatrixVector(); 00065 void testNullSpace(); 00066 void testInverse(); 00067 void testInverseSingular(); 00068 void testSVD(); 00069 void testPseudoInverse(); 00070 void testExpression(); 00071 void testPath(); 00072 }; 00073 00074 00075 } // base 00076 00077 #endif