GiNaCRA  0.6.4
MultivariateCoefficientMR.h
Go to the documentation of this file.
00001 /*
00002  * GiNaCRA - GiNaC Real Algebra package
00003  * Copyright (C) 2010-2012  Ulrich Loup, Joachim Redies, Sebastian Junges
00004  *
00005  * This file is part of GiNaCRA.
00006  *
00007  * GiNaCRA is free software: you can redistribute it and/or modify
00008  * it under the terms of the GNU General Public License as published by
00009  * the Free Software Foundation, either version 3 of the License, or
00010  * (at your option) any later version.
00011  *
00012  * GiNaCRA is distributed in the hope that it will be useful,
00013  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00014  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00015  * GNU General Public License for more details.
00016  *
00017  * You should have received a copy of the GNU General Public License
00018  * along with GiNaCRA.  If not, see <http://www.gnu.org/licenses/>.
00019  *
00020  */
00021 
00022 
00023 #ifndef MULTIVARIATECOEFFICIENTMR_H
00024 #define MULTIVARIATECOEFFICIENTMR_H
00025 
00026 #include <ginac/ginac.h>
00027 #include <iostream>
00028 
00029 namespace GiNaCRA
00030 {
00038     class MultivariateCoefficientMR
00039     {
00040         public:
00041             MultivariateCoefficientMR();
00042             MultivariateCoefficientMR( const GiNaC::ex& );
00043             friend bool operator ==( const MultivariateCoefficientMR& m1, const MultivariateCoefficientMR& m2 );
00044             friend const MultivariateCoefficientMR operator *( const MultivariateCoefficientMR& m1, const MultivariateCoefficientMR& m2 );
00045             friend const MultivariateCoefficientMR operator +( const MultivariateCoefficientMR& m1, const MultivariateCoefficientMR& m2 );
00046             friend const MultivariateCoefficientMR operator -( const MultivariateCoefficientMR& m1 );
00047             friend const MultivariateCoefficientMR operator -( const MultivariateCoefficientMR& m1, const MultivariateCoefficientMR& m2 );
00048             friend const MultivariateCoefficientMR operator /( const MultivariateCoefficientMR& m1, const MultivariateCoefficientMR& m2 );
00049             friend std::ostream& operator <<( std::ostream& os, const MultivariateCoefficientMR& m1 );
00050 
00051             inline GiNaC::ex getExpression() const
00052             {
00053                 return mCoefficient;
00054             }
00055 
00056             inline MultivariateCoefficientMR inverse() const
00057             {
00058                 if( GiNaC::is_exactly_a<GiNaC::numeric>( mCoefficient ))
00059                 {
00060                     GiNaC::numeric num = GiNaC::ex_to<GiNaC::numeric>( mCoefficient );
00061                     return MultivariateCoefficientMR( GiNaC::ex( num.inverse() ));
00062                 }
00063                 throw (std::domain_error( "The coefficient is not a numeric (others not supported yet)" ));
00064             }
00065 
00066         protected:
00067             GiNaC::ex mCoefficient;
00068     };
00069 
00070 }
00071 #endif