2 * ====================================================
3 * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
5 * Developed at SunPro, a Sun Microsystems, Inc. business.
6 * Permission to use, copy, modify, and distribute this
7 * software is freely granted, provided that this notice
9 * ====================================================
12 /* Long double expansions are
13 Copyright (C) 2001 Stephen L. Moshier <moshier@na-net.ornl.gov>
14 and are incorporated herein by permission of the author. The author
15 reserves the right to distribute this material elsewhere under different
16 copying permissions. These modifications are distributed here under
19 This library is free software; you can redistribute it and/or
20 modify it under the terms of the GNU Lesser General Public
21 License as published by the Free Software Foundation; either
22 version 2.1 of the License, or (at your option) any later version.
24 This library is distributed in the hope that it will be useful,
25 but WITHOUT ANY WARRANTY; without even the implied warranty of
26 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
27 Lesser General Public License for more details.
29 You should have received a copy of the GNU Lesser General Public
30 License along with this library; if not, see
31 <http://www.gnu.org/licenses/>. */
33 /* __ieee754_j1(x), __ieee754_y1(x)
34 * Bessel function of the first and second kinds of order zero.
36 * 1. For tiny x, we use j1(x) = x/2 - x^3/16 + x^5/384 - ...
37 * 2. Reduce x to |x| since j1(x)=-j1(-x), and
39 * j1(x) = x/2 + x*z*R0/S0, where z = x*x;
41 * j1(x) = sqrt(2/(pi*x))*(p1(x)*cos(x1)-q1(x)*sin(x1))
42 * y1(x) = sqrt(2/(pi*x))*(p1(x)*sin(x1)+q1(x)*cos(x1))
43 * where x1 = x-3*pi/4. It is better to compute sin(x1),cos(x1)
45 * cos(x1) = cos(x)cos(3pi/4)+sin(x)sin(3pi/4)
46 * = 1/sqrt(2) * (sin(x) - cos(x))
47 * sin(x1) = sin(x)cos(3pi/4)-cos(x)sin(3pi/4)
48 * = -1/sqrt(2) * (sin(x) + cos(x))
49 * (To avoid cancellation, use
50 * sin(x) +- cos(x) = -cos(2x)/(sin(x) -+ cos(x))
51 * to compute the worse one.)
59 * 1. screen out x<=0 cases: y1(0)=-inf, y1(x<0)=NaN
62 * y1(x) = 2/pi*(j1(x)*(ln(x/2)+Euler)-1/x-x/2+5/64*x^3-...)
63 * therefore y1(x)-2/pi*j1(x)*ln(x)-1/x is an odd function.
64 * We use the following function to approximate y1,
65 * y1(x) = x*U(z)/V(z) + (2/pi)*(j1(x)*ln(x)-1/x), z= x^2
66 * Note: For tiny x, 1/x dominate y1 and hence
67 * y1(tiny) = -2/pi/tiny
69 * y1(x) = sqrt(2/(pi*x))*(p1(x)*sin(x1)+q1(x)*cos(x1))
70 * where x1 = x-3*pi/4. It is better to compute sin(x1),cos(x1)
71 * by method mentioned above.
76 #include <math_private.h>
78 static long double pone (long double), qone (long double);
80 static const long double
83 invsqrtpi
= 5.6418958354775628694807945156077258584405e-1L,
84 tpi
= 6.3661977236758134307553505349005744813784e-1L,
86 /* J1(x) = .5 x + x x^2 R(x^2) / S(x^2)
88 Peak relative error 4.5e-21 */
90 -9.647406112428107954753770469290757756814E7L
,
91 2.686288565865230690166454005558203955564E6L
,
92 -3.689682683905671185891885948692283776081E4L
,
93 2.195031194229176602851429567792676658146E2L
,
94 -5.124499848728030297902028238597308971319E-1L,
99 1.543584977988497274437410333029029035089E9L
,
100 2.133542369567701244002565983150952549520E7L
,
101 1.394077011298227346483732156167414670520E5L
,
102 5.252401789085732428842871556112108446506E2L
,
103 /* 1.000000000000000000000000000000000000000E0L, */
106 static const long double zero
= 0.0;
110 __ieee754_j1l (long double x
)
112 long double z
, c
, r
, s
, ss
, cc
, u
, v
, y
;
116 GET_LDOUBLE_EXP (se
, x
);
118 if (__glibc_unlikely (ix
>= 0x7fff))
123 __sincosl (y
, &s
, &c
);
127 { /* make sure y+y not overflow */
135 * j1(x) = 1/sqrt(pi) * (P(1,x)*cc - Q(1,x)*ss) / sqrt(x)
136 * y1(x) = 1/sqrt(pi) * (P(1,x)*ss + Q(1,x)*cc) / sqrt(x)
138 if (__glibc_unlikely (ix
> 0x4080))
139 z
= (invsqrtpi
* cc
) / __ieee754_sqrtl (y
);
144 z
= invsqrtpi
* (u
* cc
- v
* ss
) / __ieee754_sqrtl (y
);
151 if (__glibc_unlikely (ix
< 0x3fde)) /* |x| < 2^-33 */
154 return 0.5 * x
; /* inexact if x!=0 necessary */
157 r
= z
* (R
[0] + z
* (R
[1]+ z
* (R
[2] + z
* (R
[3] + z
* R
[4]))));
158 s
= S
[0] + z
* (S
[1] + z
* (S
[2] + z
* (S
[3] + z
)));
160 return (x
* 0.5 + r
/ s
);
162 strong_alias (__ieee754_j1l
, __j1l_finite
)
165 /* Y1(x) = 2/pi * (log(x) * j1(x) - 1/x) + x R(x^2)
167 Peak relative error 2.3e-23 */
168 static const long double U0
[6] = {
169 -5.908077186259914699178903164682444848615E10L
,
170 1.546219327181478013495975514375773435962E10L
,
171 -6.438303331169223128870035584107053228235E8L
,
172 9.708540045657182600665968063824819371216E6L
,
173 -6.138043997084355564619377183564196265471E4L
,
174 1.418503228220927321096904291501161800215E2L
,
176 static const long double V0
[5] = {
177 3.013447341682896694781964795373783679861E11L
,
178 4.669546565705981649470005402243136124523E9L
,
179 3.595056091631351184676890179233695857260E7L
,
180 1.761554028569108722903944659933744317994E5L
,
181 5.668480419646516568875555062047234534863E2L
,
182 /* 1.000000000000000000000000000000000000000E0L, */
187 __ieee754_y1l (long double x
)
189 long double z
, s
, c
, ss
, cc
, u
, v
;
191 u_int32_t se
, i0
, i1
;
193 GET_LDOUBLE_WORDS (se
, i0
, i1
, x
);
195 /* if Y1(NaN) is NaN, Y1(-inf) is NaN, Y1(inf) is 0 */
196 if (__glibc_unlikely (se
& 0x8000))
197 return zero
/ (zero
* x
);
198 if (__glibc_unlikely (ix
>= 0x7fff))
199 return one
/ (x
+ x
* x
);
200 if (__glibc_unlikely ((i0
| i1
) == 0))
201 return -HUGE_VALL
+ x
; /* -inf and overflow exception. */
204 __sincosl (x
, &s
, &c
);
208 { /* make sure x+x not overflow */
215 /* y1(x) = sqrt(2/(pi*x))*(p1(x)*sin(x0)+q1(x)*cos(x0))
218 * cos(x0) = cos(x)cos(3pi/4)+sin(x)sin(3pi/4)
219 * = 1/sqrt(2) * (sin(x) - cos(x))
220 * sin(x0) = sin(x)cos(3pi/4)-cos(x)sin(3pi/4)
221 * = -1/sqrt(2) * (cos(x) + sin(x))
222 * To avoid cancellation, use
223 * sin(x) +- cos(x) = -cos(2x)/(sin(x) -+ cos(x))
224 * to compute the worse one.
226 if (__glibc_unlikely (ix
> 0x4080))
227 z
= (invsqrtpi
* ss
) / __ieee754_sqrtl (x
);
232 z
= invsqrtpi
* (u
* ss
+ v
* cc
) / __ieee754_sqrtl (x
);
236 if (__glibc_unlikely (ix
<= 0x3fbe))
240 __set_errno (ERANGE
);
244 u
= U0
[0] + z
* (U0
[1] + z
* (U0
[2] + z
* (U0
[3] + z
* (U0
[4] + z
* U0
[5]))));
245 v
= V0
[0] + z
* (V0
[1] + z
* (V0
[2] + z
* (V0
[3] + z
* (V0
[4] + z
))));
246 return (x
* (u
/ v
) +
247 tpi
* (__ieee754_j1l (x
) * __ieee754_logl (x
) - one
/ x
));
249 strong_alias (__ieee754_y1l
, __y1l_finite
)
252 /* For x >= 8, the asymptotic expansions of pone is
253 * 1 + 15/128 s^2 - 4725/2^15 s^4 - ..., where s = 1/x.
254 * We approximate pone by
255 * pone(x) = 1 + (R/S)
258 /* J1(x) cosX + Y1(x) sinX = sqrt( 2/(pi x)) P1(x)
259 P1(x) = 1 + z^2 R(z^2), z=1/x
260 8 <= x <= inf (0 <= z <= 0.125)
261 Peak relative error 5.2e-22 */
263 static const long double pr8
[7] = {
264 8.402048819032978959298664869941375143163E-9L,
265 1.813743245316438056192649247507255996036E-6L,
266 1.260704554112906152344932388588243836276E-4L,
267 3.439294839869103014614229832700986965110E-3L,
268 3.576910849712074184504430254290179501209E-2L,
269 1.131111483254318243139953003461511308672E-1L,
270 4.480715825681029711521286449131671880953E-2L,
272 static const long double ps8
[6] = {
273 7.169748325574809484893888315707824924354E-8L,
274 1.556549720596672576431813934184403614817E-5L,
275 1.094540125521337139209062035774174565882E-3L,
276 3.060978962596642798560894375281428805840E-2L,
277 3.374146536087205506032643098619414507024E-1L,
278 1.253830208588979001991901126393231302559E0L
,
279 /* 1.000000000000000000000000000000000000000E0L, */
282 /* J1(x) cosX + Y1(x) sinX = sqrt( 2/(pi x)) P1(x)
283 P1(x) = 1 + z^2 R(z^2), z=1/x
284 4.54541015625 <= x <= 8
285 Peak relative error 7.7e-22 */
286 static const long double pr5
[7] = {
287 4.318486887948814529950980396300969247900E-7L,
288 4.715341880798817230333360497524173929315E-5L,
289 1.642719430496086618401091544113220340094E-3L,
290 2.228688005300803935928733750456396149104E-2L,
291 1.142773760804150921573259605730018327162E-1L,
292 1.755576530055079253910829652698703791957E-1L,
293 3.218803858282095929559165965353784980613E-2L,
295 static const long double ps5
[6] = {
296 3.685108812227721334719884358034713967557E-6L,
297 4.069102509511177498808856515005792027639E-4L,
298 1.449728676496155025507893322405597039816E-2L,
299 2.058869213229520086582695850441194363103E-1L,
300 1.164890985918737148968424972072751066553E0L
,
301 2.274776933457009446573027260373361586841E0L
,
302 /* 1.000000000000000000000000000000000000000E0L,*/
305 /* J1(x) cosX + Y1(x) sinX = sqrt( 2/(pi x)) P1(x)
306 P1(x) = 1 + z^2 R(z^2), z=1/x
307 2.85711669921875 <= x <= 4.54541015625
308 Peak relative error 6.5e-21 */
309 static const long double pr3
[7] = {
310 1.265251153957366716825382654273326407972E-5L,
311 8.031057269201324914127680782288352574567E-4L,
312 1.581648121115028333661412169396282881035E-2L,
313 1.179534658087796321928362981518645033967E-1L,
314 3.227936912780465219246440724502790727866E-1L,
315 2.559223765418386621748404398017602935764E-1L,
316 2.277136933287817911091370397134882441046E-2L,
318 static const long double ps3
[6] = {
319 1.079681071833391818661952793568345057548E-4L,
320 6.986017817100477138417481463810841529026E-3L,
321 1.429403701146942509913198539100230540503E-1L,
322 1.148392024337075609460312658938700765074E0L
,
323 3.643663015091248720208251490291968840882E0L
,
324 3.990702269032018282145100741746633960737E0L
,
325 /* 1.000000000000000000000000000000000000000E0L, */
328 /* J1(x) cosX + Y1(x) sinX = sqrt( 2/(pi x)) P1(x)
329 P1(x) = 1 + z^2 R(z^2), z=1/x
330 2 <= x <= 2.85711669921875
331 Peak relative error 3.5e-21 */
332 static const long double pr2
[7] = {
333 2.795623248568412225239401141338714516445E-4L,
334 1.092578168441856711925254839815430061135E-2L,
335 1.278024620468953761154963591853679640560E-1L,
336 5.469680473691500673112904286228351988583E-1L,
337 8.313769490922351300461498619045639016059E-1L,
338 3.544176317308370086415403567097130611468E-1L,
339 1.604142674802373041247957048801599740644E-2L,
341 static const long double ps2
[6] = {
342 2.385605161555183386205027000675875235980E-3L,
343 9.616778294482695283928617708206967248579E-2L,
344 1.195215570959693572089824415393951258510E0L
,
345 5.718412857897054829999458736064922974662E0L
,
346 1.065626298505499086386584642761602177568E1L
,
347 6.809140730053382188468983548092322151791E0L
,
348 /* 1.000000000000000000000000000000000000000E0L, */
355 const long double *p
, *q
;
358 u_int32_t se
, i0
, i1
;
360 GET_LDOUBLE_WORDS (se
, i0
, i1
, x
);
362 /* ix >= 0x4000 for all calls to this function. */
363 if (ix
>= 0x4002) /* x >= 8 */
370 i1
= (ix
<< 16) | (i0
>> 16);
371 if (i1
>= 0x40019174) /* x >= 4.54541015625 */
376 else if (i1
>= 0x4000b6db) /* x >= 2.85711669921875 */
388 r
= p
[0] + z
* (p
[1] +
389 z
* (p
[2] + z
* (p
[3] + z
* (p
[4] + z
* (p
[5] + z
* p
[6])))));
390 s
= q
[0] + z
* (q
[1] + z
* (q
[2] + z
* (q
[3] + z
* (q
[4] + z
* (q
[5] + z
)))));
391 return one
+ z
* r
/ s
;
395 /* For x >= 8, the asymptotic expansions of qone is
396 * 3/8 s - 105/1024 s^3 - ..., where s = 1/x.
397 * We approximate pone by
398 * qone(x) = s*(0.375 + (R/S))
401 /* Y1(x)cosX - J1(x)sinX = sqrt( 2/(pi x)) Q1(x),
402 Q1(x) = z(.375 + z^2 R(z^2)), z=1/x
404 Peak relative error 8.3e-22 */
406 static const long double qr8
[7] = {
407 -5.691925079044209246015366919809404457380E-10L,
408 -1.632587664706999307871963065396218379137E-7L,
409 -1.577424682764651970003637263552027114600E-5L,
410 -6.377627959241053914770158336842725291713E-4L,
411 -1.087408516779972735197277149494929568768E-2L,
412 -6.854943629378084419631926076882330494217E-2L,
413 -1.055448290469180032312893377152490183203E-1L,
415 static const long double qs8
[7] = {
416 5.550982172325019811119223916998393907513E-9L,
417 1.607188366646736068460131091130644192244E-6L,
418 1.580792530091386496626494138334505893599E-4L,
419 6.617859900815747303032860443855006056595E-3L,
420 1.212840547336984859952597488863037659161E-1L,
421 9.017885953937234900458186716154005541075E-1L,
422 2.201114489712243262000939120146436167178E0L
,
423 /* 1.000000000000000000000000000000000000000E0L, */
426 /* Y1(x)cosX - J1(x)sinX = sqrt( 2/(pi x)) Q1(x),
427 Q1(x) = z(.375 + z^2 R(z^2)), z=1/x
428 4.54541015625 <= x <= 8
429 Peak relative error 4.1e-22 */
430 static const long double qr5
[7] = {
431 -6.719134139179190546324213696633564965983E-8L,
432 -9.467871458774950479909851595678622044140E-6L,
433 -4.429341875348286176950914275723051452838E-4L,
434 -8.539898021757342531563866270278505014487E-3L,
435 -6.818691805848737010422337101409276287170E-2L,
436 -1.964432669771684034858848142418228214855E-1L,
437 -1.333896496989238600119596538299938520726E-1L,
439 static const long double qs5
[7] = {
440 6.552755584474634766937589285426911075101E-7L,
441 9.410814032118155978663509073200494000589E-5L,
442 4.561677087286518359461609153655021253238E-3L,
443 9.397742096177905170800336715661091535805E-2L,
444 8.518538116671013902180962914473967738771E-1L,
445 3.177729183645800174212539541058292579009E0L
,
446 4.006745668510308096259753538973038902990E0L
,
447 /* 1.000000000000000000000000000000000000000E0L, */
450 /* Y1(x)cosX - J1(x)sinX = sqrt( 2/(pi x)) Q1(x),
451 Q1(x) = z(.375 + z^2 R(z^2)), z=1/x
452 2.85711669921875 <= x <= 4.54541015625
453 Peak relative error 2.2e-21 */
454 static const long double qr3
[7] = {
455 -3.618746299358445926506719188614570588404E-6L,
456 -2.951146018465419674063882650970344502798E-4L,
457 -7.728518171262562194043409753656506795258E-3L,
458 -8.058010968753999435006488158237984014883E-2L,
459 -3.356232856677966691703904770937143483472E-1L,
460 -4.858192581793118040782557808823460276452E-1L,
461 -1.592399251246473643510898335746432479373E-1L,
463 static const long double qs3
[7] = {
464 3.529139957987837084554591421329876744262E-5L,
465 2.973602667215766676998703687065066180115E-3L,
466 8.273534546240864308494062287908662592100E-2L,
467 9.613359842126507198241321110649974032726E-1L,
468 4.853923697093974370118387947065402707519E0L
,
469 1.002671608961669247462020977417828796933E1L
,
470 7.028927383922483728931327850683151410267E0L
,
471 /* 1.000000000000000000000000000000000000000E0L, */
474 /* Y1(x)cosX - J1(x)sinX = sqrt( 2/(pi x)) Q1(x),
475 Q1(x) = z(.375 + z^2 R(z^2)), z=1/x
476 2 <= x <= 2.85711669921875
477 Peak relative error 6.9e-22 */
478 static const long double qr2
[7] = {
479 -1.372751603025230017220666013816502528318E-4L,
480 -6.879190253347766576229143006767218972834E-3L,
481 -1.061253572090925414598304855316280077828E-1L,
482 -6.262164224345471241219408329354943337214E-1L,
483 -1.423149636514768476376254324731437473915E0L
,
484 -1.087955310491078933531734062917489870754E0L
,
485 -1.826821119773182847861406108689273719137E-1L,
487 static const long double qs2
[7] = {
488 1.338768933634451601814048220627185324007E-3L,
489 7.071099998918497559736318523932241901810E-2L,
490 1.200511429784048632105295629933382142221E0L
,
491 8.327301713640367079030141077172031825276E0L
,
492 2.468479301872299311658145549931764426840E1L
,
493 2.961179686096262083509383820557051621644E1L
,
494 1.201402313144305153005639494661767354977E1L
,
495 /* 1.000000000000000000000000000000000000000E0L, */
502 const long double *p
, *q
;
503 static long double s
, r
, z
;
505 u_int32_t se
, i0
, i1
;
507 GET_LDOUBLE_WORDS (se
, i0
, i1
, x
);
509 /* ix >= 0x4000 for all calls to this function. */
510 if (ix
>= 0x4002) /* x >= 8 */
517 i1
= (ix
<< 16) | (i0
>> 16);
518 if (i1
>= 0x40019174) /* x >= 4.54541015625 */
523 else if (i1
>= 0x4000b6db) /* x >= 2.85711669921875 */
537 z
* (p
[2] + z
* (p
[3] + z
* (p
[4] + z
* (p
[5] + z
* p
[6])))));
541 z
* (q
[3] + z
* (q
[4] + z
* (q
[5] + z
* (q
[6] + z
))))));
542 return (.375 + z
* r
/ s
) / x
;