1 ///////////////////////////////////////////////////////////////
2 // Copyright 2011 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
7 #include "table_type.hpp"
10 #include <boost/math/special_functions/math_fwd.hpp>
11 #include "libs/math/test/test_expint.hpp"
13 void expected_results()
16 // Define the max and mean errors expected for
17 // various compilers and platforms.
23 ".*gmp_float<18>.*", // test type(s)
24 ".*", // test data group
25 ".*", 2500, 1500); // test function
30 ".*mpfr_float_backend<18>.*", // test type(s)
31 ".*", // test data group
32 ".*", 1000, 500); // test function
37 ".*gmp_float.*", // test type(s)
38 ".*", // test data group
39 ".*", 250, 100); // test function
45 "float128", // test type(s)
46 ".*", // test data group
47 ".*", 4500, 1000); // test function
53 ".*cpp_bin_float.*", // test type(s)
54 ".*", // test data group
55 ".*", 5000, 2000); // test function
61 ".*", // test data group
62 ".*", 250, 50); // test function
64 // Finish off by printing out the compiler/stdlib/platform names,
65 // we do this to make it easier to mark up expected error rates.
67 std::cout << "Tests run with " << BOOST_COMPILER << ", "
68 << BOOST_STDLIB << ", " << BOOST_PLATFORM << std::endl;
72 void test(T t, const char* p)
77 BOOST_AUTO_TEST_CASE(test_main)
79 using namespace boost::multiprecision;
83 // 18 decimal digits: tests 80-bit long double approximations
84 // 30 decimal digits: tests 128-bit long double approximations
85 // 35 decimal digits: tests arbitrary precision code