/////////////////////////////////////////////////////////////////////////////// // Copyright 2018 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_0.txt) // #ifndef BOOST_MATH_HYPERGEOMETRIC_1F1_CF_HPP #define BOOST_MATH_HYPERGEOMETRIC_1F1_CF_HPP // // Evaluation of 1F1 by continued fraction // by asymptotic approximation for large a, // see https://dlmf.nist.gov/13.8#E9 // // This is not terribly useful, as it only gets a few digits correct even for very // large a, also needs b and z small: // namespace boost { namespace math { namespace detail { template T hypergeometric_1F1_large_neg_a_asymtotic_dlmf_13_8_9(T a, T b, T z, const Policy& pol) { T result = boost::math::cyl_bessel_j(b - 1, sqrt(2 * z * (b - 2 * a)), pol); result *= boost::math::tgamma(b, pol) * exp(z / 2); T p = pow((b / 2 - a) * z, (1 - b) / 4); result *= p; result *= p; return result; } } } } // namespaces #endif // BOOST_MATH_HYPERGEOMETRIC_1F1_BESSEL_HPP