besk1e.f 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. *DECK BESK1E
  2. FUNCTION BESK1E (X)
  3. C***BEGIN PROLOGUE BESK1E
  4. C***PURPOSE Compute the exponentially scaled modified (hyperbolic)
  5. C Bessel function of the third kind of order one.
  6. C***LIBRARY SLATEC (FNLIB)
  7. C***CATEGORY C10B1
  8. C***TYPE SINGLE PRECISION (BESK1E-S, DBSK1E-D)
  9. C***KEYWORDS EXPONENTIALLY SCALED, FNLIB, HYPERBOLIC BESSEL FUNCTION,
  10. C MODIFIED BESSEL FUNCTION, ORDER ONE, SPECIAL FUNCTIONS,
  11. C THIRD KIND
  12. C***AUTHOR Fullerton, W., (LANL)
  13. C***DESCRIPTION
  14. C
  15. C BESK1E(X) computes the exponentially scaled modified (hyperbolic)
  16. C Bessel function of third kind of order one for real argument
  17. C X .GT. 0.0, i.e., EXP(X)*K1(X).
  18. C
  19. C Series for BK1 on the interval 0. to 4.00000D+00
  20. C with weighted error 7.02E-18
  21. C log weighted error 17.15
  22. C significant figures required 16.73
  23. C decimal places required 17.67
  24. C
  25. C Series for AK1 on the interval 1.25000D-01 to 5.00000D-01
  26. C with weighted error 6.06E-17
  27. C log weighted error 16.22
  28. C significant figures required 15.41
  29. C decimal places required 16.83
  30. C
  31. C Series for AK12 on the interval 0. to 1.25000D-01
  32. C with weighted error 2.58E-17
  33. C log weighted error 16.59
  34. C significant figures required 15.22
  35. C decimal places required 17.16
  36. C
  37. C***REFERENCES (NONE)
  38. C***ROUTINES CALLED BESI1, CSEVL, INITS, R1MACH, XERMSG
  39. C***REVISION HISTORY (YYMMDD)
  40. C 770401 DATE WRITTEN
  41. C 890531 Changed all specific intrinsics to generic. (WRB)
  42. C 890531 REVISION DATE from Version 3.2
  43. C 891214 Prologue converted to Version 4.0 format. (BAB)
  44. C 900315 CALLs to XERROR changed to CALLs to XERMSG. (THJ)
  45. C 900326 Removed duplicate information from DESCRIPTION section.
  46. C (WRB)
  47. C***END PROLOGUE BESK1E
  48. DIMENSION BK1CS(11), AK1CS(17), AK12CS(14)
  49. LOGICAL FIRST
  50. SAVE BK1CS, AK1CS, AK12CS, NTK1, NTAK1, NTAK12, XMIN, XSML,
  51. 1 FIRST
  52. DATA BK1CS( 1) / .0253002273 389477705E0 /
  53. DATA BK1CS( 2) / -.3531559607 76544876E0 /
  54. DATA BK1CS( 3) / -.1226111808 22657148E0 /
  55. DATA BK1CS( 4) / -.0069757238 596398643E0 /
  56. DATA BK1CS( 5) / -.0001730288 957513052E0 /
  57. DATA BK1CS( 6) / -.0000024334 061415659E0 /
  58. DATA BK1CS( 7) / -.0000000221 338763073E0 /
  59. DATA BK1CS( 8) / -.0000000001 411488392E0 /
  60. DATA BK1CS( 9) / -.0000000000 006666901E0 /
  61. DATA BK1CS(10) / -.0000000000 000024274E0 /
  62. DATA BK1CS(11) / -.0000000000 000000070E0 /
  63. DATA AK1CS( 1) / .2744313406 973883E0 /
  64. DATA AK1CS( 2) / .0757198995 3199368E0 /
  65. DATA AK1CS( 3) / -.0014410515 5647540E0 /
  66. DATA AK1CS( 4) / .0000665011 6955125E0 /
  67. DATA AK1CS( 5) / -.0000043699 8470952E0 /
  68. DATA AK1CS( 6) / .0000003540 2774997E0 /
  69. DATA AK1CS( 7) / -.0000000331 1163779E0 /
  70. DATA AK1CS( 8) / .0000000034 4597758E0 /
  71. DATA AK1CS( 9) / -.0000000003 8989323E0 /
  72. DATA AK1CS(10) / .0000000000 4720819E0 /
  73. DATA AK1CS(11) / -.0000000000 0604783E0 /
  74. DATA AK1CS(12) / .0000000000 0081284E0 /
  75. DATA AK1CS(13) / -.0000000000 0011386E0 /
  76. DATA AK1CS(14) / .0000000000 0001654E0 /
  77. DATA AK1CS(15) / -.0000000000 0000248E0 /
  78. DATA AK1CS(16) / .0000000000 0000038E0 /
  79. DATA AK1CS(17) / -.0000000000 0000006E0 /
  80. DATA AK12CS( 1) / .0637930834 3739001E0 /
  81. DATA AK12CS( 2) / .0283288781 3049721E0 /
  82. DATA AK12CS( 3) / -.0002475370 6739052E0 /
  83. DATA AK12CS( 4) / .0000057719 7245160E0 /
  84. DATA AK12CS( 5) / -.0000002068 9392195E0 /
  85. DATA AK12CS( 6) / .0000000097 3998344E0 /
  86. DATA AK12CS( 7) / -.0000000005 5853361E0 /
  87. DATA AK12CS( 8) / .0000000000 3732996E0 /
  88. DATA AK12CS( 9) / -.0000000000 0282505E0 /
  89. DATA AK12CS(10) / .0000000000 0023720E0 /
  90. DATA AK12CS(11) / -.0000000000 0002176E0 /
  91. DATA AK12CS(12) / .0000000000 0000215E0 /
  92. DATA AK12CS(13) / -.0000000000 0000022E0 /
  93. DATA AK12CS(14) / .0000000000 0000002E0 /
  94. DATA FIRST /.TRUE./
  95. C***FIRST EXECUTABLE STATEMENT BESK1E
  96. IF (FIRST) THEN
  97. NTK1 = INITS (BK1CS, 11, 0.1*R1MACH(3))
  98. NTAK1 = INITS (AK1CS, 17, 0.1*R1MACH(3))
  99. NTAK12 = INITS (AK12CS, 14, 0.1*R1MACH(3))
  100. C
  101. XMIN = EXP (MAX(LOG(R1MACH(1)), -LOG(R1MACH(2))) + .01)
  102. XSML = SQRT (4.0*R1MACH(3))
  103. ENDIF
  104. FIRST = .FALSE.
  105. C
  106. IF (X .LE. 0.) CALL XERMSG ('SLATEC', 'BESK1E',
  107. + 'X IS ZERO OR NEGATIVE', 2, 2)
  108. IF (X.GT.2.0) GO TO 20
  109. C
  110. IF (X .LT. XMIN) CALL XERMSG ('SLATEC', 'BESK1E',
  111. + 'X SO SMALL K1 OVERFLOWS', 3, 2)
  112. Y = 0.
  113. IF (X.GT.XSML) Y = X*X
  114. BESK1E = EXP(X) * (LOG(0.5*X)*BESI1(X) +
  115. 1 (0.75 + CSEVL (.5*Y-1., BK1CS, NTK1))/X )
  116. RETURN
  117. C
  118. 20 IF (X.LE.8.) BESK1E = (1.25 + CSEVL ((16./X-5.)/3., AK1CS, NTAK1))
  119. 1 / SQRT(X)
  120. IF (X.GT.8.) BESK1E = (1.25 + CSEVL (16./X-1., AK12CS, NTAK12))
  121. 1 / SQRT(X)
  122. C
  123. RETURN
  124. END