math.hh

00001 // Copyright (C) 2001, 2002, 2003  EPITA Research and Development Laboratory
00002 //
00003 // This file is part of the Olena Library.  This library is free
00004 // software; you can redistribute it and/or modify it under the terms
00005 // of the GNU General Public License version 2 as published by the
00006 // Free Software Foundation.
00007 //
00008 // This library is distributed in the hope that it will be useful,
00009 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00010 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00011 // General Public License for more details.
00012 //
00013 // You should have received a copy of the GNU General Public License
00014 // along with this library; see the file COPYING.  If not, write to
00015 // the Free Software Foundation, 59 Temple Place - Suite 330, Boston,
00016 // MA 02111-1307, USA.
00017 //
00018 // As a special exception, you may use this file as part of a free
00019 // software library without restriction.  Specifically, if other files
00020 // instantiate templates or use macros or inline functions from this
00021 // file, or you compile this file and link it with other files to
00022 // produce an executable, this file does not by itself cause the
00023 // resulting executable to be covered by the GNU General Public
00024 // License.  This exception does not however invalidate any other
00025 // reasons why the executable file might be covered by the GNU General
00026 // Public License.
00027 
00028 #ifndef NTG_CONFIG_MATH_HH
00029 # define NTG_CONFIG_MATH_HH
00030 
00031 # include <ntg/config/system.hh>
00032 
00033 # include <cmath>
00034 
00035 # ifndef USE_C_LIMITS
00036 #  include <limits>
00037 #  define NTG_DOUBLE_INFINITY (std::numeric_limits<double>::infinity())
00038 #  define NTG_FLOAT_INFINITY (std::numeric_limits<float>::infinity())
00039 # else
00040 #  ifdef HUGE_VAL
00041 #   define NTG_DOUBLE_INFINITY HUGE_VAL
00042 #   ifdef HUGE_VALF
00043 #    define NTG_FLOAT_INFINITY HUGE_VALF
00044 #   else
00045 #    define NTG_FLOAT_INFINITY ((float)HUGE_VAL)
00046 #   endif
00047 #  else
00048 #   error Cannot define Infinity in this configuration.
00049 #  endif
00050 # endif
00051 
00052 # ifndef M_PI
00053 #  define M_PI 3.14159265358979323846264338327
00054 # endif
00055 
00056 # ifdef NEED_SQRTF
00057 static inline float sqrtf(float f)
00058 {
00059   return (float)sqrt((double)f);
00060 }
00061 # endif
00062 
00063 # ifdef NEED_FLOORF
00064 static inline float floorf(float f)
00065 {
00066   return (float)floor((double)f);
00067 }
00068 # endif
00069 
00070 # ifdef NEED_ROUND
00071 static inline double round(double f)
00072 {
00073   return (f < 0.) ? -floor(-f + 0.5) : floor(f + 0.5);
00074 }
00075 # endif
00076 # ifdef NEED_ROUNDF
00077 static inline float roundf(float f)
00078 {
00079   return (f < 0.f) ? -floorf(-f + 0.5f) : floorf(f + 0.5f);
00080 }
00081 # endif
00082 
00083 #endif // !NTG_CONFIG_MATH_HH

Generated on Thu Apr 15 20:13:13 2004 for Olena by doxygen 1.3.6-20040222