STK++ 1.0
STK_Real.h
Go to the documentation of this file.
00001 /*--------------------------------------------------------------------*/
00002 /*     Copyright (C) 2004-2007  Serge Iovleff
00003 
00004     This program is free software; you can redistribute it and/or modify
00005     it under the terms of the GNU Lesser General Public License as
00006     published by the Free Software Foundation; either version 2 of the
00007     License, or (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 Lesser General Public License for more details.
00013 
00014     You should have received a copy of the GNU Lesser General Public
00015     License along with this program; if not, write to the
00016     Free Software Foundation, Inc.,
00017     59 Temple Place,
00018     Suite 330,
00019     Boston, MA 02111-1307
00020     USA
00021 
00022     Contact : Serge.Iovleff@stkpp.org
00023 */
00024 
00025 /*
00026  * Project:  Base
00027  * Purpose:  Define the fundamental type Real.
00028  * Author:   Serge Iovleff, serge.iovleff@stkpp.org
00029  *
00030  **/
00031 
00036 #ifndef STK_REAL_H
00037 #define STK_REAL_H
00038 
00039 #include "STK_Arithmetic.h"
00040 #include "STK_IdTypeImpl.h"
00041 
00042 namespace STK
00043 {
00044 
00051 typedef double Real ;
00052 
00059 template<>
00060 struct Arithmetic<Real> : public std::numeric_limits<Real>
00061 {
00064   static const bool has_quiet_NaN = false;
00065 
00069   static Real NA() throw()
00070   { return std::numeric_limits<Real>::quiet_NaN();}
00071 
00073   static const bool hasNA = true;
00074 
00078   static bool isNA(Real const& x) throw()
00079   { return !(x==x);}
00080 
00084   static bool isInfinite(Real const& x) throw()
00085   { return ( (x < -std::numeric_limits<Real>::max())
00086            ||(x > std::numeric_limits<Real>::max())
00087            );
00088   }
00089 
00093   static bool isFinite(Real const& x) throw()
00094   { return (!isNA(x) && !isInfinite(x));}
00095 };
00096 
00102 template<>
00103 struct IdTypeImpl<Real>
00104 {
00106   static IdType returnType()
00107   { return(real);}
00108 };
00109   
00110 } // namespace STK
00111 
00112 #endif /*STK_REAL_H*/