precision.phpt 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. --TEST--
  2. Default precision is sufficient to serialize all the information in floats
  3. --SKIPIF--
  4. <?php
  5. if (pack('s', 1) != "\x01\x00")
  6. die("skip test for little-endian architectures");
  7. --FILE--
  8. <?php
  9. $numbers = array(
  10. "0000000000000000", //0
  11. "2d431cebe2362a3f", //.0002
  12. "2e431cebe2362a3f", //.0002 + 10^-Accuracy[.0002]*1.01
  13. "0000000000001000", //2^-1022. (minimum normal double)
  14. "0100000000001000", //2^-1022. + 10^-Accuracy[2^-1022.]*1.01
  15. "ffffffffffffef7f", //2^1024. (maximum normal double)
  16. "feffffffffffef7f", //2^1024. - 10^-Accuracy[2^1024.]
  17. "0100000000000000", //minimum subnormal double
  18. "0200000000000000", //2nd minimum subnormal double
  19. "fffffffffffff000", //maximum subnormal double
  20. "fefffffffffff000", //2nd maximum subnormal double
  21. "0000000000000f7f", //+inf
  22. "0000000000000fff", //-inf
  23. );
  24. foreach ($numbers as $ns) {
  25. $num = unpack("d", pack("H*", $ns)); $num = reset($num);
  26. echo "number: ", sprintf("%.17e", $num), "... ";
  27. $num2 = unserialize(serialize($num));
  28. $repr = unpack("H*", pack("d", $num2)); $repr = reset($repr);
  29. if ($repr == $ns)
  30. echo "OK\n";
  31. else
  32. echo "mismatch\n\twas: $ns\n\tbecame: $repr\n";
  33. }
  34. ?>
  35. --EXPECT--
  36. number: 0.00000000000000000e+0... OK
  37. number: 2.00000000000000010e-4... OK
  38. number: 2.00000000000000037e-4... OK
  39. number: 2.22507385850720138e-308... OK
  40. number: 2.22507385850720188e-308... OK
  41. number: 1.79769313486231571e+308... OK
  42. number: 1.79769313486231551e+308... OK
  43. number: 4.94065645841246544e-324... OK
  44. number: 9.88131291682493088e-324... OK
  45. number: 3.87340857288933536e-304... OK
  46. number: 3.87340857288933455e-304... OK
  47. number: 1.06293653832877718e+304... OK
  48. number: -1.06293653832877718e+304... OK