tomo/stdlib/nums.h

61 lines
2.2 KiB
C
Raw Normal View History

2024-02-17 16:32:30 -08:00
#pragma once
2024-03-18 09:57:49 -07:00
// Type infos and methods for Nums (floating point)
2024-02-27 10:39:12 -08:00
#include <math.h>
2024-02-17 16:32:30 -08:00
#include <stdbool.h>
#include <stdint.h>
#include "types.h"
#include "util.h"
2024-02-17 16:32:30 -08:00
#define Num_t double
#define Num32_t float
#define OptionalNum_t double
#define OptionalNum32_t float
#define N32(n) ((float)n)
#define N64(n) ((double)n)
Text_t Num$as_text(const double *f, bool colorize, const TypeInfo_t *type);
PUREFUNC int32_t Num$compare(const double *x, const double *y, const TypeInfo_t *type);
PUREFUNC bool Num$equal(const double *x, const double *y, const TypeInfo_t *type);
CONSTFUNC bool Num$near(double a, double b, double ratio, double absolute);
2024-09-02 15:47:39 -07:00
Text_t Num$format(double f, Int_t precision);
Text_t Num$scientific(double f, Int_t precision);
double Num$mod(double num, double modulus);
CONSTFUNC bool Num$isinf(double n);
CONSTFUNC bool Num$finite(double n);
CONSTFUNC bool Num$isnan(double n);
2024-09-02 15:47:39 -07:00
double Num$nan(Text_t tag);
double Num$random(void);
CONSTFUNC double Num$mix(double amount, double x, double y);
OptionalNum_t Num$from_text(Text_t text);
CONSTFUNC static inline double Num$clamped(double x, double low, double high) {
2024-08-18 20:20:54 -07:00
return (x <= low) ? low : (x >= high ? high : x);
}
extern const TypeInfo_t Num$info;
2024-02-17 16:32:30 -08:00
Text_t Num32$as_text(const float *f, bool colorize, const TypeInfo_t *type);
PUREFUNC int32_t Num32$compare(const float *x, const float *y, const TypeInfo_t *type);
PUREFUNC bool Num32$equal(const float *x, const float *y, const TypeInfo_t *type);
CONSTFUNC bool Num32$near(float a, float b, float ratio, float absolute);
2024-09-02 15:47:39 -07:00
Text_t Num32$format(float f, Int_t precision);
Text_t Num32$scientific(float f, Int_t precision);
float Num32$mod(float num, float modulus);
CONSTFUNC bool Num32$isinf(float n);
CONSTFUNC bool Num32$finite(float n);
CONSTFUNC bool Num32$isnan(float n);
float Num32$random(void);
CONSTFUNC float Num32$mix(float amount, float x, float y);
OptionalNum32_t Num32$from_text(Text_t text);
2024-09-02 15:47:39 -07:00
float Num32$nan(Text_t tag);
CONSTFUNC static inline float Num32$clamped(float x, float low, float high) {
2024-08-18 20:20:54 -07:00
return (x <= low) ? low : (x >= high ? high : x);
}
extern const TypeInfo_t Num32$info;
2024-02-17 16:32:30 -08:00
2024-09-08 16:33:49 -07:00
#define Num_to_Num32(n) ((Num32_t)(n))
#define Num32_to_Num(n) ((Num_t)(n))
2024-02-17 16:32:30 -08:00
// vim: ts=4 sw=0 et cino=L2,l1,(0,W4,m1,\:0