|
STK++ 1.0
|
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*/