79 const Tp x2 = x / Tp(2);
80 const Tp fact = sycl::exp(-sycl::lgamma(Tp(1)));
82 const Tp xx4 = x2 * x2;
85 constexpr Tp eps = std::numeric_limits<Tp>::epsilon();
87 for (
unsigned int i = 1; i < max_iter; ++i) {
88 term *= xx4 / (Tp(i) * Tp(i));
90 if (sycl::fabs(term / Jn) < eps) {
106 constexpr Tp eps = std::numeric_limits<Tp>::epsilon();
107 constexpr Tp fp_min = Tp(10) * eps;
108 constexpr int max_iter = 15000;
109 constexpr Tp x_min = Tp(2);
112 const Tp mu2 = mu * mu;
113 const Tp xi = Tp(1) / x;
114 const Tp xi2 = Tp(2) * xi;
121 for (i = 1; i <= max_iter; ++i) {
126 const Tp del = c * d;
128 if (sycl::fabs(del - Tp(1)) < eps) {
134 return std::numeric_limits<Tp>::infinity();
138 const Tp Inul1 = Inul;
139 const Tp Ipnul = h * Inul;
141 constexpr Tp pi =
static_cast<Tp
>(3.1415926535897932384626433832795029L);
145 const Tp x2 = x / Tp(2);
146 const Tp pimu = pi * mu;
148 (sycl::fabs(pimu) < eps ? Tp(1) : pimu / sycl::sin(pimu));
150 Tp d = -sycl::log(x2);
152 const Tp fact2 = (sycl::fabs(e) < eps ? Tp(1) : sycl::sinh(e) / e);
156 -
static_cast<Tp
>(0.5772156649015328606065120900824024L);
157 const Tp gam2 = Tp(1) / sycl::tgamma(Tp(1));
159 Tp ff = fact * (gam1 * sycl::cosh(e) + gam2 * fact2 * d);
163 Tp p = e / (Tp(2) * gam2);
164 Tp q = Tp(1) / (Tp(2) * e * gam2);
169 for (i = 1; i <= max_iter; ++i) {
170 ff = (i * ff + p + q) / (i * i - mu2);
174 const Tp del = c * ff;
176 const Tp __del1 = c * (p - i * ff);
178 if (sycl::fabs(del) < eps * sycl::fabs(sum)) {
184 return std::numeric_limits<Tp>::quiet_NaN();
190 Tp b = Tp(2) * (Tp(1) + x);
196 Tp a1 = Tp(0.25L) - mu2;
199 Tp s = Tp(1) + q * delh;
201 for (i = 2; i <= max_iter; ++i) {
204 const Tp qnew = (q1 - b * q2) / a;
209 d = Tp(1) / (b + a * d);
210 delh = (b * d - Tp(1)) * delh;
212 const Tp dels = q * delh;
214 if (sycl::fabs(dels / s) < eps) {
220 return std::numeric_limits<Tp>::quiet_NaN();
223 Kmu = sycl::sqrt(pi / (Tp(2) * x)) * sycl::exp(-x) / s;
224 Knu1 = Kmu * (mu + x + Tp(0.5L) - h) * xi;
227 Tp Kpmu = mu * xi * Kmu - Knu1;
228 Tp Inumu = xi / (f * Kmu - Kpmu);
229 return Inumu * Inul1 / Inul;