64 const Tp x2 = x / Tp(2);
65 const Tp fact = sycl::exp(-sycl::lgamma(Tp(1)));
67 const Tp xx4 = x2 * x2;
70 constexpr Tp eps = std::numeric_limits<Tp>::epsilon();
72 for (
unsigned int i = 1; i < max_iter; ++i) {
73 term *= xx4 / (Tp(i) * Tp(i));
75 if (sycl::fabs(term / Jn) < eps) {
91 constexpr Tp eps = std::numeric_limits<Tp>::epsilon();
92 constexpr Tp fp_min = Tp(10) * eps;
93 constexpr int max_iter = 15000;
94 constexpr Tp x_min = Tp(2);
97 const Tp mu2 = mu * mu;
98 const Tp xi = Tp(1) / x;
99 const Tp xi2 = Tp(2) * xi;
106 for (i = 1; i <= max_iter; ++i) {
111 const Tp del = c * d;
113 if (sycl::fabs(del - Tp(1)) < eps) {
119 return std::numeric_limits<Tp>::infinity();
123 const Tp Inul1 = Inul;
124 const Tp Ipnul = h * Inul;
126 constexpr Tp pi =
static_cast<Tp
>(3.1415926535897932384626433832795029L);
130 const Tp x2 = x / Tp(2);
131 const Tp pimu = pi * mu;
133 (sycl::fabs(pimu) < eps ? Tp(1) : pimu / sycl::sin(pimu));
135 Tp d = -sycl::log(x2);
137 const Tp fact2 = (sycl::fabs(e) < eps ? Tp(1) : sycl::sinh(e) / e);
141 -
static_cast<Tp
>(0.5772156649015328606065120900824024L);
142 const Tp gam2 = Tp(1) / sycl::tgamma(Tp(1));
144 Tp ff = fact * (gam1 * sycl::cosh(e) + gam2 * fact2 * d);
148 Tp p = e / (Tp(2) * gam2);
149 Tp q = Tp(1) / (Tp(2) * e * gam2);
154 for (i = 1; i <= max_iter; ++i) {
155 ff = (i * ff + p + q) / (i * i - mu2);
159 const Tp del = c * ff;
161 const Tp __del1 = c * (p - i * ff);
163 if (sycl::fabs(del) < eps * sycl::fabs(sum)) {
169 return std::numeric_limits<Tp>::quiet_NaN();
175 Tp b = Tp(2) * (Tp(1) + x);
181 Tp a1 = Tp(0.25L) - mu2;
184 Tp s = Tp(1) + q * delh;
186 for (i = 2; i <= max_iter; ++i) {
189 const Tp qnew = (q1 - b * q2) / a;
194 d = Tp(1) / (b + a * d);
195 delh = (b * d - Tp(1)) * delh;
197 const Tp dels = q * delh;
199 if (sycl::fabs(dels / s) < eps) {
205 return std::numeric_limits<Tp>::quiet_NaN();
208 Kmu = sycl::sqrt(pi / (Tp(2) * x)) * sycl::exp(-x) / s;
209 Knu1 = Kmu * (mu + x + Tp(0.5L) - h) * xi;
212 Tp Kpmu = mu * xi * Kmu - Knu1;
213 Tp Inumu = xi / (f * Kmu - Kpmu);
214 return Inumu * Inul1 / Inul;