bug12039.cpp 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. ///////////////////////////////////////////////////////////////////////////////
  2. // Copyright 2016 John Maddock. Distributed under the Boost
  3. // Software License, Version 1.0. (See accompanying file
  4. // LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  5. #include <boost/multiprecision/cpp_bin_float.hpp>
  6. int main()
  7. {
  8. typedef boost::multiprecision::number<boost::multiprecision::backends::cpp_bin_float<256> > ext_float_t;
  9. typedef boost::multiprecision::number<boost::multiprecision::backends::cpp_bin_float<2046> > long_ext_float_t;
  10. ext_float_t x = 5e15;
  11. x += 0.5;
  12. ext_float_t x1 = x + 255.0 / (1 << 20); // + 2^-12 - eps
  13. ext_float_t x2 = x + 257.0 / (1 << 20); // + 2^-12 + eps
  14. double d1 = x1.convert_to<double>();
  15. double d2 = x2.convert_to<double>();
  16. std::cout << std::setprecision(18) << d1 << std::endl;
  17. std::cout << std::setprecision(18) << d2 << std::endl;
  18. x = 1e7 + 0.5;
  19. x1 = x + ldexp(255.0, -38); // + 2^-30 - eps
  20. x2 = x + ldexp(257.0, -38); // + 2^-30 + eps
  21. float f1 = x1.convert_to<float>();
  22. float f2 = x2.convert_to<float>();
  23. std::cout << std::setprecision(9) << f1 << std::endl;
  24. std::cout << std::setprecision(9) << f2 << std::endl;
  25. long_ext_float_t lf(1);
  26. lf += std::numeric_limits<long_ext_float_t>::epsilon();
  27. lf += std::numeric_limits<float>::epsilon() / 2;
  28. BOOST_ASSERT(lf != 1);
  29. float f3 = lf.convert_to<float>();
  30. std::cout << std::setprecision(9) << f3 << std::endl;
  31. return (d1 == d2) && (f1 == f2) && (f3 != 1) ? 0 : 1;
  32. }