pikapython/package/PikaMath/PikaMath_Math.c

83 lines
2.3 KiB
C
Raw Normal View History

2022-06-12 10:44:32 +08:00
#include "PikaMath_Math.h"
#include <math.h>
#define PI (3.141592653589793115997963468544185161590576171875l)
2023-07-20 16:12:33 +08:00
#define E (2.718281828459045090795598298427648842334747314453125l)
void PikaMath_Math___init__(PikaObj* self) {
2022-06-12 10:44:32 +08:00
obj_setFloat(self, "pi", PI);
2023-07-20 16:12:33 +08:00
obj_setFloat(self, "e", E);
2022-06-12 10:44:32 +08:00
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_acos(PikaObj* self, pika_float x) {
2022-06-12 10:44:32 +08:00
return acos(x);
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_asin(PikaObj* self, pika_float x) {
2022-06-12 10:44:32 +08:00
return asin(x);
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_atan(PikaObj* self, pika_float x) {
2022-06-12 10:44:32 +08:00
return atan(x);
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_atan2(PikaObj* self, pika_float x, pika_float y) {
return atan2(x, y);
2022-06-12 10:44:32 +08:00
}
2023-07-20 16:12:33 +08:00
int PikaMath_Math_ceil(PikaObj* self, pika_float x) {
2022-06-12 10:44:32 +08:00
return ceil(x);
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_cos(PikaObj* self, pika_float x) {
2022-06-12 10:44:32 +08:00
return cos(x);
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_cosh(PikaObj* self, pika_float x) {
2022-06-12 10:44:32 +08:00
return cosh(x);
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_degrees(PikaObj* self, pika_float x) {
return x * 180.0 / PI;
2022-06-12 10:44:32 +08:00
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_exp(PikaObj* self, pika_float x) {
2022-06-12 10:44:32 +08:00
return exp(x);
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_fabs(PikaObj* self, pika_float x) {
2022-06-12 10:44:32 +08:00
return fabs(x);
}
2023-07-20 16:12:33 +08:00
int PikaMath_Math_floor(PikaObj* self, pika_float x) {
2022-06-12 10:44:32 +08:00
return floor(x);
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_fmod(PikaObj* self, pika_float x, pika_float y) {
return fmod(x, y);
2022-06-12 10:44:32 +08:00
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_log(PikaObj* self, pika_float x) {
2022-06-12 10:44:32 +08:00
return log(x);
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_log10(PikaObj* self, pika_float x) {
2022-06-12 10:44:32 +08:00
return log10(x);
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_log2(PikaObj* self, pika_float x) {
2022-06-12 10:44:32 +08:00
return log2(x);
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_pow(PikaObj* self, pika_float x, pika_float y) {
return pow(x, y);
2022-06-12 10:44:32 +08:00
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_radians(PikaObj* self, pika_float x) {
return x * PI / 180.0;
2022-06-12 10:44:32 +08:00
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_remainder(PikaObj* self, pika_float x, pika_float y) {
return remainder(x, y);
2022-06-12 10:44:32 +08:00
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_sin(PikaObj* self, pika_float x) {
2022-06-12 10:44:32 +08:00
return sin(x);
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_sinh(PikaObj* self, pika_float x) {
2022-06-12 10:44:32 +08:00
return sinh(x);
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_sqrt(PikaObj* self, pika_float x) {
2022-06-12 10:44:32 +08:00
return sqrt(x);
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_tan(PikaObj* self, pika_float x) {
2022-06-12 10:44:32 +08:00
return tan(x);
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_tanh(PikaObj* self, pika_float x) {
2022-06-12 10:44:32 +08:00
return tanh(x);
}
2023-07-20 16:12:33 +08:00
pika_float PikaMath_Math_trunc(PikaObj* self, pika_float x) {
2022-06-12 10:44:32 +08:00
return trunc(x);
2023-07-20 16:12:33 +08:00
}