#ifndef _MSL_MATH_INTEGRAL_H #define _MSL_MATH_INTEGRAL_H #include #if _MSL_FLOATING_POINT \ && !defined(_MSL_NO_MATH_LIB) \ && defined(__cplusplus) \ && __embedded_cplusplus == 0 \ && defined(__ANSI_OVERLOAD__) \ && defined(_MSL_INTEGRAL_MATH) \ && !(__dest_os == __mac_os && defined(__FP__)) \ && !defined(__m56800E__) _MSL_BEGIN_NAMESPACE_STD #if defined(__MWERKS__) && ! __option (bool) && !defined(_MSL_NO_BOOL) #ifndef bool #ifdef _MSL_BOOL_TYPE #define bool _MSL_BOOL_TYPE #else #define bool unsigned char #endif #define __MSL_MATH_BOOL #endif #ifndef false #define false 0 #define __MSL_MATH_FALSE #endif #ifndef true #define true 1 #define __MSL_MATH_TRUE #endif #endif template struct __msl_is_integral {static const bool value = false;}; #if __option(bool) template <> struct __msl_is_integral {static const bool value = true;}; #endif template <> struct __msl_is_integral {static const bool value = true;}; template <> struct __msl_is_integral {static const bool value = true;}; template <> struct __msl_is_integral {static const bool value = true;}; #if __option(wchar_type) template <> struct __msl_is_integral {static const bool value = true;}; #endif template <> struct __msl_is_integral {static const bool value = true;}; template <> struct __msl_is_integral {static const bool value = true;}; template <> struct __msl_is_integral {static const bool value = true;}; template <> struct __msl_is_integral {static const bool value = true;}; template <> struct __msl_is_integral {static const bool value = true;}; template <> struct __msl_is_integral {static const bool value = true;}; #if _MSL_LONGLONG template <> struct __msl_is_integral {static const bool value = true;}; template <> struct __msl_is_integral {static const bool value = true;}; #endif template struct __msl_is_floating {static const bool value = false;}; template <> struct __msl_is_floating {static const bool value = true;}; template <> struct __msl_is_floating {static const bool value = true;}; template <> struct __msl_is_floating {static const bool value = true;}; template struct __msl_is_arithmetic {static const bool value = __msl_is_integral<_T>::value || __msl_is_floating<_T>::value;}; template struct __msl_enable_if {}; template struct __msl_enable_if {typedef _T type;}; template struct __msl_if {typedef _If type;}; template struct __msl_if {typedef _Then type;}; template class __msl_promote { private: typedef typename __msl_promote<_A1>::type type1; typedef typename __msl_promote<_A2>::type type2; typedef typename __msl_promote<_A3>::type type3; public: typedef __typeof__(type1 () + type2 () + type3 ()) type; }; template class __msl_promote<_A1, void, void> { public: typedef typename __msl_if<__msl_is_arithmetic<_A1>::value, typename __msl_if<__msl_is_integral<_A1>::value, double, _A1>::type, char >::type type; }; template class __msl_promote<_A1, _A2, void> { private: typedef typename __msl_promote<_A1>::type type1; typedef typename __msl_promote<_A2>::type type2; public: typedef __typeof__(type1 () + type2 ()) type; }; template struct __msl_is_same { static const bool value = false; }; template struct __msl_is_same<_A1, _A1> { static const bool value = true; }; #ifdef __MSL_MATH_BOOL #undef bool #undef __MSL_MATH_BOOL #endif #ifdef __MSL_MATH_FALSE #undef false #undef __MSL_MATH_FALSE #endif #ifdef __MSL_MATH_TRUE #undef true #undef __MSL_MATH_TRUE #endif template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL acos(_A1 x) {return acos((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL acosh(_A1 x) {return acosh((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL asin(_A1 x) {return asin((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL asinh(_A1 x) {return asinh((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL atan(_A1 x) {return atan((double)x);} template inline typename __msl_enable_if< __msl_is_arithmetic<_A1>::value && __msl_is_arithmetic<_A2>::value, typename __msl_promote<_A1, _A2>::type >::type _MSL_MATH_CDECL atan2(_A1 x, _A2 y) { typedef typename __msl_promote<_A1, _A2>::type r_type; char test[!(__msl_is_same<_A1, r_type>::value && __msl_is_same<_A2, r_type>::value)]; (void)test; return atan2((r_type)x, (r_type)y); } template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL atanh(_A1 x) {return atanh((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL cbrt(_A1 x) {return cbrt((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL ceil(_A1 x) {return ceil((double)x);} template inline typename __msl_enable_if< __msl_is_arithmetic<_A1>::value && __msl_is_arithmetic<_A2>::value, typename __msl_promote<_A1, _A2>::type >::type _MSL_MATH_CDECL copysign(_A1 x, _A2 y) { typedef typename __msl_promote<_A1, _A2>::type r_type; char test[!(__msl_is_same<_A1, r_type>::value && __msl_is_same<_A2, r_type>::value)]; (void)test; return copysign((r_type)x, (r_type)y); } template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL cos(_A1 x) {return cos((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL cosh(_A1 x) {return cosh((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL erf(_A1 x) {return erf((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL erfc(_A1 x) {return erfc((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL exp(_A1 x) {return exp((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL exp2(_A1 x) {return exp2((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL expm1(_A1 x) {return expm1((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL fabs(_A1 x) {return fabs((double)x);} template inline typename __msl_enable_if< __msl_is_arithmetic<_A1>::value && __msl_is_arithmetic<_A2>::value, typename __msl_promote<_A1, _A2>::type >::type _MSL_MATH_CDECL fdim(_A1 x, _A2 y) { typedef typename __msl_promote<_A1, _A2>::type r_type; char test[!(__msl_is_same<_A1, r_type>::value && __msl_is_same<_A2, r_type>::value)]; (void)test; return fdim((r_type)x, (r_type)y); } template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL floor(_A1 x) {return floor((double)x);} template inline typename __msl_enable_if< __msl_is_arithmetic<_A1>::value && __msl_is_arithmetic<_A2>::value && __msl_is_arithmetic<_A3>::value, typename __msl_promote<_A1, _A2, _A3>::type >::type _MSL_MATH_CDECL fma(_A1 x, _A2 y, _A3 z) { typedef typename __msl_promote<_A1, _A2, _A3>::type r_type; char test[!(__msl_is_same<_A1, r_type>::value && __msl_is_same<_A2, r_type>::value && __msl_is_same<_A3, r_type>::value)]; (void)test; return fma((r_type)x, (r_type)y, (r_type)z); } template inline typename __msl_enable_if< __msl_is_arithmetic<_A1>::value && __msl_is_arithmetic<_A2>::value, typename __msl_promote<_A1, _A2>::type >::type _MSL_MATH_CDECL fmax(_A1 x, _A2 y) { typedef typename __msl_promote<_A1, _A2>::type r_type; char test[!(__msl_is_same<_A1, r_type>::value && __msl_is_same<_A2, r_type>::value)]; (void)test; return fmax((r_type)x, (r_type)y); } template inline typename __msl_enable_if< __msl_is_arithmetic<_A1>::value && __msl_is_arithmetic<_A2>::value, typename __msl_promote<_A1, _A2>::type >::type _MSL_MATH_CDECL fmin(_A1 x, _A2 y) { typedef typename __msl_promote<_A1, _A2>::type r_type; char test[!(__msl_is_same<_A1, r_type>::value && __msl_is_same<_A2, r_type>::value)]; (void)test; return fmin((r_type)x, (r_type)y); } template inline typename __msl_enable_if< __msl_is_arithmetic<_A1>::value && __msl_is_arithmetic<_A2>::value, typename __msl_promote<_A1, _A2>::type >::type _MSL_MATH_CDECL fmod(_A1 x, _A2 y) { typedef typename __msl_promote<_A1, _A2>::type r_type; char test[!(__msl_is_same<_A1, r_type>::value && __msl_is_same<_A2, r_type>::value)]; (void)test; return fmod((r_type)x, (r_type)y); } template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL frexp(_A1 x, int * y) {return frexp((double)x, y);} template inline typename __msl_enable_if< __msl_is_arithmetic<_A1>::value && __msl_is_arithmetic<_A2>::value, typename __msl_promote<_A1, _A2>::type >::type _MSL_MATH_CDECL hypot(_A1 x, _A2 y) { typedef typename __msl_promote<_A1, _A2>::type r_type; char test[!(__msl_is_same<_A1, r_type>::value && __msl_is_same<_A2, r_type>::value)]; (void)test; return hypot((r_type)x, (r_type)y); } template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, int>::type _MSL_MATH_CDECL ilogb(_A1 x) {return ilogb((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL ldexp(_A1 x, int y) {return ldexp((double)x, y);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL lgamma(_A1 x) {return lgamma((double)x);} #if _MSL_LONGLONG template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, long long>::type _MSL_MATH_CDECL llrint(_A1 x) {return llrint((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, long long>::type _MSL_MATH_CDECL llround(_A1 x) {return llround((double)x);} #endif template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL log(_A1 x) {return log((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL log10(_A1 x) {return log10((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL log1p(_A1 x) {return log1p((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL log2(_A1 x) {return log2((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL logb(_A1 x) {return logb((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, long>::type _MSL_MATH_CDECL lrint(_A1 x) {return lrint((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, long>::type _MSL_MATH_CDECL lround(_A1 x) {return lround((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL modf(_A1 x, double * y) {return modf((double)x, y);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL nearbyint(_A1 x) {return nearbyint((double)x);} template inline typename __msl_enable_if< __msl_is_arithmetic<_A1>::value && __msl_is_arithmetic<_A2>::value, typename __msl_promote<_A1, _A2>::type >::type _MSL_MATH_CDECL nextafter(_A1 x, _A2 y) { typedef typename __msl_promote<_A1, _A2>::type r_type; char test[!(__msl_is_same<_A1, r_type>::value && __msl_is_same<_A2, r_type>::value)]; (void)test; return nextafter((r_type)x, (r_type)y); } template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL nexttoward(_A1 x, long double y) {return nexttoward((double)x, y);} template inline typename __msl_enable_if< __msl_is_arithmetic<_A1>::value && __msl_is_arithmetic<_A2>::value, typename __msl_promote<_A1, _A2>::type >::type _MSL_MATH_CDECL pow(_A1 x, _A2 y) { typedef typename __msl_promote<_A1, _A2>::type r_type; char test[!(__msl_is_same<_A1, r_type>::value && __msl_is_same<_A2, r_type>::value)]; (void)test; return pow((r_type)x, (r_type)y); } template inline typename __msl_enable_if< __msl_is_arithmetic<_A1>::value && __msl_is_arithmetic<_A2>::value, typename __msl_promote<_A1, _A2>::type >::type _MSL_MATH_CDECL remainder(_A1 x, _A2 y) { typedef typename __msl_promote<_A1, _A2>::type r_type; char test[!(__msl_is_same<_A1, r_type>::value && __msl_is_same<_A2, r_type>::value)]; (void)test; return remainder((r_type)x, (r_type)y); } template inline typename __msl_enable_if< __msl_is_arithmetic<_A1>::value && __msl_is_arithmetic<_A2>::value, typename __msl_promote<_A1, _A2>::type >::type _MSL_MATH_CDECL remquo(_A1 x, _A2 y, int * z) { typedef typename __msl_promote<_A1, _A2>::type r_type; char test[!(__msl_is_same<_A1, r_type>::value && __msl_is_same<_A2, r_type>::value)]; (void)test; return remquo((r_type)x, (r_type)y, z); } template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL rint(_A1 x) {return rint((double)x);} #if !_MSL_USES_SUN_MATH_LIB template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL round(_A1 x) {return round((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL scalbln(_A1 x, long y) {return scalbln((double)x, y);} #endif template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL scalbn(_A1 x, int y) {return scalbn((double)x, y);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL sin(_A1 x) {return sin((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL sinh(_A1 x) {return sinh((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL sqrt(_A1 x) {return sqrt((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL tan(_A1 x) {return tan((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL tanh(_A1 x) {return tanh((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL tgamma(_A1 x) {return tgamma((double)x);} template inline typename __msl_enable_if<__msl_is_integral<_A1>::value, double>::type _MSL_MATH_CDECL trunc(_A1 x) {return trunc((double)x);} _MSL_END_NAMESPACE_STD #endif #endif