mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-25 18:10:21 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			60 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| ///////////////////////////////////////////////////////////////
 | |
| //  Copyright 2011 John Maddock. Distributed under the Boost
 | |
| //  Software License, Version 1.0. (See accompanying file
 | |
| //  LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_
 | |
| 
 | |
| #include "setup.hpp"
 | |
| #include "table_type.hpp"
 | |
| #define TEST_UDT
 | |
| 
 | |
| #include <boost/math/special_functions/erf.hpp>
 | |
| #include "libs/math/test/test_erf.hpp"
 | |
| 
 | |
| void expected_results()
 | |
| {
 | |
|    //
 | |
|    // Define the max and mean errors expected for
 | |
|    // various compilers and platforms.
 | |
|    //
 | |
|    add_expected_result(
 | |
|       ".*",                          // compiler
 | |
|       ".*",                          // stdlib
 | |
|       ".*",                          // platform
 | |
|       ".*",                          // test type(s)
 | |
|       "Erf Function:.*",             // test data group
 | |
|       "erfc?", 2500, 1000); // test function
 | |
|    add_expected_result(
 | |
|       ".*",                          // compiler
 | |
|       ".*",                          // stdlib
 | |
|       ".*",                          // platform
 | |
|       ".*",                          // test type(s)
 | |
|       "Inverse Erf.*",               // test data group
 | |
|       "erfc?_inv", 60, 20);  // test function
 | |
|    //
 | |
|    // Finish off by printing out the compiler/stdlib/platform names,
 | |
|    // we do this to make it easier to mark up expected error rates.
 | |
|    //
 | |
|    std::cout << "Tests run with " << BOOST_COMPILER << ", "
 | |
|       << BOOST_STDLIB << ", " << BOOST_PLATFORM << std::endl;
 | |
| }
 | |
| 
 | |
| template <class T>
 | |
| void test(T t, const char* p)
 | |
| {
 | |
|    test_erf(t, p);
 | |
| }
 | |
| 
 | |
| 
 | |
| BOOST_AUTO_TEST_CASE( test_main )
 | |
| {
 | |
|    expected_results();
 | |
|    //
 | |
|    // Test at:
 | |
|    // 18 decimal digits: tests 80-bit long double approximations
 | |
|    // 30 decimal digits: tests 128-bit long double approximations
 | |
|    // 35 decimal digits: tests arbitrary precision code
 | |
|    //
 | |
|    ALL_TESTS
 | |
| }
 | |
| 
 |