OpenWalnut  1.4.0
WMatrixTraits.h
00001 //---------------------------------------------------------------------------
00002 //
00003 // Project: OpenWalnut ( http://www.openwalnut.org )
00004 //
00005 // Copyright 2009 OpenWalnut Community, BSV@Uni-Leipzig and CNCF@MPI-CBS
00006 // For more information see http://www.openwalnut.org/copying
00007 //
00008 // This file is part of OpenWalnut.
00009 //
00010 // OpenWalnut is free software: you can redistribute it and/or modify
00011 // it under the terms of the GNU Lesser General Public License as published by
00012 // the Free Software Foundation, either version 3 of the License, or
00013 // (at your option) any later version.
00014 //
00015 // OpenWalnut is distributed in the hope that it will be useful,
00016 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00018 // GNU Lesser General Public License for more details.
00019 //
00020 // You should have received a copy of the GNU Lesser General Public License
00021 // along with OpenWalnut. If not, see <http://www.gnu.org/licenses/>.
00022 //
00023 //---------------------------------------------------------------------------
00024 
00025 #ifndef WMATRIXTRAITS_H
00026 #define WMATRIXTRAITS_H
00027 
00028 #include <sstream>
00029 
00030 #include <cxxtest/TestSuite.h>
00031 #include <cxxtest/ValueTraits.h>
00032 
00033 #include "../../test/WTraitsBase.h"
00034 #include "../WMatrix.h"
00035 
00036 #ifdef CXXTEST_RUNNING
00037 namespace CxxTest
00038 {
00039 CXXTEST_TEMPLATE_INSTANTIATION
00040 /**
00041  * Enables better UnitTest OutPut if something fails with WFibers, so you see
00042  * immedeatly what is failing.
00043  */
00044 class ValueTraits< WMatrix< double > > : public WTraitsBase
00045 {
00046 public:
00047     /**
00048      * Constructor for class allowing usable output of WMatrix in tests
00049      *
00050      * \param m the WMatrix to print
00051      */
00052     explicit ValueTraits( const WMatrix<double> &m )
00053     {
00054         std::stringstream tmp;
00055         tmp.precision( 5 );
00056         tmp << std::endl;
00057         for( size_t row = 0; row < m.getNbRows(); row++ )
00058         {
00059           for( size_t col = 0; col < m.getNbCols(); col++ )
00060           {
00061               tmp << m( row, col ) << "\t";
00062           }
00063           tmp << std::endl;
00064         }
00065         m_s = tmp.str();
00066     }
00067 };
00068 }
00069 #endif  // CXXTEST_RUNNING
00070 #endif  // WMATRIXTRAITS_H