2023-08-08 18:38:38 +00:00
|
|
|
/* math.h: Floating-point arithmetic functions. */
|
|
|
|
|
|
|
|
#ifndef _MATH_H
|
|
|
|
#define _MATH_H
|
|
|
|
|
|
|
|
typedef float float_t;
|
|
|
|
typedef double double_t;
|
|
|
|
|
|
|
|
#define FP_NAN 0
|
|
|
|
#define FP_INFINITE 1
|
|
|
|
#define FP_ZERO 2
|
|
|
|
#define FP_SUBNORMAL 3
|
|
|
|
#define FP_NORMAL 4
|
|
|
|
#define fpclassify(x) __builtin_fpclassify(FP_NAN, FP_INFINITE, FP_ZERO, FP_SUBNORMAL, FP_ZERO, x)
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C"
|
|
|
|
{
|
|
|
|
#endif
|
|
|
|
|
|
|
|
double cos(double val);
|
|
|
|
float cosf(float val);
|
|
|
|
long double cosl(long double val);
|
|
|
|
double sin(double val);
|
|
|
|
float sinf(float val);
|
|
|
|
long double sinl(long double val);
|
|
|
|
double tan(double val);
|
|
|
|
float tanf(float val);
|
|
|
|
long double tanl(long double val);
|
|
|
|
double acos(double val);
|
|
|
|
float acosf(float val);
|
|
|
|
long double acosl(long double val);
|
|
|
|
double asin(double val);
|
|
|
|
float asinf(float val);
|
|
|
|
long double asinl(long double val);
|
|
|
|
double atan(double val);
|
|
|
|
float atanf(float val);
|
|
|
|
long double atanl(long double val);
|
|
|
|
double cosh(double val);
|
|
|
|
float coshf(float val);
|
|
|
|
long double coshl(long double val);
|
|
|
|
double sinh(double val);
|
|
|
|
float sinhf(float val);
|
|
|
|
long double sinhl(long double val);
|
|
|
|
double tanh(double val);
|
|
|
|
float tanhf(float val);
|
|
|
|
long double tanhl(long double val);
|
|
|
|
double log(double val);
|
|
|
|
float logf(float val);
|
|
|
|
long double logl(long double val);
|
|
|
|
double exp(double val);
|
|
|
|
float expf(float val);
|
|
|
|
long double expl(long double val);
|
|
|
|
double sqrt(double val);
|
|
|
|
float sqrtf(float val);
|
|
|
|
long double sqrtl(long double val);
|
|
|
|
double fabs(double val);
|
|
|
|
float fabsf(float val);
|
|
|
|
long double fabsl(long double val);
|
|
|
|
double floor(double val);
|
|
|
|
float floorf(float val);
|
|
|
|
long double floorl(long double val);
|
|
|
|
double ceil(double val);
|
|
|
|
float ceilf(float val);
|
|
|
|
long double ceill(long double val);
|
|
|
|
double log10(double val);
|
|
|
|
float log10f(float val);
|
|
|
|
long double log10l(long double val);
|
|
|
|
double fmod(double val1, double val2);
|
|
|
|
float fmodf(float val1, float val2);
|
|
|
|
long double fmodl(long double val1, long double val2);
|
|
|
|
double pow(double val1, double val2);
|
|
|
|
float powf(float val1, float val2);
|
|
|
|
long double powl(long double val1, long double val2);
|
|
|
|
double atan2(double val1, double val2);
|
|
|
|
float atan2f(float val1, float val2);
|
|
|
|
long double atan2l(long double val1, long double val2);
|
|
|
|
double frexp(double val1, int* val2);
|
|
|
|
float frexpf(float val1, int* val2);
|
|
|
|
long double frexpl(long double val1, int* val2);
|
|
|
|
double ldexp(double val1, int val2);
|
|
|
|
float ldexpf(float val1, int val2);
|
|
|
|
long double ldexpl(long double val1, int val2);
|
|
|
|
double modf(double val1, double* val2);
|
|
|
|
float modff(float val1, float* val2);
|
|
|
|
long double modfl(long double val1, long double* val2);
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|