FUNCTION BESY0(X) C***BEGIN PROLOGUE BESY0 C***DATE WRITTEN 770401 (YYMMDD) C***REVISION DATE 840405 (YYMMDD) C***CATEGORY NO. C10A1 C***KEYWORDS BESSEL FUNCTION,ORDER ZERO,SECOND KIND,SPECIAL FUNCTION C***AUTHOR FULLERTON, W., (LANL) C***PURPOSE Computes the Bessel function of the second kind of order C zero. C***DESCRIPTION C C BESY0(X) calculates the Bessel function of the second kind C of order zero for real argument X. C C Series for BY0 on the interval 0. to 1.60000D+01 C with weighted error 1.20E-17 C log weighted error 16.92 C significant figures required 16.15 C decimal places required 17.48 C C Series for BM0 on the interval 0. to 6.25000D-02 C with weighted error 4.98E-17 C log weighted error 16.30 C significant figures required 14.97 C decimal places required 16.96 C C Series for BTH0 on the interval 0. to 6.25000D-02 C with weighted error 3.67E-17 C log weighted error 16.44 C significant figures required 15.53 C decimal places required 17.13 C***REFERENCES (NONE) C***ROUTINES CALLED BESJ0,CSEVL,INITS,R1MACH,XERROR C***END PROLOGUE BESY0 DIMENSION BY0CS(13), BM0CS(21), BTH0CS(24) DATA BY0 CS( 1) / -.0112778393 92865573E0 / DATA BY0 CS( 2) / -.1283452375 6042035E0 / DATA BY0 CS( 3) / -.1043788479 9794249E0 / DATA BY0 CS( 4) / .0236627491 83969695E0 / DATA BY0 CS( 5) / -.0020903916 47700486E0 / DATA BY0 CS( 6) / .0001039754 53939057E0 / DATA BY0 CS( 7) / -.0000033697 47162423E0 / DATA BY0 CS( 8) / .0000000772 93842676E0 / DATA BY0 CS( 9) / -.0000000013 24976772E0 / DATA BY0 CS(10) / .0000000000 17648232E0 / DATA BY0 CS(11) / -.0000000000 00188105E0 / DATA BY0 CS(12) / .0000000000 00001641E0 / DATA BY0 CS(13) / -.0000000000 00000011E0 / DATA BM0 CS( 1) / .0928496163 7381644E0 / DATA BM0 CS( 2) / -.0014298770 7403484E0 / DATA BM0 CS( 3) / .0000283057 9271257E0 / DATA BM0 CS( 4) / -.0000014330 0611424E0 / DATA BM0 CS( 5) / .0000001202 8628046E0 / DATA BM0 CS( 6) / -.0000000139 7113013E0 / DATA BM0 CS( 7) / .0000000020 4076188E0 / DATA BM0 CS( 8) / -.0000000003 5399669E0 / DATA BM0 CS( 9) / .0000000000 7024759E0 / DATA BM0 CS(10) / -.0000000000 1554107E0 / DATA BM0 CS(11) / .0000000000 0376226E0 / DATA BM0 CS(12) / -.0000000000 0098282E0 / DATA BM0 CS(13) / .0000000000 0027408E0 / DATA BM0 CS(14) / -.0000000000 0008091E0 / DATA BM0 CS(15) / .0000000000 0002511E0 / DATA BM0 CS(16) / -.0000000000 0000814E0 / DATA BM0 CS(17) / .0000000000 0000275E0 / DATA BM0 CS(18) / -.0000000000 0000096E0 / DATA BM0 CS(19) / .0000000000 0000034E0 / DATA BM0 CS(20) / -.0000000000 0000012E0 / DATA BM0 CS(21) / .0000000000 0000004E0 / DATA BTH0CS( 1) / -.2463916377 4300119E0 / DATA BTH0CS( 2) / .0017370983 07508963E0 / DATA BTH0CS( 3) / -.0000621836 33402968E0 / DATA BTH0CS( 4) / .0000043680 50165742E0 / DATA BTH0CS( 5) / -.0000004560 93019869E0 / DATA BTH0CS( 6) / .0000000621 97400101E0 / DATA BTH0CS( 7) / -.0000000103 00442889E0 / DATA BTH0CS( 8) / .0000000019 79526776E0 / DATA BTH0CS( 9) / -.0000000004 28198396E0 / DATA BTH0CS(10) / .0000000001 02035840E0 / DATA BTH0CS(11) / -.0000000000 26363898E0 / DATA BTH0CS(12) / .0000000000 07297935E0 / DATA BTH0CS(13) / -.0000000000 02144188E0 / DATA BTH0CS(14) / .0000000000 00663693E0 / DATA BTH0CS(15) / -.0000000000 00215126E0 / DATA BTH0CS(16) / .0000000000 00072659E0 / DATA BTH0CS(17) / -.0000000000 00025465E0 / DATA BTH0CS(18) / .0000000000 00009229E0 / DATA BTH0CS(19) / -.0000000000 00003448E0 / DATA BTH0CS(20) / .0000000000 00001325E0 / DATA BTH0CS(21) / -.0000000000 00000522E0 / DATA BTH0CS(22) / .0000000000 00000210E0 / DATA BTH0CS(23) / -.0000000000 00000087E0 / DATA BTH0CS(24) / .0000000000 00000036E0 / DATA TWODPI / 0.6366197723 6758134E0 / DATA PI4 / 0.7853981633 9744831E0 / DATA NTY0, NTM0, NTTH0, XSML, XMAX / 3*0, 2*0./ C***FIRST EXECUTABLE STATEMENT BESY0 IF (NTY0.NE.0) GO TO 10 NTY0 = INITS (BY0CS, 13, 0.1*R1MACH(3)) NTM0 = INITS (BM0CS, 21, 0.1*R1MACH(3)) NTTH0 = INITS (BTH0CS, 24, 0.1*R1MACH(3)) C XSML = SQRT (4.0*R1MACH(3)) XMAX = 1.0/R1MACH(4) C 10 IF (X.LE.0.) CALL XERROR ( 'BESY0 X IS ZERO OR NEGATIVE', 29, 1 1, 2) IF (X.GT.4.0) GO TO 20 C Y = 0. IF (X.GT.XSML) Y = X*X BESY0 = TWODPI*ALOG(0.5*X)*BESJ0(X) + .375 + CSEVL (.125*Y-1., 1 BY0CS, NTY0) RETURN C 20 IF (X.GT.XMAX) CALL XERROR ( 'BESY0 NO PRECISION BECAUSE X IS BI 1G', 37, 2, 2) C Z = 32.0/X**2 - 1.0 AMPL = (0.75 + CSEVL (Z, BM0CS, NTM0)) / SQRT(X) THETA = X - PI4 + CSEVL (Z, BTH0CS, NTTH0) / X BESY0 = AMPL * SIN (THETA) C RETURN END