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_erf.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 "Erf Function:.*", // test data group
25 "erfc?", 2200, 1500); // test function
30 ".*gmp_float<18>.*", // test type(s)
31 "Inverse Erf.*", // test data group
32 "erfc?_inv", 2200, 1500); // test function
38 "float128", // test type(s)
39 "Erf Function:.*", // test data group
40 "erfc?", 15000, 1000); // test function
46 ".*cpp_bin_float.*", // test type(s)
47 "Erf Function:.*", // test data group
48 "erfc?", 3000, 1000); // test function
53 ".*mpfr_float_backend<0>.*", // test type(s)
54 ".*", // test data group
55 ".*", 600, 100); // test function
61 "Erf Function:.*", // test data group
62 "erfc?", 300, 200); // test function
68 "Inverse Erf.*", // test data group
69 "erfc?_inv", 60, 20); // test function
71 // Finish off by printing out the compiler/stdlib/platform names,
72 // we do this to make it easier to mark up expected error rates.
74 std::cout << "Tests run with " << BOOST_COMPILER << ", "
75 << BOOST_STDLIB << ", " << BOOST_PLATFORM << std::endl;
79 void test(T t, const char* p)
84 BOOST_AUTO_TEST_CASE(test_main)
86 using namespace boost::multiprecision;
90 // 18 decimal digits: tests 80-bit long double approximations
91 // 30 decimal digits: tests 128-bit long double approximations
92 // 35 decimal digits: tests arbitrary precision code