mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-11-03 21:40:52 -05:00 
			
		
		
		
	
		
			
	
	
		
			53 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
		
		
			
		
	
	
			53 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| 
								 | 
							
								///////////////////////////////////////////////////////////////
							 | 
						||
| 
								 | 
							
								//  Copyright Christopher Kormanyos 2002 - 2011.
							 | 
						||
| 
								 | 
							
								//  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_
							 | 
						||
| 
								 | 
							
								//
							 | 
						||
| 
								 | 
							
								// This work is based on an earlier work:
							 | 
						||
| 
								 | 
							
								// "Algorithm 910: A Portable C++ Multiple-Precision System for Special-Function Calculations",
							 | 
						||
| 
								 | 
							
								// in ACM TOMS, {VOL 37, ISSUE 4, (February 2011)} (C) ACM, 2011. http://doi.acm.org/10.1145/1916461.1916469
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#include "setup.hpp"
							 | 
						||
| 
								 | 
							
								#include "table_type.hpp"
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#include <boost/math/special_functions/binomial.hpp>
							 | 
						||
| 
								 | 
							
								#include "libs/math/test/test_binomial_coeff.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)
							 | 
						||
| 
								 | 
							
								      ".*",                          // test data group
							 | 
						||
| 
								 | 
							
								      ".*", 100, 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_binomial(t, p);
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								BOOST_AUTO_TEST_CASE( test_main )
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								   expected_results();
							 | 
						||
| 
								 | 
							
								   ALL_TESTS
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 |