frexp.c 374 B

1234567891011121314151617181920212223
  1. #include <math.h>
  2. #include <stdint.h>
  3. double frexp(double x, int *e)
  4. {
  5. union { double d; uint64_t i; } y = { x };
  6. int ee = y.i>>52 & 0x7ff;
  7. if (!ee) {
  8. if (x) {
  9. x = frexp(x*0x1p64, e);
  10. *e -= 64;
  11. } else *e = 0;
  12. return x;
  13. } else if (ee == 0x7ff) {
  14. return x;
  15. }
  16. *e = ee - 0x3fe;
  17. y.i &= 0x800fffffffffffffull;
  18. y.i |= 0x3fe0000000000000ull;
  19. return y.d;
  20. }