1 #define BOOST_TEST_MAIN
2 // Copyright John Maddock 2007.
4 // Use, modification and distribution are subject to the
5 // Boost Software License, Version 1.0.
6 // (See accompanying file LICENSE_1_0.txt
7 // or copy at http://www.boost.org/LICENSE_1_0.txt)
9 #include <boost/math/policies/policy.hpp>
10 #include <boost/type_traits/is_same.hpp>
11 #include <boost/test/unit_test.hpp> // for test_main
14 template <class P1
, class P2
>
15 bool check_same(const P1
&, const P2
&)
17 if(!boost::is_same
<P1
, P2
>::value
)
19 std::cout
<< "P1 = " << typeid(P1
).name() << std::endl
;
20 std::cout
<< "P2 = " << typeid(P2
).name() << std::endl
;
22 return boost::is_same
<P1
, P2
>::value
;
26 BOOST_AUTO_TEST_CASE( test_main
)
28 using namespace boost::math::policies
;
29 using namespace boost
;
31 BOOST_CHECK((is_same
<normalise
<policy
<>, digits2
<20>, promote_float
<false>, discrete_quantile
<integer_round_down
>, denorm_error
<throw_on_error
>, domain_error
<ignore_error
> >::type::domain_error_type
, domain_error
<ignore_error
> >::value
));
32 BOOST_CHECK((is_same
<normalise
<policy
<>, digits2
<20>, promote_float
<false>, discrete_quantile
<integer_round_down
>, denorm_error
<throw_on_error
>, domain_error
<ignore_error
> >::type::pole_error_type
, pole_error
<BOOST_MATH_POLE_ERROR_POLICY
> >::value
));
33 BOOST_CHECK((is_same
<normalise
<policy
<>, digits2
<20>, promote_float
<false>, discrete_quantile
<integer_round_down
>, denorm_error
<throw_on_error
>, domain_error
<ignore_error
> >::type::overflow_error_type
, overflow_error
<BOOST_MATH_OVERFLOW_ERROR_POLICY
> >::value
));
34 BOOST_CHECK((is_same
<normalise
<policy
<>, digits2
<20>, promote_float
<false>, discrete_quantile
<integer_round_down
>, denorm_error
<throw_on_error
>, domain_error
<ignore_error
> >::type::underflow_error_type
, underflow_error
<BOOST_MATH_UNDERFLOW_ERROR_POLICY
> >::value
));
35 BOOST_CHECK((is_same
<normalise
<policy
<>, digits2
<20>, promote_float
<false>, discrete_quantile
<integer_round_down
>, denorm_error
<throw_on_error
>, domain_error
<ignore_error
> >::type::denorm_error_type
, denorm_error
<throw_on_error
> >::value
));
36 BOOST_CHECK((is_same
<normalise
<policy
<>, digits2
<20>, promote_float
<false>, discrete_quantile
<integer_round_down
>, denorm_error
<throw_on_error
>, domain_error
<ignore_error
> >::type::evaluation_error_type
, evaluation_error
<BOOST_MATH_EVALUATION_ERROR_POLICY
> >::value
));
37 BOOST_CHECK((is_same
<normalise
<policy
<>, digits2
<20>, promote_float
<false>, discrete_quantile
<integer_round_down
>, denorm_error
<throw_on_error
>, domain_error
<ignore_error
> >::type::indeterminate_result_error_type
, indeterminate_result_error
<BOOST_MATH_INDETERMINATE_RESULT_ERROR_POLICY
> >::value
));
38 BOOST_CHECK((is_same
<normalise
<policy
<>, digits2
<20>, promote_float
<false>, discrete_quantile
<integer_round_down
>, denorm_error
<throw_on_error
>, domain_error
<ignore_error
> >::type::precision_type
, digits2
<20> >::value
));
39 BOOST_CHECK((is_same
<normalise
<policy
<>, digits2
<20>, promote_float
<false>, discrete_quantile
<integer_round_down
>, denorm_error
<throw_on_error
>, domain_error
<ignore_error
> >::type::promote_float_type
, promote_float
<false> >::value
));
40 BOOST_CHECK((is_same
<normalise
<policy
<>, digits2
<20>, promote_float
<false>, discrete_quantile
<integer_round_down
>, denorm_error
<throw_on_error
>, domain_error
<ignore_error
> >::type::promote_double_type
, policy
<>::promote_double_type
>::value
));
41 BOOST_CHECK((is_same
<normalise
<policy
<>, digits2
<20>, promote_float
<false>, discrete_quantile
<integer_round_down
>, denorm_error
<throw_on_error
>, domain_error
<ignore_error
> >::type::discrete_quantile_type
, discrete_quantile
<integer_round_down
> >::value
));
44 } // BOOST_AUTO_TEST_CASE( test_main )