besy0.f 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. *DECK BESY0
  2. FUNCTION BESY0 (X)
  3. C***BEGIN PROLOGUE BESY0
  4. C***PURPOSE Compute the Bessel function of the second kind of order
  5. C zero.
  6. C***LIBRARY SLATEC (FNLIB)
  7. C***CATEGORY C10A1
  8. C***TYPE SINGLE PRECISION (BESY0-S, DBESY0-D)
  9. C***KEYWORDS BESSEL FUNCTION, FNLIB, ORDER ZERO, SECOND KIND,
  10. C SPECIAL FUNCTIONS
  11. C***AUTHOR Fullerton, W., (LANL)
  12. C***DESCRIPTION
  13. C
  14. C BESY0(X) calculates the Bessel function of the second kind
  15. C of order zero for real argument X.
  16. C
  17. C Series for BY0 on the interval 0. to 1.60000D+01
  18. C with weighted error 1.20E-17
  19. C log weighted error 16.92
  20. C significant figures required 16.15
  21. C decimal places required 17.48
  22. C
  23. C Series for BM0 on the interval 0. to 6.25000D-02
  24. C with weighted error 4.98E-17
  25. C log weighted error 16.30
  26. C significant figures required 14.97
  27. C decimal places required 16.96
  28. C
  29. C Series for BTH0 on the interval 0. to 6.25000D-02
  30. C with weighted error 3.67E-17
  31. C log weighted error 16.44
  32. C significant figures required 15.53
  33. C decimal places required 17.13
  34. C
  35. C***REFERENCES (NONE)
  36. C***ROUTINES CALLED BESJ0, CSEVL, INITS, R1MACH, XERMSG
  37. C***REVISION HISTORY (YYMMDD)
  38. C 770401 DATE WRITTEN
  39. C 890531 Changed all specific intrinsics to generic. (WRB)
  40. C 890531 REVISION DATE from Version 3.2
  41. C 891214 Prologue converted to Version 4.0 format. (BAB)
  42. C 900315 CALLs to XERROR changed to CALLs to XERMSG. (THJ)
  43. C 900326 Removed duplicate information from DESCRIPTION section.
  44. C (WRB)
  45. C***END PROLOGUE BESY0
  46. DIMENSION BY0CS(13), BM0CS(21), BTH0CS(24)
  47. LOGICAL FIRST
  48. SAVE BY0CS, BM0CS, BTH0CS, TWODPI, PI4,
  49. 1 NTY0, NTM0, NTTH0, XSML, XMAX, FIRST
  50. DATA BY0CS( 1) / -.0112778393 92865573E0 /
  51. DATA BY0CS( 2) / -.1283452375 6042035E0 /
  52. DATA BY0CS( 3) / -.1043788479 9794249E0 /
  53. DATA BY0CS( 4) / .0236627491 83969695E0 /
  54. DATA BY0CS( 5) / -.0020903916 47700486E0 /
  55. DATA BY0CS( 6) / .0001039754 53939057E0 /
  56. DATA BY0CS( 7) / -.0000033697 47162423E0 /
  57. DATA BY0CS( 8) / .0000000772 93842676E0 /
  58. DATA BY0CS( 9) / -.0000000013 24976772E0 /
  59. DATA BY0CS(10) / .0000000000 17648232E0 /
  60. DATA BY0CS(11) / -.0000000000 00188105E0 /
  61. DATA BY0CS(12) / .0000000000 00001641E0 /
  62. DATA BY0CS(13) / -.0000000000 00000011E0 /
  63. DATA BM0CS( 1) / .0928496163 7381644E0 /
  64. DATA BM0CS( 2) / -.0014298770 7403484E0 /
  65. DATA BM0CS( 3) / .0000283057 9271257E0 /
  66. DATA BM0CS( 4) / -.0000014330 0611424E0 /
  67. DATA BM0CS( 5) / .0000001202 8628046E0 /
  68. DATA BM0CS( 6) / -.0000000139 7113013E0 /
  69. DATA BM0CS( 7) / .0000000020 4076188E0 /
  70. DATA BM0CS( 8) / -.0000000003 5399669E0 /
  71. DATA BM0CS( 9) / .0000000000 7024759E0 /
  72. DATA BM0CS(10) / -.0000000000 1554107E0 /
  73. DATA BM0CS(11) / .0000000000 0376226E0 /
  74. DATA BM0CS(12) / -.0000000000 0098282E0 /
  75. DATA BM0CS(13) / .0000000000 0027408E0 /
  76. DATA BM0CS(14) / -.0000000000 0008091E0 /
  77. DATA BM0CS(15) / .0000000000 0002511E0 /
  78. DATA BM0CS(16) / -.0000000000 0000814E0 /
  79. DATA BM0CS(17) / .0000000000 0000275E0 /
  80. DATA BM0CS(18) / -.0000000000 0000096E0 /
  81. DATA BM0CS(19) / .0000000000 0000034E0 /
  82. DATA BM0CS(20) / -.0000000000 0000012E0 /
  83. DATA BM0CS(21) / .0000000000 0000004E0 /
  84. DATA BTH0CS( 1) / -.2463916377 4300119E0 /
  85. DATA BTH0CS( 2) / .0017370983 07508963E0 /
  86. DATA BTH0CS( 3) / -.0000621836 33402968E0 /
  87. DATA BTH0CS( 4) / .0000043680 50165742E0 /
  88. DATA BTH0CS( 5) / -.0000004560 93019869E0 /
  89. DATA BTH0CS( 6) / .0000000621 97400101E0 /
  90. DATA BTH0CS( 7) / -.0000000103 00442889E0 /
  91. DATA BTH0CS( 8) / .0000000019 79526776E0 /
  92. DATA BTH0CS( 9) / -.0000000004 28198396E0 /
  93. DATA BTH0CS(10) / .0000000001 02035840E0 /
  94. DATA BTH0CS(11) / -.0000000000 26363898E0 /
  95. DATA BTH0CS(12) / .0000000000 07297935E0 /
  96. DATA BTH0CS(13) / -.0000000000 02144188E0 /
  97. DATA BTH0CS(14) / .0000000000 00663693E0 /
  98. DATA BTH0CS(15) / -.0000000000 00215126E0 /
  99. DATA BTH0CS(16) / .0000000000 00072659E0 /
  100. DATA BTH0CS(17) / -.0000000000 00025465E0 /
  101. DATA BTH0CS(18) / .0000000000 00009229E0 /
  102. DATA BTH0CS(19) / -.0000000000 00003448E0 /
  103. DATA BTH0CS(20) / .0000000000 00001325E0 /
  104. DATA BTH0CS(21) / -.0000000000 00000522E0 /
  105. DATA BTH0CS(22) / .0000000000 00000210E0 /
  106. DATA BTH0CS(23) / -.0000000000 00000087E0 /
  107. DATA BTH0CS(24) / .0000000000 00000036E0 /
  108. DATA TWODPI / 0.6366197723 6758134E0 /
  109. DATA PI4 / 0.7853981633 9744831E0 /
  110. DATA FIRST /.TRUE./
  111. C***FIRST EXECUTABLE STATEMENT BESY0
  112. IF (FIRST) THEN
  113. NTY0 = INITS (BY0CS, 13, 0.1*R1MACH(3))
  114. NTM0 = INITS (BM0CS, 21, 0.1*R1MACH(3))
  115. NTTH0 = INITS (BTH0CS, 24, 0.1*R1MACH(3))
  116. C
  117. XSML = SQRT (4.0*R1MACH(3))
  118. XMAX = 1.0/R1MACH(4)
  119. ENDIF
  120. FIRST = .FALSE.
  121. C
  122. IF (X .LE. 0.) CALL XERMSG ('SLATEC', 'BESY0',
  123. + 'X IS ZERO OR NEGATIVE', 1, 2)
  124. IF (X.GT.4.0) GO TO 20
  125. C
  126. Y = 0.
  127. IF (X.GT.XSML) Y = X*X
  128. BESY0 = TWODPI*LOG(0.5*X)*BESJ0(X) + .375 + CSEVL (.125*Y-1.,
  129. 1 BY0CS, NTY0)
  130. RETURN
  131. C
  132. 20 IF (X .GT. XMAX) CALL XERMSG ('SLATEC', 'BESY0',
  133. + 'NO PRECISION BECAUSE X IS BIG', 2, 2)
  134. C
  135. Z = 32.0/X**2 - 1.0
  136. AMPL = (0.75 + CSEVL (Z, BM0CS, NTM0)) / SQRT(X)
  137. THETA = X - PI4 + CSEVL (Z, BTH0CS, NTTH0) / X
  138. BESY0 = AMPL * SIN (THETA)
  139. C
  140. RETURN
  141. END