2004-03-12 20:47:20 +01:00
|
|
|
/*
|
|
|
|
* Math functions.
|
|
|
|
*
|
|
|
|
* Derived from the mingw header written by Colin Peters.
|
|
|
|
* Modified for Wine use by Hans Leidekker.
|
|
|
|
* This file is in the public domain.
|
|
|
|
*/
|
|
|
|
|
2003-09-02 02:58:21 +02:00
|
|
|
#ifndef __WINE_MATH_H
|
|
|
|
#define __WINE_MATH_H
|
2008-12-11 22:37:34 +01:00
|
|
|
|
|
|
|
#include <crtdefs.h>
|
2004-03-12 20:47:20 +01:00
|
|
|
|
2007-02-20 09:35:41 +01:00
|
|
|
#include <pshpack8.h>
|
|
|
|
|
2003-09-02 02:58:21 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2004-03-12 20:47:20 +01:00
|
|
|
#define _DOMAIN 1 /* domain error in argument */
|
|
|
|
#define _SING 2 /* singularity */
|
|
|
|
#define _OVERFLOW 3 /* range overflow */
|
|
|
|
#define _UNDERFLOW 4 /* range underflow */
|
|
|
|
#define _TLOSS 5 /* total loss of precision */
|
|
|
|
#define _PLOSS 6 /* partial loss of precision */
|
|
|
|
|
2004-06-25 03:19:15 +02:00
|
|
|
#ifndef _EXCEPTION_DEFINED
|
|
|
|
#define _EXCEPTION_DEFINED
|
|
|
|
struct _exception
|
2004-03-12 20:47:20 +01:00
|
|
|
{
|
|
|
|
int type;
|
|
|
|
char *name;
|
|
|
|
double arg1;
|
|
|
|
double arg2;
|
|
|
|
double retval;
|
|
|
|
};
|
2004-06-25 03:19:15 +02:00
|
|
|
#endif /* _EXCEPTION_DEFINED */
|
2004-03-12 20:47:20 +01:00
|
|
|
|
2004-06-25 03:19:15 +02:00
|
|
|
#ifndef _COMPLEX_DEFINED
|
|
|
|
#define _COMPLEX_DEFINED
|
|
|
|
struct _complex
|
2004-03-12 20:47:20 +01:00
|
|
|
{
|
|
|
|
double x; /* Real part */
|
|
|
|
double y; /* Imaginary part */
|
|
|
|
};
|
2004-06-25 03:19:15 +02:00
|
|
|
#endif /* _COMPLEX_DEFINED */
|
2004-03-12 20:47:20 +01:00
|
|
|
|
2008-12-17 14:45:18 +01:00
|
|
|
double __cdecl sin(double);
|
|
|
|
double __cdecl cos(double);
|
|
|
|
double __cdecl tan(double);
|
|
|
|
double __cdecl sinh(double);
|
|
|
|
double __cdecl cosh(double);
|
|
|
|
double __cdecl tanh(double);
|
|
|
|
double __cdecl asin(double);
|
|
|
|
double __cdecl acos(double);
|
|
|
|
double __cdecl atan(double);
|
|
|
|
double __cdecl atan2(double, double);
|
2016-08-30 22:48:42 +02:00
|
|
|
double __cdecl asinh(double);
|
|
|
|
double __cdecl acosh(double);
|
|
|
|
double __cdecl atanh(double);
|
2008-12-17 14:45:18 +01:00
|
|
|
double __cdecl exp(double);
|
|
|
|
double __cdecl log(double);
|
|
|
|
double __cdecl log10(double);
|
|
|
|
double __cdecl pow(double, double);
|
|
|
|
double __cdecl sqrt(double);
|
|
|
|
double __cdecl ceil(double);
|
|
|
|
double __cdecl floor(double);
|
|
|
|
double __cdecl fabs(double);
|
|
|
|
double __cdecl ldexp(double, int);
|
|
|
|
double __cdecl frexp(double, int*);
|
|
|
|
double __cdecl modf(double, double*);
|
|
|
|
double __cdecl fmod(double, double);
|
2004-03-12 20:47:20 +01:00
|
|
|
|
2013-10-21 18:45:27 +02:00
|
|
|
double __cdecl _hypot(double, double);
|
|
|
|
double __cdecl _j0(double);
|
|
|
|
double __cdecl _j1(double);
|
|
|
|
double __cdecl _jn(int, double);
|
|
|
|
double __cdecl _y0(double);
|
|
|
|
double __cdecl _y1(double);
|
|
|
|
double __cdecl _yn(int, double);
|
2004-03-12 20:47:20 +01:00
|
|
|
|
2015-10-18 01:31:05 +02:00
|
|
|
double __cdecl cbrt(double);
|
|
|
|
double __cdecl exp2(double);
|
|
|
|
double __cdecl log2(double);
|
|
|
|
double __cdecl rint(double);
|
|
|
|
double __cdecl round(double);
|
|
|
|
double __cdecl trunc(double);
|
|
|
|
|
|
|
|
float __cdecl cbrtf(float);
|
|
|
|
float __cdecl exp2f(float);
|
|
|
|
float __cdecl log2f(float);
|
|
|
|
float __cdecl rintf(float);
|
|
|
|
float __cdecl roundf(float);
|
|
|
|
float __cdecl truncf(float);
|
|
|
|
|
|
|
|
long __cdecl lrint(double);
|
|
|
|
long __cdecl lrintf(float);
|
|
|
|
long __cdecl lround(double);
|
|
|
|
long __cdecl lroundf(float);
|
|
|
|
|
2015-10-18 01:31:03 +02:00
|
|
|
#if defined(__x86_64__) || defined(__arm__)
|
2010-05-01 16:32:45 +02:00
|
|
|
|
|
|
|
float __cdecl sinf(float);
|
|
|
|
float __cdecl cosf(float);
|
|
|
|
float __cdecl tanf(float);
|
|
|
|
float __cdecl sinhf(float);
|
|
|
|
float __cdecl coshf(float);
|
|
|
|
float __cdecl tanhf(float);
|
|
|
|
float __cdecl asinf(float);
|
|
|
|
float __cdecl acosf(float);
|
|
|
|
float __cdecl atanf(float);
|
|
|
|
float __cdecl atan2f(float, float);
|
2016-08-30 22:48:42 +02:00
|
|
|
float __cdecl asinhf(float);
|
|
|
|
float __cdecl acoshf(float);
|
|
|
|
float __cdecl atanhf(float);
|
2010-05-01 16:32:45 +02:00
|
|
|
float __cdecl expf(float);
|
|
|
|
float __cdecl logf(float);
|
|
|
|
float __cdecl log10f(float);
|
|
|
|
float __cdecl powf(float, float);
|
|
|
|
float __cdecl sqrtf(float);
|
|
|
|
float __cdecl ceilf(float);
|
|
|
|
float __cdecl floorf(float);
|
|
|
|
float __cdecl fabsf(float);
|
|
|
|
float __cdecl ldexpf(float, int);
|
|
|
|
float __cdecl frexpf(float, int*);
|
|
|
|
float __cdecl modff(float, float*);
|
|
|
|
float __cdecl fmodf(float, float);
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
#define sinf(x) ((float)sin((double)(x)))
|
|
|
|
#define cosf(x) ((float)cos((double)(x)))
|
|
|
|
#define tanf(x) ((float)tan((double)(x)))
|
|
|
|
#define sinhf(x) ((float)sinh((double)(x)))
|
|
|
|
#define coshf(x) ((float)cosh((double)(x)))
|
|
|
|
#define tanhf(x) ((float)tanh((double)(x)))
|
|
|
|
#define asinf(x) ((float)asin((double)(x)))
|
|
|
|
#define acosf(x) ((float)acos((double)(x)))
|
|
|
|
#define atanf(x) ((float)atan((double)(x)))
|
|
|
|
#define atan2f(x,y) ((float)atan2((double)(x), (double)(y)))
|
2016-08-30 22:48:42 +02:00
|
|
|
#define asinhf(x) ((float)asinh((double)(x)))
|
|
|
|
#define acoshf(x) ((float)acosh((double)(x)))
|
|
|
|
#define atanhf(x) ((float)atanh((double)(x)))
|
2010-05-01 16:32:45 +02:00
|
|
|
#define expf(x) ((float)exp((double)(x)))
|
|
|
|
#define logf(x) ((float)log((double)(x)))
|
|
|
|
#define log10f(x) ((float)log10((double)(x)))
|
|
|
|
#define powf(x,y) ((float)pow((double)(x), (double)(y)))
|
|
|
|
#define sqrtf(x) ((float)sqrt((double)(x)))
|
|
|
|
#define ceilf(x) ((float)ceil((double)(x)))
|
|
|
|
#define floorf(x) ((float)floor((double)(x)))
|
2015-10-18 01:31:04 +02:00
|
|
|
#define fabsf(x) ((float)fabs((double)(x)))
|
2010-05-01 16:32:45 +02:00
|
|
|
#define frexpf(x) ((float)frexp((double)(x)))
|
|
|
|
#define modff(x,y) ((float)modf((double)(x), (double*)(y)))
|
|
|
|
#define fmodf(x,y) ((float)fmod((double)(x), (double)(y)))
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2011-05-04 16:58:09 +02:00
|
|
|
#define ldexpf(x,y) ((float)ldexp((double)(x),(y)))
|
2010-05-01 16:32:45 +02:00
|
|
|
|
2016-11-22 09:39:50 +01:00
|
|
|
double __cdecl nearbyint(double);
|
|
|
|
float __cdecl nearbyintf(float);
|
|
|
|
|
2013-10-21 18:45:27 +02:00
|
|
|
float __cdecl _hypotf(float, float);
|
2010-05-01 16:32:45 +02:00
|
|
|
|
2008-12-17 14:45:18 +01:00
|
|
|
int __cdecl _matherr(struct _exception*);
|
|
|
|
double __cdecl _cabs(struct _complex);
|
2004-03-12 20:47:20 +01:00
|
|
|
|
2004-04-09 21:02:45 +02:00
|
|
|
#ifndef HUGE_VAL
|
|
|
|
# if defined(__GNUC__) && (__GNUC__ >= 3)
|
|
|
|
# define HUGE_VAL (__extension__ 0x1.0p2047)
|
|
|
|
# else
|
|
|
|
static const union {
|
|
|
|
unsigned char __c[8];
|
|
|
|
double __d;
|
|
|
|
} __huge_val = { { 0, 0, 0, 0, 0, 0, 0xf0, 0x7f } };
|
|
|
|
# define HUGE_VAL (__huge_val.__d)
|
|
|
|
# endif
|
|
|
|
#endif
|
|
|
|
|
2015-09-12 16:13:25 +02:00
|
|
|
#define FP_INFINITE 1
|
|
|
|
#define FP_NAN 2
|
|
|
|
#define FP_NORMAL -1
|
|
|
|
#define FP_SUBNORMAL -2
|
|
|
|
#define FP_ZERO 0
|
|
|
|
|
2016-08-30 22:48:42 +02:00
|
|
|
short __cdecl _dclass(double);
|
|
|
|
#define isfinite(x) (_dclass((double)(x)) <= FP_ZERO)
|
|
|
|
#define isinf(x) (_dclass((double)(x)) == FP_INFINITE)
|
|
|
|
#define isnan(x) (_dclass((double)(x)) == FP_NAN)
|
|
|
|
#define isnormal(x) (_dclass((double)(x)) == FP_NORMAL)
|
|
|
|
|
2003-09-02 02:58:21 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2007-02-20 09:35:41 +01:00
|
|
|
#include <poppack.h>
|
|
|
|
|
2013-01-25 10:36:51 +01:00
|
|
|
#ifdef _USE_MATH_DEFINES
|
|
|
|
#ifndef _MATH_DEFINES_DEFINED
|
|
|
|
#define _MATH_DEFINES_DEFINED
|
|
|
|
#define M_E 2.71828182845904523536
|
|
|
|
#define M_LOG2E 1.44269504088896340736
|
|
|
|
#define M_LOG10E 0.434294481903251827651
|
|
|
|
#define M_LN2 0.693147180559945309417
|
|
|
|
#define M_LN10 2.30258509299404568402
|
|
|
|
#define M_PI 3.14159265358979323846
|
|
|
|
#define M_PI_2 1.57079632679489661923
|
|
|
|
#define M_PI_4 0.785398163397448309616
|
|
|
|
#define M_1_PI 0.318309886183790671538
|
|
|
|
#define M_2_PI 0.636619772367581343076
|
|
|
|
#define M_2_SQRTPI 1.12837916709551257390
|
|
|
|
#define M_SQRT2 1.41421356237309504880
|
|
|
|
#define M_SQRT1_2 0.707106781186547524401
|
|
|
|
#endif /* !_MATH_DEFINES_DEFINED */
|
|
|
|
#endif /* _USE_MATH_DEFINES */
|
|
|
|
|
2013-10-21 18:45:27 +02:00
|
|
|
static inline double hypot( double x, double y ) { return _hypot( x, y ); }
|
|
|
|
static inline double j0( double x ) { return _j0( x ); }
|
|
|
|
static inline double j1( double x ) { return _j1( x ); }
|
|
|
|
static inline double jn( int n, double x ) { return _jn( n, x ); }
|
|
|
|
static inline double y0( double x ) { return _y0( x ); }
|
|
|
|
static inline double y1( double x ) { return _y1( x ); }
|
|
|
|
static inline double yn( int n, double x ) { return _yn( n, x ); }
|
2016-08-30 22:48:42 +02:00
|
|
|
static inline double cabs( struct _complex z ) { return _cabs( z ); }
|
2013-10-21 18:45:27 +02:00
|
|
|
|
|
|
|
static inline float hypotf( float x, float y ) { return _hypotf( x, y ); }
|
|
|
|
|
2003-09-02 02:58:21 +02:00
|
|
|
#endif /* __WINE_MATH_H */
|