ilogb.c 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. #include <math.h>
  2. #include <stdlib.h>
  3. #include <stdint.h>
  4. #include <limits.h>
  5. #include <stdio.h>
  6. #define check_d1(func, param, expected) \
  7. do { \
  8. int err; hex_union ur; hex_union up; \
  9. double result = func(param); up.f = param; ur.f = result; \
  10. errors += (err = (result != (expected))); \
  11. err \
  12. ? printf("FAIL: %s(%g/"HEXFMT")=%g/"HEXFMT" (expected %g)\n", \
  13. #func, (double)(param), (long long)up.hex, result, (long long)ur.hex, (double)(expected)) \
  14. : printf("PASS: %s(%g)=%g\n", #func, (double)(param), result); \
  15. } while (0)
  16. #define check_i1(func, param, expected) \
  17. do { \
  18. int err; hex_union up; \
  19. long long result = func(param); up.f = param; \
  20. errors += (err = (result != (expected))); \
  21. err \
  22. ? printf("FAIL: %s(%g/"HEXFMT")=%lld/%llu (expected %llu)\n", \
  23. #func, (double)(param), (long long)up.hex, result, result, (long long)(expected)) \
  24. : printf("PASS: %s(%g)=%lld/%llu\n", #func, (double)(param), result, result); \
  25. } while (0)
  26. #define HEXFMT "%08llx"
  27. typedef union {
  28. double f;
  29. uint64_t hex;
  30. } hex_union;
  31. double nan_value = 0.0;
  32. int errors = 0;
  33. int main(void)
  34. {
  35. nan_value /= nan_value;
  36. check_i1(ilogb, 0.0, FP_ILOGB0);
  37. check_i1(ilogb, HUGE_VAL, INT_MAX);
  38. check_i1(ilogb, nan_value, FP_ILOGBNAN);
  39. check_i1(ilogbf, 0.0, FP_ILOGB0);
  40. check_i1(ilogbf, HUGE_VALF, INT_MAX);
  41. check_i1(ilogbf, nan_value, FP_ILOGBNAN);
  42. printf("Errors: %d\n", errors);
  43. return errors;
  44. }