//C++ header - Open Scene Graph - Copyright (C) 1998-2001 Robert Osfield //Distributed under the terms of the GNU Library General Public License (LGPL) //as published by the Free Software Foundation. #ifndef __OSG_MATH #define __OSG_MATH #include #if defined(WIN32) || defined (macintosh)|| defined (sun) || defined (__DARWIN_OSX__) #include // PJA MAC OSX // This appears to be the simplest way to get these defined under MACOSX // where they arent in math.h #ifndef acosf #define acosf (float)acos #endif #ifndef asinf #define asinf (float)asin #endif #ifndef cosf #define cosf (float)cos #endif #ifndef sinf #define sinf (float)sin #endif #ifndef logf #define logf (float)log #endif #ifndef floorf #define floorf (float)floor #endif #ifndef powf #define powf (float)pow #endif #ifndef sqrtf #define sqrtf (float)sqrt #endif #ifndef fabsf #define fabsf (float)fabs #endif #ifndef isnanf #define isnanf (float)isnan #endif #endif namespace osg { // define the stand trig values #ifdef PI #undef PI #undef PI_2 #undef PI_4 #endif const double PI = 3.14159265358979323846; const double PI_2 = 1.57079632679489661923; const double PI_4 = 0.78539816339744830962; template inline T clampTo(T v,T minimum,T maximum) { return vmaximum?maximum:v; } template inline T clampAbove(T v,T minimum) { return v inline T clampBelow(T v,T maximum) { return v>maximum?maximum:v; } template inline T sign(T v) { return v<(T)0?(T)-1:(T)1; } template inline T square(T v) { return v*v; } template inline T signedSquare(T v) { return v<(T)0?-v*v:v*v;; } template inline T inDegrees(T angle) { return angle*(T)PI/(T)180.0; } template inline T inRadians(T angle) { return angle; } template inline T DegreesToRadians(T angle) { return angle*(T)PI/(T)180.0; } template inline T RadiansToDegrees(T angle) { return angle*(T)180.0/(T)PI; } #if defined(WIN32) && !defined(__CYGWIN__) && !defined(__MWERKS__) inline bool isNaN(float v) { return _isnan(v)!=0; } inline bool isNaN(double v) { return _isnan(v)!=0; } #else inline bool isNaN(float v) { return isnan(v); } inline bool isNaN(double v) { return isnan(v); } #endif } #endif // __OSG_MATH