test_arithmetic_cpp_bin_float_2m.cpp 1.6 KB

123456789101112131415161718192021222324252627
  1. ///////////////////////////////////////////////////////////////
  2. // Copyright 2012 John Maddock. Distributed under the Boost
  3. // Software License, Version 1.0. (See accompanying file
  4. // LICENSE_1_0.txt or copy at https://www.boost.org/LICENSE_1_0.txt
  5. #define MIXED_OPS_ONLY
  6. #include <boost/multiprecision/cpp_bin_float.hpp>
  7. #include "libs/multiprecision/test/test_arithmetic.hpp"
  8. #ifndef _WIN64 // object file too large
  9. template <unsigned Digits, boost::multiprecision::backends::digit_base_type DigitBase, class Allocator, class Exponent, Exponent MinExponent, Exponent MaxExponent, boost::multiprecision::expression_template_option ET>
  10. struct related_type<boost::multiprecision::number<boost::multiprecision::cpp_bin_float<Digits, DigitBase, Allocator, Exponent, MinExponent, MaxExponent>, ET> >
  11. {
  12. typedef boost::multiprecision::number<boost::multiprecision::cpp_bin_float<Digits, DigitBase, Allocator, Exponent, MinExponent, MaxExponent>, ET> number_type;
  13. typedef boost::multiprecision::number<boost::multiprecision::cpp_bin_float<((std::numeric_limits<number_type>::digits / 2) > std::numeric_limits<long double>::digits ? Digits / 2 : Digits), DigitBase, Allocator, Exponent, MinExponent, MaxExponent>, ET> type;
  14. };
  15. #endif
  16. int main()
  17. {
  18. //test<boost::multiprecision::cpp_bin_float_50>();
  19. test<boost::multiprecision::number<boost::multiprecision::cpp_bin_float<1000, boost::multiprecision::digit_base_10, std::allocator<char>, boost::long_long_type> > >();
  20. //test<boost::multiprecision::cpp_bin_float_quad>();
  21. return boost::report_errors();
  22. }