d9knus.f 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252
  1. *DECK D9KNUS
  2. SUBROUTINE D9KNUS (XNU, X, BKNU, BKNU1, ISWTCH)
  3. C***BEGIN PROLOGUE D9KNUS
  4. C***SUBSIDIARY
  5. C***PURPOSE Compute Bessel functions EXP(X)*K-SUB-XNU(X) and EXP(X)*
  6. C K-SUB-XNU+1(X) for 0.0 .LE. XNU .LT. 1.0.
  7. C***LIBRARY SLATEC (FNLIB)
  8. C***CATEGORY C10B3
  9. C***TYPE DOUBLE PRECISION (R9KNUS-S, D9KNUS-D)
  10. C***KEYWORDS BESSEL FUNCTION, FNLIB, SPECIAL FUNCTIONS
  11. C***AUTHOR Fullerton, W., (LANL)
  12. C***DESCRIPTION
  13. C
  14. C Compute Bessel functions EXP(X) * K-sub-XNU (X) and
  15. C EXP(X) * K-sub-XNU+1 (X) for 0.0 .LE. XNU .LT. 1.0 .
  16. C
  17. C Series for C0K on the interval 0. to 2.50000E-01
  18. C with weighted error 2.16E-32
  19. C log weighted error 31.67
  20. C significant figures required 30.86
  21. C decimal places required 32.40
  22. C
  23. C Series for ZNU1 on the interval -7.00000E-01 to 0.
  24. C with weighted error 2.45E-33
  25. C log weighted error 32.61
  26. C significant figures required 31.85
  27. C decimal places required 33.26
  28. C
  29. C***REFERENCES (NONE)
  30. C***ROUTINES CALLED D1MACH, DCSEVL, DGAMMA, INITDS, XERMSG
  31. C***REVISION HISTORY (YYMMDD)
  32. C 770601 DATE WRITTEN
  33. C 890531 Changed all specific intrinsics to generic. (WRB)
  34. C 890911 Removed unnecessary intrinsics. (WRB)
  35. C 890911 REVISION DATE from Version 3.2
  36. C 891214 Prologue converted to Version 4.0 format. (BAB)
  37. C 900315 CALLs to XERROR changed to CALLs to XERMSG. (THJ)
  38. C 900720 Routine changed from user-callable to subsidiary. (WRB)
  39. C 900727 Added EXTERNAL statement. (WRB)
  40. C 920618 Removed space from variable names. (RWC, WRB)
  41. C***END PROLOGUE D9KNUS
  42. DOUBLE PRECISION XNU, X, BKNU, BKNU1, ALPHA(32), BETA(32), A(32),
  43. 1 C0KCS(29), ZNU1CS(20), ALNZ, ALN2, A0, BKNUD, BKNU0,
  44. 2 B0, C0, EULER, EXPX, P1, P2, P3, QQ, RESULT, SQPI2, SQRTX, V,
  45. 3 VLNZ, XI, XMU, XNUSML, XSML, X2N, X2TOV, Z, ZTOV, ALNSML,
  46. 4 ALNBIG
  47. REAL ALNEPS
  48. DOUBLE PRECISION D1MACH, DCSEVL, DGAMMA
  49. LOGICAL FIRST
  50. EXTERNAL DGAMMA
  51. SAVE C0KCS, ZNU1CS, EULER, SQPI2, ALN2, NTC0K,
  52. 1 NTZNU1, XNUSML, XSML, ALNSML, ALNBIG, ALNEPS, FIRST
  53. DATA C0KCS( 1) / +.6018305724 2626108387 5774451803 29 D-1 /
  54. DATA C0KCS( 2) / -.1536487143 3017286092 9597559431 24 D+0 /
  55. DATA C0KCS( 3) / -.1175117600 8210492040 0682292262 13 D-1 /
  56. DATA C0KCS( 4) / -.8524878889 1979509827 0484015509 87 D-3 /
  57. DATA C0KCS( 5) / -.6132983876 7496791874 0981769221 11 D-4 /
  58. DATA C0KCS( 6) / -.4405228124 5510444562 6798895485 05 D-5 /
  59. DATA C0KCS( 7) / -.3163124672 8384488192 9154458921 99 D-6 /
  60. DATA C0KCS( 8) / -.2271071938 2899588330 6737717933 96 D-7 /
  61. DATA C0KCS( 9) / -.1630564460 8077609552 2746205153 60 D-8 /
  62. DATA C0KCS( 10) / -.1170693929 9414776568 7560440431 30 D-9 /
  63. DATA C0KCS( 11) / -.8405206378 6464437174 5465934137 92 D-11 /
  64. DATA C0KCS( 12) / -.6034667011 8979991487 0960507371 98 D-12 /
  65. DATA C0KCS( 13) / -.4332696033 5681371952 0459973669 03 D-13 /
  66. DATA C0KCS( 14) / -.3110735803 0203546214 6346977722 37 D-14 /
  67. DATA C0KCS( 15) / -.2233407822 6736982254 4861334098 40 D-15 /
  68. DATA C0KCS( 16) / -.1603514671 6864226300 6357915286 10 D-16 /
  69. DATA C0KCS( 17) / -.1151271736 3666556196 0356977053 05 D-17 /
  70. DATA C0KCS( 18) / -.8265759174 6836959105 1694790892 58 D-19 /
  71. DATA C0KCS( 19) / -.5934548080 6383948172 3334366959 84 D-20 /
  72. DATA C0KCS( 20) / -.4260813819 6467143926 4996130239 76 D-21 /
  73. DATA C0KCS( 21) / -.3059126686 4812876299 2636983705 42 D-22 /
  74. DATA C0KCS( 22) / -.2196354142 6734575224 9755018155 16 D-23 /
  75. DATA C0KCS( 23) / -.1576911326 1495836071 1057506847 60 D-24 /
  76. DATA C0KCS( 24) / -.1132171393 5950320948 7577310480 56 D-25 /
  77. DATA C0KCS( 25) / -.8128624883 4598404082 7923497144 33 D-27 /
  78. DATA C0KCS( 26) / -.5836090089 3453226552 8293493159 49 D-28 /
  79. DATA C0KCS( 27) / -.4190124162 3610922519 4523377809 05 D-29 /
  80. DATA C0KCS( 28) / -.3008373796 0206435069 5305042128 62 D-30 /
  81. DATA C0KCS( 29) / -.2159915206 7808647728 3421680898 32 D-31 /
  82. DATA ZNU1CS( 1) / +.2033067569 9419172967 4444001216 911 D+0 /
  83. DATA ZNU1CS( 2) / +.1400779334 1321977106 2943670790 563 D+0 /
  84. DATA ZNU1CS( 3) / +.7916796961 0016135284 0972241972 320 D-2 /
  85. DATA ZNU1CS( 4) / +.3398011825 3210404535 2930092205 750 D-3 /
  86. DATA ZNU1CS( 5) / +.1174197568 8989336666 4507228352 690 D-4 /
  87. DATA ZNU1CS( 6) / +.3393575706 1226168033 3825865475 121 D-6 /
  88. DATA ZNU1CS( 7) / +.8425941769 7621991019 4629891264 803 D-8 /
  89. DATA ZNU1CS( 8) / +.1833366770 2485008918 4748150900 090 D-9 /
  90. DATA ZNU1CS( 9) / +.3549698447 0441631086 3007064469 557 D-11 /
  91. DATA ZNU1CS( 10) / +.6190324964 6988733220 5244342078 407 D-13 /
  92. DATA ZNU1CS( 11) / +.9819645356 8043942496 0346115456 527 D-15 /
  93. DATA ZNU1CS( 12) / +.1428513143 9649047421 1473563005 985 D-16 /
  94. DATA ZNU1CS( 13) / +.1918949218 8782529896 6162467488 436 D-18 /
  95. DATA ZNU1CS( 14) / +.2394309797 3949891416 2313140597 128 D-20 /
  96. DATA ZNU1CS( 15) / +.2788902468 1534735483 5870465474 995 D-22 /
  97. DATA ZNU1CS( 16) / +.3046066506 3303344258 2845214092 865 D-24 /
  98. DATA ZNU1CS( 17) / +.3131732370 4219181577 1564260932 089 D-26 /
  99. DATA ZNU1CS( 18) / +.3041330989 8785495164 5174908005 034 D-28 /
  100. DATA ZNU1CS( 19) / +.2798403846 3683308434 3185097659 733 D-30 /
  101. DATA ZNU1CS( 20) / +.2446371862 7449759648 5238794922 666 D-32 /
  102. DATA EULER / 0.5772156649 0153286060 6512090082 40D0 /
  103. DATA SQPI2 / +1.253314137 3155002512 0788264240 55 D0 /
  104. DATA ALN2 / 0.6931471805 5994530941 7232121458 18D0 /
  105. DATA FIRST /.TRUE./
  106. C***FIRST EXECUTABLE STATEMENT D9KNUS
  107. IF (FIRST) THEN
  108. ETA = 0.1D0*D1MACH(3)
  109. NTC0K = INITDS (C0KCS, 29, ETA)
  110. NTZNU1 = INITDS (ZNU1CS, 20, ETA)
  111. C
  112. XNUSML = SQRT(D1MACH(3)/8.D0)
  113. XSML = 0.1D0*D1MACH(3)
  114. ALNSML = LOG (D1MACH(1))
  115. ALNBIG = LOG (D1MACH(2))
  116. ALNEPS = LOG (0.1D0*D1MACH(3))
  117. ENDIF
  118. FIRST = .FALSE.
  119. C
  120. IF (XNU .LT. 0.D0 .OR. XNU .GE. 1.D0) CALL XERMSG ('SLATEC',
  121. + 'D9KNUS', 'XNU MUST BE GE 0 AND LT 1', 1, 2)
  122. IF (X .LE. 0.) CALL XERMSG ('SLATEC', 'D9KNUS', 'X MUST BE GT 0',
  123. + 2, 2)
  124. C
  125. ISWTCH = 0
  126. IF (X.GT.2.0D0) GO TO 50
  127. C
  128. C X IS SMALL. COMPUTE K-SUB-XNU (X) AND THE DERIVATIVE OF K-SUB-XNU (X)
  129. C THEN FIND K-SUB-XNU+1 (X). XNU IS REDUCED TO THE INTERVAL (-.5,+.5)
  130. C THEN TO (0., .5), BECAUSE K OF NEGATIVE ORDER (-NU) = K OF POSITIVE
  131. C ORDER (+NU).
  132. C
  133. V = XNU
  134. IF (XNU.GT.0.5D0) V = 1.0D0 - XNU
  135. C
  136. C CAREFULLY FIND (X/2)**XNU AND Z**XNU WHERE Z = X*X/4.
  137. ALNZ = 2.D0 * (LOG(X) - ALN2)
  138. C
  139. IF (X.GT.XNU) GO TO 20
  140. IF (-0.5D0*XNU*ALNZ-ALN2-LOG(XNU) .GT. ALNBIG) CALL XERMSG
  141. + ('SLATEC', 'D9KNUS', 'X SO SMALL BESSEL K-SUB-XNU OVERFLOWS',
  142. + 3, 2)
  143. C
  144. 20 VLNZ = V*ALNZ
  145. X2TOV = EXP (0.5D0*VLNZ)
  146. ZTOV = 0.0D0
  147. IF (VLNZ.GT.ALNSML) ZTOV = X2TOV**2
  148. C
  149. A0 = 0.5D0*DGAMMA(1.0D0+V)
  150. B0 = 0.5D0*DGAMMA(1.0D0-V)
  151. C0 = -EULER
  152. IF (ZTOV.GT.0.5D0 .AND. V.GT.XNUSML) C0 = -0.75D0 +
  153. 1 DCSEVL ((8.0D0*V)*V-1.0D0, C0KCS, NTC0K)
  154. C
  155. IF (ZTOV.LE.0.5D0) ALPHA(1) = (A0-ZTOV*B0)/V
  156. IF (ZTOV.GT.0.5D0) ALPHA(1) = C0 - ALNZ*(0.75D0 +
  157. 1 DCSEVL (VLNZ/0.35D0+1.0D0, ZNU1CS, NTZNU1))*B0
  158. BETA(1) = -0.5D0*(A0+ZTOV*B0)
  159. C
  160. Z = 0.0D0
  161. IF (X.GT.XSML) Z = 0.25D0*X*X
  162. NTERMS = MAX (2.0, 11.0+(8.*REAL(ALNZ)-25.19-ALNEPS)
  163. 1 /(4.28-REAL(ALNZ)))
  164. DO 30 I=2,NTERMS
  165. XI = I - 1
  166. A0 = A0/(XI*(XI-V))
  167. B0 = B0/(XI*(XI+V))
  168. ALPHA(I) = (ALPHA(I-1)+2.0D0*XI*A0)/(XI*(XI+V))
  169. BETA(I) = (XI-0.5D0*V)*ALPHA(I) - ZTOV*B0
  170. 30 CONTINUE
  171. C
  172. BKNU = ALPHA(NTERMS)
  173. BKNUD = BETA(NTERMS)
  174. DO 40 II=2,NTERMS
  175. I = NTERMS + 1 - II
  176. BKNU = ALPHA(I) + BKNU*Z
  177. BKNUD = BETA(I) + BKNUD*Z
  178. 40 CONTINUE
  179. C
  180. EXPX = EXP(X)
  181. BKNU = EXPX*BKNU/X2TOV
  182. C
  183. IF (-0.5D0*(XNU+1.D0)*ALNZ-2.0D0*ALN2.GT.ALNBIG) ISWTCH = 1
  184. IF (ISWTCH.EQ.1) RETURN
  185. BKNUD = EXPX*BKNUD*2.0D0/(X2TOV*X)
  186. C
  187. IF (XNU.LE.0.5D0) BKNU1 = V*BKNU/X - BKNUD
  188. IF (XNU.LE.0.5D0) RETURN
  189. C
  190. BKNU0 = BKNU
  191. BKNU = -V*BKNU/X - BKNUD
  192. BKNU1 = 2.0D0*XNU*BKNU/X + BKNU0
  193. RETURN
  194. C
  195. C X IS LARGE. FIND K-SUB-XNU (X) AND K-SUB-XNU+1 (X) WITH Y. L. LUKE-S
  196. C RATIONAL EXPANSION.
  197. C
  198. 50 SQRTX = SQRT(X)
  199. IF (X.GT.1.0D0/XSML) GO TO 90
  200. AN = -0.60 - 1.02/REAL(X)
  201. BN = -0.27 - 0.53/REAL(X)
  202. NTERMS = MIN (32, MAX1 (3.0, AN+BN*ALNEPS))
  203. C
  204. DO 80 INU=1,2
  205. XMU = 0.D0
  206. IF (INU.EQ.1 .AND. XNU.GT.XNUSML) XMU = (4.0D0*XNU)*XNU
  207. IF (INU.EQ.2) XMU = 4.0D0*(ABS(XNU)+1.D0)**2
  208. C
  209. A(1) = 1.0D0 - XMU
  210. A(2) = 9.0D0 - XMU
  211. A(3) = 25.0D0 - XMU
  212. IF (A(2).EQ.0.D0) RESULT = SQPI2*(16.D0*X+XMU+7.D0) /
  213. 1 (16.D0*X*SQRTX)
  214. IF (A(2).EQ.0.D0) GO TO 70
  215. C
  216. ALPHA(1) = 1.0D0
  217. ALPHA(2) = (16.D0*X+A(2))/A(2)
  218. ALPHA(3) = ((768.D0*X+48.D0*A(3))*X + A(2)*A(3))/(A(2)*A(3))
  219. C
  220. BETA(1) = 1.0D0
  221. BETA(2) = (16.D0*X+(XMU+7.D0))/A(2)
  222. BETA(3) = ((768.D0*X+48.D0*(XMU+23.D0))*X +
  223. 1 ((XMU+62.D0)*XMU+129.D0))/(A(2)*A(3))
  224. C
  225. IF (NTERMS.LT.4) GO TO 65
  226. DO 60 I=4,NTERMS
  227. N = I - 1
  228. X2N = 2*N - 1
  229. C
  230. A(I) = (X2N+2.D0)**2 - XMU
  231. QQ = 16.D0*X2N/A(I)
  232. P1 = -X2N*((12*N*N-20*N)-A(1))/((X2N-2.D0)*A(I))
  233. 1 - QQ*X
  234. P2 = ((12*N*N-28*N+8)-A(1))/A(I) - QQ*X
  235. P3 = -X2N*A(I-3)/((X2N-2.D0)*A(I))
  236. C
  237. ALPHA(I) = -P1*ALPHA(I-1) - P2*ALPHA(I-2) - P3*ALPHA(I-3)
  238. BETA(I) = -P1*BETA(I-1) - P2*BETA(I-2) - P3*BETA(I-3)
  239. 60 CONTINUE
  240. C
  241. 65 RESULT = SQPI2*BETA(NTERMS)/(SQRTX*ALPHA(NTERMS))
  242. C
  243. 70 IF (INU.EQ.1) BKNU = RESULT
  244. IF (INU.EQ.2) BKNU1 = RESULT
  245. 80 CONTINUE
  246. RETURN
  247. C
  248. 90 BKNU = SQPI2/SQRTX
  249. BKNU1 = BKNU
  250. RETURN
  251. C
  252. END