Files
libpostal/src/float_utils.c

39 lines
823 B
C

#include "float_utils.h"
inline bool float_equals_epsilon(float a, float b, float epsilon) {
float diff = fabsf(a - b);
a = fabsf(a);
b = fabsf(b);
float largest = (b > a) ? b : a;
return (diff <= largest * epsilon);
}
inline bool float_equals(float a, float b) {
return float_equals_epsilon(a, b, FLT_EPSILON);
}
inline float fsign(float x) {
return (float)((x > 0.0f) - (x < 0.0f));
}
inline bool double_equals_epsilon(double a, double b, double epsilon) {
double diff = fabs(a - b);
a = fabs(a);
b = fabs(b);
double largest = (b > a) ? b : a;
return (diff <= largest * epsilon);
}
inline bool double_equals(double a, double b) {
return double_equals_epsilon(a, b, DBL_EPSILON);
}
inline double sign(double x) {
return (double)((x > 0.0) - (x < 0.0));
}