/* * SubspaceFactorizerUnitTest.hpp * * Created on: Nov 13, 2010 * Author: heber */ #ifndef SUBSPACEFACTORIZERUNITTEST_HPP_ #define SUBSPACEFACTORIZERUNITTEST_HPP_ #include class MatrixContent; class VectorContent; class Subspace; typedef std::set > SetofIndexSets; typedef std::set IndexSet; typedef std::multimap< size_t, boost::shared_ptr > SubspaceMap; typedef std::multimap< size_t, boost::shared_ptr > IndexMap; typedef std::list< boost::shared_ptr > VectorList; typedef std::list< std::pair, double> > VectorValueList; typedef std::vector< boost::shared_ptr > VectorArray; typedef std::vector< double > ValueArray; class SubspaceFactorizerUnittest : public CppUnit::TestFixture { CPPUNIT_TEST_SUITE( SubspaceFactorizerUnittest) ; CPPUNIT_TEST ( BlockTest ); //CPPUNIT_TEST ( EigenvectorTest ); CPPUNIT_TEST ( generatePowerSetTest ); CPPUNIT_TEST ( SubspaceTest ); CPPUNIT_TEST_SUITE_END(); public: void setUp(); void tearDown(); void BlockTest(); void EigenvectorTest(); void generatePowerSetTest(); void SubspaceTest(); enum { matrixdimension = 4 }; enum { subspacelimit = 3 }; private: MatrixContent *matrix; MatrixContent ***transformation; }; MatrixContent * getSubspaceMatrix(MatrixContent &bigmatrix, const IndexSet &rowindexset, const IndexSet &columnindexset); void embedSubspaceMatrix(MatrixContent &bigmatrix, MatrixContent &subsystem, const IndexSet &rowindexset, const IndexSet &columnindexset); std::ostream & operator<<(std::ostream &ost, const IndexSet &indexset); #endif /* SUBSPACEFACTORIZERUNITTEST_HPP_ */