besk1.f 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. *DECK BESK1
  2. FUNCTION BESK1 (X)
  3. C***BEGIN PROLOGUE BESK1
  4. C***PURPOSE Compute the modified (hyperbolic) Bessel function of the
  5. C third kind of order one.
  6. C***LIBRARY SLATEC (FNLIB)
  7. C***CATEGORY C10B1
  8. C***TYPE SINGLE PRECISION (BESK1-S, DBESK1-D)
  9. C***KEYWORDS 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 BESK1(X) computes the modified (hyperbolic) Bessel function of third
  16. C kind of order one for real argument X, where X .GT. 0.
  17. C
  18. C Series for BK1 on the interval 0. to 4.00000D+00
  19. C with weighted error 7.02E-18
  20. C log weighted error 17.15
  21. C significant figures required 16.73
  22. C decimal places required 17.67
  23. C
  24. C***REFERENCES (NONE)
  25. C***ROUTINES CALLED BESI1, BESK1E, CSEVL, INITS, R1MACH, XERMSG
  26. C***REVISION HISTORY (YYMMDD)
  27. C 770401 DATE WRITTEN
  28. C 890531 Changed all specific intrinsics to generic. (WRB)
  29. C 890531 REVISION DATE from Version 3.2
  30. C 891214 Prologue converted to Version 4.0 format. (BAB)
  31. C 900315 CALLs to XERROR changed to CALLs to XERMSG. (THJ)
  32. C 900326 Removed duplicate information from DESCRIPTION section.
  33. C (WRB)
  34. C***END PROLOGUE BESK1
  35. DIMENSION BK1CS(11)
  36. LOGICAL FIRST
  37. SAVE BK1CS, NTK1, XMIN, XSML, XMAX, FIRST
  38. DATA BK1CS( 1) / .0253002273 389477705E0 /
  39. DATA BK1CS( 2) / -.3531559607 76544876E0 /
  40. DATA BK1CS( 3) / -.1226111808 22657148E0 /
  41. DATA BK1CS( 4) / -.0069757238 596398643E0 /
  42. DATA BK1CS( 5) / -.0001730288 957513052E0 /
  43. DATA BK1CS( 6) / -.0000024334 061415659E0 /
  44. DATA BK1CS( 7) / -.0000000221 338763073E0 /
  45. DATA BK1CS( 8) / -.0000000001 411488392E0 /
  46. DATA BK1CS( 9) / -.0000000000 006666901E0 /
  47. DATA BK1CS(10) / -.0000000000 000024274E0 /
  48. DATA BK1CS(11) / -.0000000000 000000070E0 /
  49. DATA FIRST /.TRUE./
  50. C***FIRST EXECUTABLE STATEMENT BESK1
  51. IF (FIRST) THEN
  52. NTK1 = INITS (BK1CS, 11, 0.1*R1MACH(3))
  53. XMIN = EXP (MAX(LOG(R1MACH(1)), -LOG(R1MACH(2))) + .01)
  54. XSML = SQRT (4.0*R1MACH(3))
  55. XMAXT = -LOG(R1MACH(1))
  56. XMAX = XMAXT - 0.5*XMAXT*LOG(XMAXT)/(XMAXT+0.5)
  57. ENDIF
  58. FIRST = .FALSE.
  59. C
  60. IF (X .LE. 0.) CALL XERMSG ('SLATEC', 'BESK1',
  61. + 'X IS ZERO OR NEGATIVE', 2, 2)
  62. IF (X.GT.2.0) GO TO 20
  63. C
  64. IF (X .LT. XMIN) CALL XERMSG ('SLATEC', 'BESK1',
  65. + 'X SO SMALL K1 OVERFLOWS', 3, 2)
  66. Y = 0.
  67. IF (X.GT.XSML) Y = X*X
  68. BESK1 = LOG(0.5*X)*BESI1(X) +
  69. 1 (0.75 + CSEVL (.5*Y-1., BK1CS, NTK1))/X
  70. RETURN
  71. C
  72. 20 BESK1 = 0.
  73. IF (X .GT. XMAX) CALL XERMSG ('SLATEC', 'BESK1',
  74. + 'X SO BIG K1 UNDERFLOWS', 1, 1)
  75. IF (X.GT.XMAX) RETURN
  76. C
  77. BESK1 = EXP(-X) * BESK1E(X)
  78. C
  79. RETURN
  80. END