From 19fcec84d8d7d21e796c7624e521b60d28ee21ed Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 20:45:59 +0200 Subject: Adding upstream version 16.2.11+ds. Signed-off-by: Daniel Baumann --- src/boost/libs/math/test/test_2F0.hpp | 102 ++++++++++++++++++++++++++++++++++ 1 file changed, 102 insertions(+) create mode 100644 src/boost/libs/math/test/test_2F0.hpp (limited to 'src/boost/libs/math/test/test_2F0.hpp') diff --git a/src/boost/libs/math/test/test_2F0.hpp b/src/boost/libs/math/test/test_2F0.hpp new file mode 100644 index 000000000..d0cacf9e3 --- /dev/null +++ b/src/boost/libs/math/test/test_2F0.hpp @@ -0,0 +1,102 @@ +// Copyright John Maddock 2006. +// Copyright Paul A. Bristow 2007, 2009 +// 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) + +#define BOOST_MATH_OVERFLOW_ERROR_POLICY ignore_error + +#include +#include +#define BOOST_TEST_MAIN +#include +#include +#include +#include +#include +#include +#include +#include +#include "functor.hpp" + +#include "handle_test_result.hpp" +#include "table_type.hpp" + +#include + +template +void do_test_2F0(const T& data, const char* type_name, const char* test_name) +{ + typedef Real value_type; + + typedef value_type(*pg)(value_type, value_type, value_type); +#if defined(BOOST_MATH_NO_DEDUCED_FUNCTION_POINTERS) + pg funcp = boost::math::hypergeometric_0F1; +#else + pg funcp = boost::math::hypergeometric_2F0; +#endif + + boost::math::tools::test_result result; + + std::cout << "Testing " << test_name << " with type " << type_name + << "\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n"; + + // + // test hypergeometric_2F0 against data: + // + result = boost::math::tools::test_hetero( + data, + bind_func(funcp, 0, 1, 2), + extract_result(3)); + handle_test_result(result, data[result.worst()], result.worst(), type_name, "hypergeometric_0F1", test_name); + std::cout << std::endl; +} + +#ifndef SC_ +#define SC_(x) BOOST_MATH_BIG_CONSTANT(T, 1000000, x) +#endif + +template +void test_spots1(T, const char* type_name) +{ +#include "hypergeometric_2F0.ipp" + + do_test_2F0(hypergeometric_2F0, type_name, "Random non-integer a2, |z| < 1"); + +#include "hypergeometric_2F0_large_z.ipp" + + do_test_2F0(hypergeometric_2F0_large_z, type_name, "Random non-integer a2, |z| > 1"); +} + +template +void test_spots2(T, const char* type_name) +{ +#include "hypergeometric_2F0_integer_a2.ipp" + + do_test_2F0(hypergeometric_2F0_integer_a2, type_name, "Integer a2, |z| > 1"); + +#include "hypergeometric_2F0_half.ipp" + + do_test_2F0(hypergeometric_2F0_half, type_name, "a1 = a2 + 0.5"); +} + +template +void test_spots(T z, const char* type_name) +{ + test_spots1(z, type_name); + test_spots2(z, type_name); + + T a1 = 1; + T a2 = 0.1f; + z = -1; + if (std::numeric_limits::has_infinity) + { + BOOST_CHECK((boost::math::isinf)(boost::math::hypergeometric_2F0(a1, a2, z))); + z = 1; + BOOST_CHECK((boost::math::isinf)(boost::math::hypergeometric_2F0(a1, a2, z))); + a2 = -2.4f; + BOOST_CHECK((boost::math::isinf)(boost::math::hypergeometric_2F0(a1, a2, z))); + a1 = -0.5f; + BOOST_CHECK((boost::math::isinf)(boost::math::hypergeometric_2F0(a1, a2, z))); + } +} -- cgit v1.2.3