// Copyright John Maddock 2007. // Use, modification and distribution are subject to the // Boost Software License, Version 1.0. // (See accompanying file LICENSE_1_0.txt // or copy at http://www.boost.org/LICENSE_1_0.txt) #include #include #include // for test_main template bool check_same(const P1&, const P2&) { if(!boost::is_same::value) { std::cout << "P1 = " << typeid(P1).name() << std::endl; std::cout << "P2 = " << typeid(P2).name() << std::endl; } return boost::is_same::value; } int test_main(int, char* []) { using namespace boost::math::policies; using namespace boost; BOOST_CHECK(is_domain_error >::value); BOOST_CHECK(0 == is_domain_error >::value); BOOST_CHECK(is_pole_error >::value); BOOST_CHECK(0 == is_pole_error >::value); BOOST_CHECK(is_digits10 >::value); BOOST_CHECK(0 == is_digits10 >::value); BOOST_CHECK((is_same::domain_error_type, domain_error >::value)); BOOST_CHECK((is_same::evaluation_error_type, evaluation_error >::value)); BOOST_CHECK((is_same >::domain_error_type, domain_error >::value)); BOOST_CHECK((is_same >::pole_error_type, pole_error >::value)); BOOST_CHECK((is_same >::overflow_error_type, overflow_error >::value)); BOOST_CHECK((is_same >::underflow_error_type, underflow_error >::value)); BOOST_CHECK((is_same >::denorm_error_type, denorm_error >::value)); BOOST_CHECK((is_same >::evaluation_error_type, evaluation_error >::value)); BOOST_CHECK((is_same >::precision_type, policy<>::precision_type>::value)); BOOST_CHECK((is_same >::promote_float_type, policy<>::promote_float_type>::value)); BOOST_CHECK((is_same >::promote_double_type, policy<>::promote_double_type>::value)); BOOST_CHECK((is_same >::discrete_quantile_type, policy<>::discrete_quantile_type>::value)); BOOST_CHECK((is_same >::domain_error_type, policy<>::domain_error_type >::value)); BOOST_CHECK((is_same >::pole_error_type, pole_error >::value)); BOOST_CHECK((is_same >::overflow_error_type, overflow_error >::value)); BOOST_CHECK((is_same >::underflow_error_type, underflow_error >::value)); BOOST_CHECK((is_same >::denorm_error_type, denorm_error >::value)); BOOST_CHECK((is_same >::evaluation_error_type, evaluation_error >::value)); BOOST_CHECK((is_same >::precision_type, policy<>::precision_type>::value)); BOOST_CHECK((is_same >::promote_float_type, policy<>::promote_float_type>::value)); BOOST_CHECK((is_same >::promote_double_type, policy<>::promote_double_type>::value)); BOOST_CHECK((is_same >::discrete_quantile_type, policy<>::discrete_quantile_type>::value)); BOOST_CHECK((is_same >::domain_error_type, policy<>::domain_error_type >::value)); BOOST_CHECK((is_same >::pole_error_type, policy<>::pole_error_type >::value)); BOOST_CHECK((is_same >::overflow_error_type, overflow_error >::value)); BOOST_CHECK((is_same >::underflow_error_type, underflow_error >::value)); BOOST_CHECK((is_same >::denorm_error_type, denorm_error >::value)); BOOST_CHECK((is_same >::evaluation_error_type, evaluation_error >::value)); BOOST_CHECK((is_same >::precision_type, policy<>::precision_type>::value)); BOOST_CHECK((is_same >::promote_float_type, policy<>::promote_float_type>::value)); BOOST_CHECK((is_same >::promote_double_type, policy<>::promote_double_type>::value)); BOOST_CHECK((is_same >::discrete_quantile_type, policy<>::discrete_quantile_type>::value)); BOOST_CHECK((is_same >::domain_error_type, policy<>::domain_error_type >::value)); BOOST_CHECK((is_same >::pole_error_type, policy<>::pole_error_type >::value)); BOOST_CHECK((is_same >::overflow_error_type, policy<>::overflow_error_type >::value)); BOOST_CHECK((is_same >::underflow_error_type, underflow_error >::value)); BOOST_CHECK((is_same >::denorm_error_type, denorm_error >::value)); BOOST_CHECK((is_same >::evaluation_error_type, evaluation_error >::value)); BOOST_CHECK((is_same >::precision_type, policy<>::precision_type>::value)); BOOST_CHECK((is_same >::promote_float_type, policy<>::promote_float_type>::value)); BOOST_CHECK((is_same >::promote_double_type, policy<>::promote_double_type>::value)); BOOST_CHECK((is_same >::discrete_quantile_type, policy<>::discrete_quantile_type>::value)); BOOST_CHECK((is_same >::domain_error_type, policy<>::domain_error_type >::value)); BOOST_CHECK((is_same >::pole_error_type, policy<>::pole_error_type >::value)); BOOST_CHECK((is_same >::overflow_error_type, policy<>::overflow_error_type >::value)); BOOST_CHECK((is_same >::underflow_error_type, policy<>::underflow_error_type >::value)); BOOST_CHECK((is_same >::denorm_error_type, denorm_error >::value)); BOOST_CHECK((is_same >::evaluation_error_type, evaluation_error >::value)); BOOST_CHECK((is_same >::precision_type, policy<>::precision_type>::value)); BOOST_CHECK((is_same >::promote_float_type, policy<>::promote_float_type>::value)); BOOST_CHECK((is_same >::promote_double_type, policy<>::promote_double_type>::value)); BOOST_CHECK((is_same >::discrete_quantile_type, policy<>::discrete_quantile_type>::value)); BOOST_CHECK((is_same >::domain_error_type, policy<>::domain_error_type >::value)); BOOST_CHECK((is_same >::pole_error_type, policy<>::pole_error_type >::value)); BOOST_CHECK((is_same >::overflow_error_type, policy<>::overflow_error_type >::value)); BOOST_CHECK((is_same >::underflow_error_type, policy<>::underflow_error_type >::value)); BOOST_CHECK((is_same >::denorm_error_type, policy<>::denorm_error_type >::value)); BOOST_CHECK((is_same >::evaluation_error_type, evaluation_error >::value)); BOOST_CHECK((is_same >::precision_type, policy<>::precision_type>::value)); BOOST_CHECK((is_same >::promote_float_type, policy<>::promote_float_type>::value)); BOOST_CHECK((is_same >::promote_double_type, policy<>::promote_double_type>::value)); BOOST_CHECK((is_same >::discrete_quantile_type, policy<>::discrete_quantile_type>::value)); BOOST_CHECK((is_same >::domain_error_type, policy<>::domain_error_type >::value)); BOOST_CHECK((is_same >::pole_error_type, policy<>::pole_error_type >::value)); BOOST_CHECK((is_same >::overflow_error_type, policy<>::overflow_error_type >::value)); BOOST_CHECK((is_same >::underflow_error_type, policy<>::underflow_error_type >::value)); BOOST_CHECK((is_same >::denorm_error_type, policy<>::denorm_error_type >::value)); BOOST_CHECK((is_same >::evaluation_error_type, policy<>::evaluation_error_type >::value)); BOOST_CHECK((is_same >::precision_type, digits2<20> >::value)); BOOST_CHECK((is_same >::promote_float_type, policy<>::promote_float_type>::value)); BOOST_CHECK((is_same >::promote_double_type, policy<>::promote_double_type>::value)); BOOST_CHECK((is_same >::discrete_quantile_type, policy<>::discrete_quantile_type>::value)); BOOST_CHECK((is_same >::domain_error_type, policy<>::domain_error_type >::value)); BOOST_CHECK((is_same >::pole_error_type, policy<>::pole_error_type >::value)); BOOST_CHECK((is_same >::overflow_error_type, policy<>::overflow_error_type >::value)); BOOST_CHECK((is_same >::underflow_error_type, policy<>::underflow_error_type >::value)); BOOST_CHECK((is_same >::denorm_error_type, policy<>::denorm_error_type >::value)); BOOST_CHECK((is_same >::evaluation_error_type, policy<>::evaluation_error_type >::value)); BOOST_CHECK((is_same >::precision_type, policy<>::precision_type >::value)); BOOST_CHECK((is_same >::promote_float_type, promote_float >::value)); BOOST_CHECK((is_same >::promote_double_type, policy<>::promote_double_type>::value)); BOOST_CHECK((is_same >::discrete_quantile_type, policy<>::discrete_quantile_type>::value)); BOOST_CHECK((is_same >::domain_error_type, policy<>::domain_error_type >::value)); BOOST_CHECK((is_same >::pole_error_type, policy<>::pole_error_type >::value)); BOOST_CHECK((is_same >::overflow_error_type, policy<>::overflow_error_type >::value)); BOOST_CHECK((is_same >::underflow_error_type, policy<>::underflow_error_type >::value)); BOOST_CHECK((is_same >::denorm_error_type, policy<>::denorm_error_type >::value)); BOOST_CHECK((is_same >::evaluation_error_type, policy<>::evaluation_error_type >::value)); BOOST_CHECK((is_same >::precision_type, policy<>::precision_type >::value)); BOOST_CHECK((is_same >::promote_float_type, policy<>::promote_float_type>::value)); BOOST_CHECK((is_same >::promote_double_type, promote_double >::value)); BOOST_CHECK((is_same >::discrete_quantile_type, policy<>::discrete_quantile_type>::value)); BOOST_CHECK((is_same >::domain_error_type, policy<>::domain_error_type >::value)); BOOST_CHECK((is_same >::pole_error_type, policy<>::pole_error_type >::value)); BOOST_CHECK((is_same >::overflow_error_type, policy<>::overflow_error_type >::value)); BOOST_CHECK((is_same >::underflow_error_type, policy<>::underflow_error_type >::value)); BOOST_CHECK((is_same >::denorm_error_type, policy<>::denorm_error_type >::value)); BOOST_CHECK((is_same >::evaluation_error_type, policy<>::evaluation_error_type >::value)); BOOST_CHECK((is_same >::precision_type, policy<>::precision_type >::value)); BOOST_CHECK((is_same >::promote_float_type, policy<>::promote_float_type>::value)); BOOST_CHECK((is_same >::promote_double_type, policy<>::promote_double_type>::value)); BOOST_CHECK((is_same >::discrete_quantile_type, discrete_quantile >::value)); // // Now try again with 2 policies: // BOOST_CHECK((is_same, overflow_error >::domain_error_type, domain_error >::value)); BOOST_CHECK((is_same, overflow_error >::pole_error_type, pole_error >::value)); BOOST_CHECK((is_same, overflow_error >::overflow_error_type, overflow_error >::value)); BOOST_CHECK((is_same, overflow_error >::underflow_error_type, underflow_error >::value)); BOOST_CHECK((is_same, overflow_error >::denorm_error_type, denorm_error >::value)); BOOST_CHECK((is_same, overflow_error >::evaluation_error_type, evaluation_error >::value)); BOOST_CHECK((is_same, overflow_error >::precision_type, policy<>::precision_type>::value)); BOOST_CHECK((is_same, overflow_error >::promote_float_type, policy<>::promote_float_type>::value)); BOOST_CHECK((is_same, overflow_error >::promote_double_type, policy<>::promote_double_type>::value)); BOOST_CHECK((is_same, overflow_error >::discrete_quantile_type, policy<>::discrete_quantile_type>::value)); BOOST_CHECK((is_same, domain_error >::domain_error_type, domain_error >::value)); BOOST_CHECK((is_same, domain_error >::pole_error_type, pole_error >::value)); BOOST_CHECK((is_same, domain_error >::overflow_error_type, overflow_error >::value)); BOOST_CHECK((is_same, domain_error >::underflow_error_type, underflow_error >::value)); BOOST_CHECK((is_same, domain_error >::denorm_error_type, denorm_error >::value)); BOOST_CHECK((is_same, domain_error >::evaluation_error_type, evaluation_error >::value)); BOOST_CHECK((is_same, domain_error >::precision_type, policy<>::precision_type>::value)); BOOST_CHECK((is_same, domain_error >::promote_float_type, policy<>::promote_float_type>::value)); BOOST_CHECK((is_same, domain_error >::promote_double_type, policy<>::promote_double_type>::value)); BOOST_CHECK((is_same, domain_error >::discrete_quantile_type, policy<>::discrete_quantile_type>::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error >::domain_error_type, domain_error >::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error >::pole_error_type, pole_error >::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error >::overflow_error_type, overflow_error >::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error >::underflow_error_type, underflow_error >::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error >::denorm_error_type, denorm_error >::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error >::evaluation_error_type, evaluation_error >::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error >::precision_type, digits2<20> >::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error >::promote_float_type, promote_float >::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error >::promote_double_type, policy<>::promote_double_type>::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error >::discrete_quantile_type, discrete_quantile >::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error > >::type::domain_error_type, domain_error >::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error > >::type::pole_error_type, pole_error >::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error > >::type::overflow_error_type, overflow_error >::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error > >::type::underflow_error_type, underflow_error >::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error > >::type::denorm_error_type, denorm_error >::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error > >::type::evaluation_error_type, evaluation_error >::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error > >::type::precision_type, digits2<20> >::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error > >::type::promote_float_type, promote_float >::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error > >::type::promote_double_type, policy<>::promote_double_type>::value)); BOOST_CHECK((is_same, promote_float, discrete_quantile, denorm_error, domain_error > >::type::discrete_quantile_type, discrete_quantile >::value)); BOOST_CHECK((is_same, digits2<20>, promote_float, discrete_quantile, denorm_error, domain_error >::type::domain_error_type, domain_error >::value)); BOOST_CHECK((is_same, digits2<20>, promote_float, discrete_quantile, denorm_error, domain_error >::type::pole_error_type, pole_error >::value)); BOOST_CHECK((is_same, digits2<20>, promote_float, discrete_quantile, denorm_error, domain_error >::type::overflow_error_type, overflow_error >::value)); BOOST_CHECK((is_same, digits2<20>, promote_float, discrete_quantile, denorm_error, domain_error >::type::underflow_error_type, underflow_error >::value)); BOOST_CHECK((is_same, digits2<20>, promote_float, discrete_quantile, denorm_error, domain_error >::type::denorm_error_type, denorm_error >::value)); BOOST_CHECK((is_same, digits2<20>, promote_float, discrete_quantile, denorm_error, domain_error >::type::evaluation_error_type, evaluation_error >::value)); BOOST_CHECK((is_same, digits2<20>, promote_float, discrete_quantile, denorm_error, domain_error >::type::precision_type, digits2<20> >::value)); BOOST_CHECK((is_same, digits2<20>, promote_float, discrete_quantile, denorm_error, domain_error >::type::promote_float_type, promote_float >::value)); BOOST_CHECK((is_same, digits2<20>, promote_float, discrete_quantile, denorm_error, domain_error >::type::promote_double_type, policy<>::promote_double_type>::value)); BOOST_CHECK((is_same, digits2<20>, promote_float, discrete_quantile, denorm_error, domain_error >::type::discrete_quantile_type, discrete_quantile >::value)); BOOST_CHECK(check_same(make_policy(), policy<>())); BOOST_CHECK(check_same(make_policy(denorm_error()), normalise > >::type())); BOOST_CHECK(check_same(make_policy(digits2<20>()), normalise > >::type())); BOOST_CHECK(check_same(make_policy(promote_float()), normalise > >::type())); BOOST_CHECK(check_same(make_policy(domain_error()), normalise > >::type())); BOOST_CHECK(check_same(make_policy(pole_error()), normalise > >::type())); BOOST_CHECK(check_same(make_policy(domain_error()), policy >())); BOOST_CHECK(check_same(make_policy(domain_error(), pole_error()), policy, pole_error >())); BOOST_CHECK(check_same(make_policy(domain_error(), pole_error(), overflow_error()), policy, pole_error, overflow_error >())); BOOST_CHECK(check_same(make_policy(domain_error(), pole_error(), overflow_error(), underflow_error()), policy, pole_error, overflow_error, underflow_error >())); BOOST_CHECK(check_same(make_policy(domain_error(), pole_error(), overflow_error(), underflow_error(), denorm_error()), policy, pole_error, overflow_error, underflow_error, denorm_error >())); BOOST_CHECK(check_same(make_policy(domain_error(), pole_error(), overflow_error(), underflow_error(), denorm_error(), evaluation_error()), policy, pole_error, overflow_error, underflow_error, denorm_error, evaluation_error >())); BOOST_CHECK(check_same(make_policy(domain_error(), pole_error(), overflow_error(), underflow_error(), denorm_error(), evaluation_error(), digits2<10>()), policy, pole_error, overflow_error, underflow_error, denorm_error, evaluation_error, digits2<10> >())); BOOST_CHECK(check_same(make_policy(domain_error(), pole_error(), overflow_error(), underflow_error(), denorm_error(), evaluation_error(), digits10<5>()), policy, pole_error, overflow_error, underflow_error, denorm_error, evaluation_error, digits2<19> >())); BOOST_CHECK(check_same(make_policy(domain_error(), pole_error(), overflow_error(), underflow_error(), denorm_error(), evaluation_error(), digits2<10>(), promote_float()), policy, pole_error, overflow_error, underflow_error, denorm_error, evaluation_error, digits2<10>, promote_float >())); #ifndef BOOST_MATH_NO_LONG_DOUBLE_MATH_FUNCTIONS BOOST_CHECK(check_same(make_policy(domain_error(), pole_error(), overflow_error(), underflow_error(), denorm_error(), evaluation_error(), digits2<10>(), promote_float(), promote_double()), policy, pole_error, overflow_error, underflow_error, denorm_error, evaluation_error, digits2<10>, promote_float, promote_double >())); BOOST_CHECK(check_same(make_policy(domain_error(), pole_error(), overflow_error(), underflow_error(), denorm_error(), evaluation_error(), digits2<10>(), promote_float(), promote_double(), discrete_quantile()), policy, pole_error, overflow_error, underflow_error, denorm_error, evaluation_error, digits2<10>, promote_float, promote_double, discrete_quantile >())); #endif return 0; } // int test_main(int, char* [])