1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
|
// Copyright John Maddock 2006.
// 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)
//
// Basic sanity check that header <boost/math/special_functions/gamma.hpp>
// #includes all the files that it needs to.
//
#include <boost/math/special_functions/gamma.hpp>
//
// Note this header includes no other headers, this is
// important if this test is to be meaningful:
//
#include "test_compile_result.hpp"
void check()
{
check_result<float>(boost::math::tgamma<float>(f));
check_result<double>(boost::math::tgamma<double>(d));
#ifndef BOOST_MATH_NO_LONG_DOUBLE_MATH_FUNCTIONS
check_result<long double>(boost::math::tgamma<long double>(l));
#endif
check_result<float>(boost::math::lgamma<float>(f));
check_result<double>(boost::math::lgamma<double>(d));
#ifndef BOOST_MATH_NO_LONG_DOUBLE_MATH_FUNCTIONS
check_result<long double>(boost::math::lgamma<long double>(l));
#endif
check_result<float>(boost::math::gamma_p<float>(f, f));
check_result<double>(boost::math::gamma_p<double>(d, d));
#ifndef BOOST_MATH_NO_LONG_DOUBLE_MATH_FUNCTIONS
check_result<long double>(boost::math::gamma_p<long double>(l, l));
#endif
check_result<float>(boost::math::gamma_q<float>(f, f));
check_result<double>(boost::math::gamma_q<double>(d, d));
#ifndef BOOST_MATH_NO_LONG_DOUBLE_MATH_FUNCTIONS
check_result<long double>(boost::math::gamma_q<long double>(l, l));
#endif
check_result<float>(boost::math::gamma_p_inv<float>(f, f));
check_result<double>(boost::math::gamma_p_inv<double>(d, d));
#ifndef BOOST_MATH_NO_LONG_DOUBLE_MATH_FUNCTIONS
check_result<long double>(boost::math::gamma_p_inv<long double>(l, l));
#endif
check_result<float>(boost::math::gamma_q_inv<float>(f, f));
check_result<double>(boost::math::gamma_q_inv<double>(d, d));
#ifndef BOOST_MATH_NO_LONG_DOUBLE_MATH_FUNCTIONS
check_result<long double>(boost::math::gamma_q_inv<long double>(l, l));
#endif
check_result<float>(boost::math::gamma_p_inva<float>(f, f));
check_result<double>(boost::math::gamma_p_inva<double>(d, d));
#ifndef BOOST_MATH_NO_LONG_DOUBLE_MATH_FUNCTIONS
check_result<long double>(boost::math::gamma_p_inva<long double>(l, l));
#endif
check_result<float>(boost::math::gamma_q_inva<float>(f, f));
check_result<double>(boost::math::gamma_q_inva<double>(d, d));
#ifndef BOOST_MATH_NO_LONG_DOUBLE_MATH_FUNCTIONS
check_result<long double>(boost::math::gamma_q_inva<long double>(l, l));
#endif
check_result<float>(boost::math::gamma_p_derivative<float>(f, f));
check_result<double>(boost::math::gamma_p_derivative<double>(d, d));
#ifndef BOOST_MATH_NO_LONG_DOUBLE_MATH_FUNCTIONS
check_result<long double>(boost::math::gamma_p_derivative<long double>(l, l));
#endif
check_result<float>(boost::math::tgamma_ratio<float>(f, f));
check_result<double>(boost::math::tgamma_ratio<double>(d, d));
#ifndef BOOST_MATH_NO_LONG_DOUBLE_MATH_FUNCTIONS
check_result<long double>(boost::math::tgamma_ratio<long double>(l, l));
#endif
check_result<float>(boost::math::tgamma_delta_ratio<float>(f, f));
check_result<double>(boost::math::tgamma_delta_ratio<double>(d, d));
#ifndef BOOST_MATH_NO_LONG_DOUBLE_MATH_FUNCTIONS
check_result<long double>(boost::math::tgamma_delta_ratio<long double>(l, l));
#endif
}
|