2023-10-23 23:02:01 +03:00
|
|
|
#ifndef LIBC_MATH_H
|
|
|
|
#define LIBC_MATH_H
|
|
|
|
|
|
|
|
#include "PR/ultratypes.h"
|
|
|
|
|
|
|
|
#define M_PI 3.14159265358979323846f
|
|
|
|
#define M_DTOR (M_PI / 180.0f)
|
|
|
|
#define M_SQRT2 1.41421356237309504880f
|
|
|
|
#define M_SQRT1_2 0.70710678118654752440f /* 1/sqrt(2) */
|
|
|
|
#define FLT_MAX 340282346638528859811704183484516925440.0f
|
|
|
|
#define SHT_MAX 32767.0f
|
|
|
|
#define SHT_MINV (1.0f / SHT_MAX)
|
|
|
|
|
|
|
|
typedef union {
|
|
|
|
struct {
|
|
|
|
u32 hi;
|
|
|
|
u32 lo;
|
|
|
|
} word;
|
|
|
|
|
|
|
|
f64 d;
|
|
|
|
} du;
|
|
|
|
|
|
|
|
typedef union {
|
|
|
|
u32 i;
|
|
|
|
f32 f;
|
|
|
|
} fu;
|
|
|
|
|
2023-11-08 01:32:09 +03:00
|
|
|
typedef union {
|
|
|
|
float m[4][4];
|
|
|
|
struct {
|
|
|
|
float xx, yx, zx, wx,
|
|
|
|
xy, yy, zy, wy,
|
|
|
|
xz, yz, zz, wz,
|
|
|
|
xw, yw, zw, ww;
|
|
|
|
};
|
|
|
|
// u64 force_struct_alignment;
|
|
|
|
} Matrix;
|
2023-10-23 23:02:01 +03:00
|
|
|
|
|
|
|
extern f32 __libm_qnan_f;
|
|
|
|
|
|
|
|
float fabsf(float f);
|
|
|
|
#pragma intrinsic(fabsf)
|
|
|
|
#ifdef __GNUC__
|
|
|
|
#define fabsf(f) __builtin_fabsf((float)(f))
|
|
|
|
#endif
|
|
|
|
|
|
|
|
double fabs(double f);
|
|
|
|
#pragma intrinsic(fabs)
|
|
|
|
#ifdef __GNUC__
|
|
|
|
#define fabs(f) __builtin_fabs((double)(f))
|
|
|
|
#endif
|
|
|
|
|
|
|
|
float sqrtf(float f);
|
|
|
|
#pragma intrinsic(sqrtf)
|
|
|
|
|
|
|
|
double sqrt(double d);
|
|
|
|
#pragma intrinsic(sqrt)
|
|
|
|
|
|
|
|
#endif
|