/** * Jingga * * @package Utils * @copyright Jingga * @license OMS License 2.0 * @version 1.0.0 * @link https://jingga.app */ #ifndef TOS_UTILS_MATH_UTILS_H #define TOS_UTILS_MATH_UTILS_H #include #define OMS_PI 3.14159265358979323846f #define OMS_PI_OVER_TWO (OMS_PI / 2.0f) #define OMS_PI_OVER_FOUR (OMS_PI / 4.0f) #define OMS_TWO_PI (2.0f * OMS_PI) #define OMS_MAX(a, b) ((a) > (b) ? (a) : (b)) #define OMS_MIN(a, b) ((a) > (b) ? (b) : (a)) #define OMS_CLAMP(val, high, low) (OMS_MAX(OMS_MIN((val), (high)), (low))) #define OMS_ABS(a) ((a) > 0 ? (a) : -(a)) #define OMS_DEG2RAD(angle) ((angle) * OMS_PI / 180.0f) #define OMS_RAD2DEG(angle) ((angle) * 180.0f / OMS_PI) #define ROUND_TO_NEAREST(a, b) (((a) + ((b) - 1)) & ~((b) - 1)) #define CEIL_DIV(a, b) (((a) + (b) - 1) / (b)) #define OMS_CEIL(x) ((x) == (int)(x) ? (int)(x) : ((x) > 0 ? (int)(x) + 1 : (int)(x))) #define OMS_ROUND(x) (((x) >= 0) ? ((int)((x) + 0.5f)) : ((int)((x) - 0.5f))) #define OMS_ROUND_POSITIVE(x) ((int)((x) + 0.5f)) // Modulo function when b is a power of 2 #define MODULO_2(a, b) ((a) & (b - 1)) #define SQRT_2 1.4142135623730950488016887242097f #endif