60 const Tp x2 = x / Tp(2);
61 const Tp fact = sycl::exp(-sycl::lgamma(Tp(1)));
63 const Tp xx4 = x2 * x2;
66 constexpr Tp eps = std::numeric_limits<Tp>::epsilon();
68 for (
unsigned int i = 1; i < max_iter; ++i) {
69 term *= xx4 / (Tp(i) * Tp(i));
71 if (sycl::fabs(term / Jn) < eps) {
87 constexpr Tp eps = std::numeric_limits<Tp>::epsilon();
88 constexpr Tp fp_min = Tp(10) * eps;
89 constexpr int max_iter = 15000;
90 constexpr Tp x_min = Tp(2);
93 const Tp mu2 = mu * mu;
94 const Tp xi = Tp(1) / x;
95 const Tp xi2 = Tp(2) * xi;
102 for (i = 1; i <= max_iter; ++i) {
107 const Tp del = c * d;
109 if (sycl::fabs(del - Tp(1)) < eps) {
115 return std::numeric_limits<Tp>::infinity();
119 const Tp Inul1 = Inul;
120 const Tp Ipnul = h * Inul;
122 constexpr Tp pi =
static_cast<Tp
>(3.1415926535897932384626433832795029L);
126 const Tp x2 = x / Tp(2);
127 const Tp pimu = pi * mu;
129 (sycl::fabs(pimu) < eps ? Tp(1) : pimu / sycl::sin(pimu));
131 Tp d = -sycl::log(x2);
133 const Tp fact2 = (sycl::fabs(e) < eps ? Tp(1) : sycl::sinh(e) / e);
137 -
static_cast<Tp
>(0.5772156649015328606065120900824024L);
138 const Tp gam2 = Tp(1) / sycl::tgamma(Tp(1));
140 Tp ff = fact * (gam1 * sycl::cosh(e) + gam2 * fact2 * d);
144 Tp p = e / (Tp(2) * gam2);
145 Tp q = Tp(1) / (Tp(2) * e * gam2);
150 for (i = 1; i <= max_iter; ++i) {
151 ff = (i * ff + p + q) / (i * i - mu2);
155 const Tp del = c * ff;
157 const Tp __del1 = c * (p - i * ff);
159 if (sycl::fabs(del) < eps * sycl::fabs(sum)) {
165 return std::numeric_limits<Tp>::quiet_NaN();
171 Tp b = Tp(2) * (Tp(1) + x);
177 Tp a1 = Tp(0.25L) - mu2;
180 Tp s = Tp(1) + q * delh;
182 for (i = 2; i <= max_iter; ++i) {
185 const Tp qnew = (q1 - b * q2) / a;
190 d = Tp(1) / (b + a * d);
191 delh = (b * d - Tp(1)) * delh;
193 const Tp dels = q * delh;
195 if (sycl::fabs(dels / s) < eps) {
201 return std::numeric_limits<Tp>::quiet_NaN();
204 Kmu = sycl::sqrt(pi / (Tp(2) * x)) * sycl::exp(-x) / s;
205 Knu1 = Kmu * (mu + x + Tp(0.5L) - h) * xi;
208 Tp Kpmu = mu * xi * Kmu - Knu1;
209 Tp Inumu = xi / (f * Kmu - Kpmu);
210 return Inumu * Inul1 / Inul;