this repo has no description
at fixPythonPipStalling 646 lines 24 kB view raw
1/* 2 * Copyright (c) 2002 Apple Computer, Inc. All rights reserved. 3 * 4 * @APPLE_LICENSE_HEADER_START@ 5 * 6 * The contents of this file constitute Original Code as defined in and 7 * are subject to the Apple Public Source License Version 1.1 (the 8 * "License"). You may not use this file except in compliance with the 9 * License. Please obtain a copy of the License at 10 * http://www.apple.com/publicsource and read it before using this file. 11 * 12 * This Original Code and all software distributed under the License are 13 * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER 14 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, 15 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, 16 * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the 17 * License for the specific language governing rights and limitations 18 * under the License. 19 * 20 * @APPLE_LICENSE_HEADER_END@ 21 */ 22 23/******************************************************************************* 24* * 25* File: math.h * 26* * 27* Contains: typedefs, prototypes, and macros germane to C99 floating point.* 28* * 29*******************************************************************************/ 30#ifndef __MATH__ 31#define __MATH__ 32 33#include <sys/cdefs.h> /* For definition of __DARWIN_UNIX03 et al */ 34 35#ifdef __cplusplus 36extern "C" { 37#endif 38 39/****************************************************************************** 40* Floating point data types * 41******************************************************************************/ 42 43/* Define float_t and double_t per C standard, ISO/IEC 9899:1999 7.12 2, 44 taking advantage of GCC's __FLT_EVAL_METHOD__ (which a compiler may 45 define anytime and GCC does) that shadows FLT_EVAL_METHOD (which a compiler 46 must and may define only in float.h). 47*/ 48#if __FLT_EVAL_METHOD__ == 0 49 typedef float float_t; 50 typedef double double_t; 51#elif __FLT_EVAL_METHOD__ == 1 52 typedef double float_t; 53 typedef double double_t; 54#elif __FLT_EVAL_METHOD__ == 2 || __FLT_EVAL_METHOD__ == -1 55 typedef long double float_t; 56 typedef long double double_t; 57#else /* __FLT_EVAL_METHOD__ */ 58 #error "Unsupported value of __FLT_EVAL_METHOD__." 59#endif /* __FLT_EVAL_METHOD__ */ 60 61 62#if defined(__GNUC__) 63 #define HUGE_VAL __builtin_huge_val() 64 #define HUGE_VALF __builtin_huge_valf() 65 #define HUGE_VALL __builtin_huge_vall() 66 #define NAN __builtin_nanf("0x7fc00000") /* Constant expression, can be used as initializer. */ 67 #define __MATH_H_ALWAYS_INLINE__ __attribute__ ((always_inline)) 68#else 69 #define HUGE_VAL 1e500 70 #define HUGE_VALF 1e50f 71 #define HUGE_VALL 1e5000L 72 #define NAN __nan( ) 73 #define __MATH_H_ALWAYS_INLINE__ 74#endif 75 76#define INFINITY HUGE_VALF 77 78 79/****************************************************************************** 80* Taxonomy of floating point data types * 81******************************************************************************/ 82 83#define FP_NAN 1 84#define FP_INFINITE 2 85#define FP_ZERO 3 86#define FP_NORMAL 4 87#define FP_SUBNORMAL 5 88#define FP_SUPERNORMAL 6 /* meaningful only on PowerPC */ 89 90/* fma() *function call* is more costly than equivalent (in-line) multiply and add operations */ 91/* For single and double precision, the cost isn't too bad, because we can fall back on higher */ 92/* precision hardware, with the necessary range to handle infinite precision products. However, */ 93/* expect the long double fma to be at least an order of magnitude slower than a simple multiply */ 94/* and an add. */ 95#undef FP_FAST_FMA 96#undef FP_FAST_FMAF 97#undef FP_FAST_FMAL 98 99/* The values returned by `ilogb' for 0 and NaN respectively. */ 100#define FP_ILOGB0 (-2147483647 - 1) 101#define FP_ILOGBNAN (-2147483647 - 1) 102 103/* Bitmasks for the math_errhandling macro. */ 104#define MATH_ERRNO 1 /* errno set by math functions. */ 105#define MATH_ERREXCEPT 2 /* Exceptions raised by math functions. */ 106 107#define math_errhandling (__math_errhandling()) 108extern int __math_errhandling ( void ); 109 110/******************************************************************************** 111* * 112* Inquiry macros * 113* * 114* fpclassify Returns one of the FP_* values. * 115* isnormal Non-zero if and only if the argument x is normalized. * 116* isfinite Non-zero if and only if the argument x is finite. * 117* isnan Non-zero if and only if the argument x is a NaN. * 118* signbit Non-zero if and only if the sign of the argument x is * 119* negative. This includes, NaNs, infinities and zeros. * 120* * 121********************************************************************************/ 122 123#define fpclassify(x) \ 124 ( sizeof (x) == sizeof(float ) ? __fpclassifyf((float)(x)) \ 125 : sizeof (x) == sizeof(double) ? __fpclassifyd((double)(x)) \ 126 : __fpclassify ((long double)(x))) 127 128extern int __fpclassifyf(float ); 129extern int __fpclassifyd(double ); 130extern int __fpclassify (long double); 131 132#if defined( __GNUC__ ) && 0 == __FINITE_MATH_ONLY__ 133 /* Yes, that's right. You only get the fast iswhatever() macros if you do NOT turn on -ffast-math. */ 134 /* These inline functions require the compiler to be compiling to standard in order to work. */ 135 /* -ffast-math, among other things, implies that NaNs don't happen. The compiler can in that case */ 136 /* optimize x != x to be false always, wheras it would be true for NaNs. That breaks __inline_isnan() */ 137 /* below. */ 138 #define isnormal(x) \ 139 ( sizeof (x) == sizeof(float ) ? __inline_isnormalf((float)(x)) \ 140 : sizeof (x) == sizeof(double) ? __inline_isnormald((double)(x)) \ 141 : __inline_isnormal ((long double)(x))) 142 143 #define isfinite(x) \ 144 ( sizeof (x) == sizeof(float ) ? __inline_isfinitef((float)(x)) \ 145 : sizeof (x) == sizeof(double) ? __inline_isfinited((double)(x)) \ 146 : __inline_isfinite ((long double)(x))) 147 148 #define isinf(x) \ 149 ( sizeof (x) == sizeof(float ) ? __inline_isinff((float)(x)) \ 150 : sizeof (x) == sizeof(double) ? __inline_isinfd((double)(x)) \ 151 : __inline_isinf ((long double)(x))) 152 153 #define isnan(x) \ 154 ( sizeof (x) == sizeof(float ) ? __inline_isnanf((float)(x)) \ 155 : sizeof (x) == sizeof(double) ? __inline_isnand((double)(x)) \ 156 : __inline_isnan ((long double)(x))) 157 158 #define signbit(x) \ 159 ( sizeof (x) == sizeof(float ) ? __inline_signbitf((float)(x)) \ 160 : sizeof (x) == sizeof(double) ? __inline_signbitd((double)(x)) \ 161 : __inline_signbit((long double)(x))) 162 163 static __inline__ int __inline_isfinitef (float ) __MATH_H_ALWAYS_INLINE__; 164 static __inline__ int __inline_isfinited (double ) __MATH_H_ALWAYS_INLINE__; 165 static __inline__ int __inline_isfinite (long double) __MATH_H_ALWAYS_INLINE__; 166 static __inline__ int __inline_isinff (float ) __MATH_H_ALWAYS_INLINE__; 167 static __inline__ int __inline_isinfd (double ) __MATH_H_ALWAYS_INLINE__; 168 static __inline__ int __inline_isinf (long double) __MATH_H_ALWAYS_INLINE__; 169 static __inline__ int __inline_isnanf (float ) __MATH_H_ALWAYS_INLINE__; 170 static __inline__ int __inline_isnand (double ) __MATH_H_ALWAYS_INLINE__; 171 static __inline__ int __inline_isnan (long double) __MATH_H_ALWAYS_INLINE__; 172 static __inline__ int __inline_isnormalf (float ) __MATH_H_ALWAYS_INLINE__; 173 static __inline__ int __inline_isnormald (double ) __MATH_H_ALWAYS_INLINE__; 174 static __inline__ int __inline_isnormal (long double) __MATH_H_ALWAYS_INLINE__; 175 static __inline__ int __inline_signbitf (float ) __MATH_H_ALWAYS_INLINE__; 176 static __inline__ int __inline_signbitd (double ) __MATH_H_ALWAYS_INLINE__; 177 static __inline__ int __inline_signbit (long double) __MATH_H_ALWAYS_INLINE__; 178 179 static __inline__ int __inline_isinff( float __x ) { return __builtin_fabsf(__x) == __builtin_inff(); } 180 static __inline__ int __inline_isinfd( double __x ) { return __builtin_fabs(__x) == __builtin_inf(); } 181 static __inline__ int __inline_isinf( long double __x ) { return __builtin_fabsl(__x) == __builtin_infl(); } 182 static __inline__ int __inline_isfinitef( float __x ) { return __x == __x && __builtin_fabsf(__x) != __builtin_inff(); } 183 static __inline__ int __inline_isfinited( double __x ) { return __x == __x && __builtin_fabs(__x) != __builtin_inf(); } 184 static __inline__ int __inline_isfinite( long double __x ) { return __x == __x && __builtin_fabsl(__x) != __builtin_infl(); } 185 static __inline__ int __inline_isnanf( float __x ) { return __x != __x; } 186 static __inline__ int __inline_isnand( double __x ) { return __x != __x; } 187 static __inline__ int __inline_isnan( long double __x ) { return __x != __x; } 188 static __inline__ int __inline_signbitf( float __x ) { union{ float __f; unsigned int __u; }__u; __u.__f = __x; return (int)(__u.__u >> 31); } 189 static __inline__ int __inline_signbitd( double __x ) { union{ double __f; unsigned int __u[2]; }__u; __u.__f = __x; return (int)(__u.__u[1] >> 31); } 190 static __inline__ int __inline_signbit( long double __x ){ union{ long double __ld; struct{ unsigned int __m[2]; short __sexp; }__p; }__u; __u.__ld = __x; return (int) (((unsigned short) __u.__p.__sexp) >> 15); } 191 static __inline__ int __inline_isnormalf( float __x ) { float fabsf = __builtin_fabsf(__x); if( __x != __x ) return 0; return fabsf < __builtin_inff() && fabsf >= __FLT_MIN__; } 192 static __inline__ int __inline_isnormald( double __x ) { double fabsf = __builtin_fabs(__x); if( __x != __x ) return 0; return fabsf < __builtin_inf() && fabsf >= __DBL_MIN__; } 193 static __inline__ int __inline_isnormal( long double __x ) { long double fabsf = __builtin_fabsl(__x); if( __x != __x ) return 0; return fabsf < __builtin_infl() && fabsf >= __LDBL_MIN__; } 194 195#else 196 197 #define isnormal(x) \ 198 ( sizeof (x) == sizeof(float ) ? __isnormalf((float)(x)) \ 199 : sizeof (x) == sizeof(double) ? __isnormald((double)(x)) \ 200 : __isnormal ((long double)(x))) 201 202 #define isfinite(x) \ 203 ( sizeof (x) == sizeof(float ) ? __isfinitef((float)(x)) \ 204 : sizeof (x) == sizeof(double) ? __isfinited((double)(x)) \ 205 : __isfinite ((long double)(x))) 206 207 #define isinf(x) \ 208 ( sizeof (x) == sizeof(float ) ? __isinff((float)(x)) \ 209 : sizeof (x) == sizeof(double) ? __isinfd((double)(x)) \ 210 : __isinf ((long double)(x))) 211 212 #define isnan(x) \ 213 ( sizeof (x) == sizeof(float ) ? __isnanf((float)(x)) \ 214 : sizeof (x) == sizeof(double) ? __isnand((double)(x)) \ 215 : __isnan ((long double)(x))) 216 217 #define signbit(x) \ 218 ( sizeof (x) == sizeof(float ) ? __signbitf((float)(x)) \ 219 : sizeof (x) == sizeof(double) ? __signbitd((double)(x)) \ 220 : __signbitl((long double)(x))) 221 222 223 extern int __isnormalf (float ); 224 extern int __isnormald (double ); 225 extern int __isnormal (long double); 226 227 extern int __isfinitef (float ); 228 extern int __isfinited (double ); 229 extern int __isfinite (long double); 230 231 extern int __isinff (float ); 232 extern int __isinfd (double ); 233 extern int __isinf (long double); 234 235 extern int __isnanf (float ); 236 extern int __isnand (double ); 237 extern int __isnan (long double); 238 239 extern int __signbitf (float ); 240 extern int __signbitd (double ); 241 extern int __signbitl (long double); 242 243#endif 244 245 246 247/******************************************************************************** 248* * 249* Math Functions * 250* * 251********************************************************************************/ 252 253extern double acos( double ); 254extern float acosf( float ); 255 256extern double asin( double ); 257extern float asinf( float ); 258 259extern double atan( double ); 260extern float atanf( float ); 261 262extern double atan2( double, double ); 263extern float atan2f( float, float ); 264 265extern double cos( double ); 266extern float cosf( float ); 267 268extern double sin( double ); 269extern float sinf( float ); 270 271extern double tan( double ); 272extern float tanf( float ); 273 274extern double acosh( double ); 275extern float acoshf( float ); 276 277extern double asinh( double ); 278extern float asinhf( float ); 279 280extern double atanh( double ); 281extern float atanhf( float ); 282 283extern double cosh( double ); 284extern float coshf( float ); 285 286extern double sinh( double ); 287extern float sinhf( float ); 288 289extern double tanh( double ); 290extern float tanhf( float ); 291 292extern double exp ( double ); 293extern float expf ( float ); 294 295extern double exp2 ( double ); 296extern float exp2f ( float ); 297 298extern double expm1 ( double ); 299extern float expm1f ( float ); 300 301extern double log ( double ); 302extern float logf ( float ); 303 304extern double log10 ( double ); 305extern float log10f ( float ); 306 307extern double log2 ( double ); 308extern float log2f ( float ); 309 310extern double log1p ( double ); 311extern float log1pf ( float ); 312 313extern double logb ( double ); 314extern float logbf ( float ); 315 316extern double modf ( double, double * ); 317extern float modff ( float, float * ); 318 319extern double ldexp ( double, int ); 320extern float ldexpf ( float, int ); 321 322extern double frexp ( double, int * ); 323extern float frexpf ( float, int * ); 324 325extern int ilogb ( double ); 326extern int ilogbf ( float ); 327 328extern double scalbn ( double, int ); 329extern float scalbnf ( float, int ); 330 331extern double scalbln ( double, long int ); 332extern float scalblnf ( float, long int ); 333 334extern double fabs( double ); 335extern float fabsf( float ); 336 337extern double cbrt( double ); 338extern float cbrtf( float ); 339 340extern double hypot ( double, double ); 341extern float hypotf ( float, float ); 342 343extern double pow ( double, double ); 344extern float powf ( float, float ); 345 346extern double sqrt( double ); 347extern float sqrtf( float ); 348 349extern double erf( double ); 350extern float erff( float ); 351 352extern double erfc( double ); 353extern float erfcf( float ); 354 355/* lgamma and lgammaf are not thread-safe. The thread-safe variants 356 * lgamma_r and lgammaf_r are available on OS X 10.6 and later. 357 * 358 * To use the thread-safe variants, you must define the _REENTRANT symbol. 359 */ 360extern double lgamma( double ); 361extern float lgammaf( float ); 362 363extern double tgamma( double ); 364extern float tgammaf( float ); 365 366extern double ceil ( double ); 367extern float ceilf ( float ); 368 369extern double floor ( double ); 370extern float floorf ( float ); 371 372extern double nearbyint ( double ); 373extern float nearbyintf ( float ); 374 375extern double rint ( double ); 376extern float rintf ( float ); 377 378extern long int lrint ( double ); 379extern long int lrintf ( float ); 380 381extern double round ( double ); 382extern float roundf ( float ); 383 384extern long int lround ( double ); 385extern long int lroundf ( float ); 386 387#if !(__DARWIN_NO_LONG_LONG) 388 /* long long is not part of C90. Make sure you are passing -std=c99 or -std=gnu99 or better if you need this. */ 389 extern long long int llrint ( double ); 390 extern long long int llrintf ( float ); 391 extern long long int llround ( double ); 392 extern long long int llroundf ( float ); 393#endif /* !(__DARWIN_NO_LONG_LONG) */ 394 395extern double trunc ( double ); 396extern float truncf ( float ); 397 398extern double fmod ( double, double ); 399extern float fmodf ( float, float ); 400 401extern double remainder ( double, double ); 402extern float remainderf ( float, float ); 403 404extern double remquo ( double, double, int * ); 405extern float remquof ( float, float, int * ); 406 407extern double copysign ( double, double ); 408extern float copysignf ( float, float ); 409 410extern double nan( const char * ); 411extern float nanf( const char * ); 412 413extern double nextafter ( double, double ); 414extern float nextafterf ( float, float ); 415 416extern double fdim ( double, double ); 417extern float fdimf ( float, float ); 418 419extern double fmax ( double, double ); 420extern float fmaxf ( float, float ); 421 422extern double fmin ( double, double ); 423extern float fminf ( float, float ); 424 425extern double fma ( double, double, double ); 426extern float fmaf ( float, float, float ); 427 428extern long double acosl(long double); 429extern long double asinl(long double); 430extern long double atanl(long double); 431extern long double atan2l(long double, long double); 432extern long double cosl(long double); 433extern long double sinl(long double); 434extern long double tanl(long double); 435extern long double acoshl(long double); 436extern long double asinhl(long double); 437extern long double atanhl(long double); 438extern long double coshl(long double); 439extern long double sinhl(long double); 440extern long double tanhl(long double); 441extern long double expl(long double); 442extern long double exp2l(long double); 443extern long double expm1l(long double); 444extern long double logl(long double); 445extern long double log10l(long double); 446extern long double log2l(long double); 447extern long double log1pl(long double); 448extern long double logbl(long double); 449extern long double modfl(long double, long double *); 450extern long double ldexpl(long double, int); 451extern long double frexpl(long double, int *); 452extern int ilogbl(long double); 453extern long double scalbnl(long double, int); 454extern long double scalblnl(long double, long int); 455extern long double fabsl(long double); 456extern long double cbrtl(long double); 457extern long double hypotl(long double, long double); 458extern long double powl(long double, long double); 459extern long double sqrtl(long double); 460extern long double erfl(long double); 461extern long double erfcl(long double); 462 463/* lgammal is not thread-safe. 464 * The thread-safe variant lgammal_r is available on OS X 10.6 and later. 465 * 466 * To use the thread-safe variant, you must define the _REENTRANT symbol. 467 */ 468extern long double lgammal(long double); 469 470extern long double tgammal(long double); 471extern long double ceill(long double); 472extern long double floorl(long double); 473extern long double nearbyintl(long double); 474extern long double rintl(long double); 475extern long int lrintl(long double); 476extern long double roundl(long double); 477extern long int lroundl(long double); 478 479#if !(__DARWIN_NO_LONG_LONG) 480 /* long long is not part of C90. Make sure you are passing -std=c99 or -std=gnu99 or better if you need this. */ 481 extern long long int llrintl(long double); 482 extern long long int llroundl(long double); 483#endif /* !(__DARWIN_NO_LONG_LONG) */ 484 485extern long double truncl(long double); 486extern long double fmodl(long double, long double); 487extern long double remainderl(long double, long double); 488extern long double remquol(long double, long double, int *); 489extern long double copysignl(long double, long double); 490extern long double nanl(const char *); 491extern long double nextafterl(long double, long double); 492extern double nexttoward(double, long double); 493extern float nexttowardf(float, long double); 494extern long double nexttowardl(long double, long double); 495extern long double fdiml(long double, long double); 496extern long double fmaxl(long double, long double); 497extern long double fminl(long double, long double); 498extern long double fmal(long double, long double, long double); 499 500#define isgreater(x, y) __builtin_isgreater ((x),(y)) 501#define isgreaterequal(x, y) __builtin_isgreaterequal ((x),(y)) 502#define isless(x, y) __builtin_isless ((x),(y)) 503#define islessequal(x, y) __builtin_islessequal ((x),(y)) 504#define islessgreater(x, y) __builtin_islessgreater ((x),(y)) 505#define isunordered(x, y) __builtin_isunordered ((x),(y)) 506 507extern double __inf( void ); 508extern float __inff( void ); 509extern long double __infl( void ); 510extern float __nan( void ); /* 10.3 (and later) must retain in ABI for backward compatability */ 511 512#if !defined(_ANSI_SOURCE) 513extern double j0 ( double ); 514 515extern double j1 ( double ); 516 517extern double jn ( int, double ); 518 519extern double y0 ( double ); 520 521extern double y1 ( double ); 522 523extern double yn ( int, double ); 524 525extern double scalb ( double, double ); 526 527 528#define M_E 2.71828182845904523536028747135266250 /* e */ 529#define M_LOG2E 1.44269504088896340735992468100189214 /* log 2e */ 530#define M_LOG10E 0.434294481903251827651128918916605082 /* log 10e */ 531#define M_LN2 0.693147180559945309417232121458176568 /* log e2 */ 532#define M_LN10 2.30258509299404568401799145468436421 /* log e10 */ 533#define M_PI 3.14159265358979323846264338327950288 /* pi */ 534#define M_PI_2 1.57079632679489661923132169163975144 /* pi/2 */ 535#define M_PI_4 0.785398163397448309615660845819875721 /* pi/4 */ 536#define M_1_PI 0.318309886183790671537767526745028724 /* 1/pi */ 537#define M_2_PI 0.636619772367581343075535053490057448 /* 2/pi */ 538#define M_2_SQRTPI 1.12837916709551257389615890312154517 /* 2/sqrt(pi) */ 539#define M_SQRT2 1.41421356237309504880168872420969808 /* sqrt(2) */ 540#define M_SQRT1_2 0.707106781186547524400844362104849039 /* 1/sqrt(2) */ 541 542#define MAXFLOAT ((float)3.40282346638528860e+38) 543extern int signgam; /* required for unix 2003 */ 544 545 546#endif /* !defined(_ANSI_SOURCE) */ 547 548#if !defined(__NOEXTENSIONS__) && (!defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE)) 549#define __WANT_EXTENSIONS__ 550#endif 551 552#ifdef __WANT_EXTENSIONS__ 553 554#define FP_SNAN FP_NAN 555#define FP_QNAN FP_NAN 556 557/* Legacy API: please use C99 lrint() instead. */ 558extern long int rinttol ( double ); 559 560/* Legacy API: please use C99 lround() instead. */ 561extern long int roundtol ( double ); 562 563/* 564 * XOPEN/SVID 565 */ 566#if !defined(_ANSI_SOURCE) && (!defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE)) 567#if (!defined(_XOPEN_SOURCE) || defined(_DARWIN_C_SOURCE)) 568#if !defined(__cplusplus) 569/* used by matherr below */ 570struct exception { 571 int type; 572 char *name; 573 double arg1; 574 double arg2; 575 double retval; 576}; 577#endif 578 579#define HUGE MAXFLOAT 580 581/* 582 * set X_TLOSS = pi*2**52, which is possibly defined in <values.h> 583 * (one may replace the following line by "#include <values.h>") 584 */ 585 586#define X_TLOSS 1.41484755040568800000e+16 587 588#define DOMAIN 1 589#define SING 2 590#define OVERFLOW 3 591#define UNDERFLOW 4 592#define TLOSS 5 593#define PLOSS 6 594 595#endif /* (!_XOPEN_SOURCE || _DARWIN_C_SOURCE) */ 596#endif /* !_ANSI_SOURCE && (!_POSIX_C_SOURCE || _DARWIN_C_SOURCE) */ 597 598#if !defined( __STRICT_ANSI__) && !defined(_ANSI_SOURCE) && (!defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE)) 599 600/* Legacy API: please use C99 isfinite() instead. */ 601extern int finite ( double ); 602 603/* Legacy API: please use C99 tgamma() instead. */ 604extern double gamma ( double ); 605 606#if (!defined(_XOPEN_SOURCE) || defined(_DARWIN_C_SOURCE)) 607 608#if !defined(__cplusplus) 609extern int matherr ( struct exception * ); 610#endif 611 612/* 613 * IEEE Test Vector 614 */ 615extern double significand ( double ); 616 617/* 618 * BSD math library entry points 619 */ 620 621/* Legacy API: please use C99 remainder() instead. */ 622extern double drem ( double, double ); 623 624/* 625 * Reentrant version of lgamma; passes signgam back by reference 626 * as the second argument; user must allocate space for signgam. 627 */ 628 629#ifdef _REENTRANT 630#include <AvailabilityMacros.h> 631 // Available on OS X 10.6 and later. 632 extern float lgammaf_r ( float, int * ) AVAILABLE_MAC_OS_X_VERSION_10_6_AND_LATER; 633 extern double lgamma_r ( double, int * ) AVAILABLE_MAC_OS_X_VERSION_10_6_AND_LATER; 634 extern long double lgammal_r ( long double, int * ) AVAILABLE_MAC_OS_X_VERSION_10_6_AND_LATER; 635#endif /* _REENTRANT */ 636 637#endif /* (!_XOPEN_SOURCE || _DARWIN_C_SOURCE) */ 638#endif /* !_ANSI_SOURCE && (!_POSIX_C_SOURCE || _DARWIN_C_SOURCE) */ 639 640#endif /* __WANT_EXTENSIONS__ */ 641 642#ifdef __cplusplus 643} 644#endif 645 646#endif /* __MATH__ */