besj1.f 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. *DECK BESJ1
  2. FUNCTION BESJ1 (X)
  3. C***BEGIN PROLOGUE BESJ1
  4. C***PURPOSE Compute the Bessel function of the first kind of order one.
  5. C***LIBRARY SLATEC (FNLIB)
  6. C***CATEGORY C10A1
  7. C***TYPE SINGLE PRECISION (BESJ1-S, DBESJ1-D)
  8. C***KEYWORDS BESSEL FUNCTION, FIRST KIND, FNLIB, ORDER ONE,
  9. C SPECIAL FUNCTIONS
  10. C***AUTHOR Fullerton, W., (LANL)
  11. C***DESCRIPTION
  12. C
  13. C BESJ1(X) calculates the Bessel function of the first kind of
  14. C order one for real argument X.
  15. C
  16. C Series for BJ1 on the interval 0. to 1.60000D+01
  17. C with weighted error 4.48E-17
  18. C log weighted error 16.35
  19. C significant figures required 15.77
  20. C decimal places required 16.89
  21. C
  22. C Series for BM1 on the interval 0. to 6.25000D-02
  23. C with weighted error 5.61E-17
  24. C log weighted error 16.25
  25. C significant figures required 14.97
  26. C decimal places required 16.91
  27. C
  28. C Series for BTH1 on the interval 0. to 6.25000D-02
  29. C with weighted error 4.10E-17
  30. C log weighted error 16.39
  31. C significant figures required 15.96
  32. C decimal places required 17.08
  33. C
  34. C***REFERENCES (NONE)
  35. C***ROUTINES CALLED CSEVL, INITS, R1MACH, XERMSG
  36. C***REVISION HISTORY (YYMMDD)
  37. C 780601 DATE WRITTEN
  38. C 890210 REVISION DATE from Version 3.2
  39. C 891214 Prologue converted to Version 4.0 format. (BAB)
  40. C 900315 CALLs to XERROR changed to CALLs to XERMSG. (THJ)
  41. C 900326 Removed duplicate information from DESCRIPTION section.
  42. C (WRB)
  43. C***END PROLOGUE BESJ1
  44. DIMENSION BJ1CS(12), BM1CS(21), BTH1CS(24)
  45. LOGICAL FIRST
  46. SAVE BJ1CS, BM1CS, BTH1CS, PI4, NTJ1, NTM1, NTTH1,
  47. 1 XSML, XMIN, XMAX, FIRST
  48. DATA BJ1CS( 1) / -.1172614151 3332787E0 /
  49. DATA BJ1CS( 2) / -.2536152183 0790640E0 /
  50. DATA BJ1CS( 3) / .0501270809 84469569E0 /
  51. DATA BJ1CS( 4) / -.0046315148 09625081E0 /
  52. DATA BJ1CS( 5) / .0002479962 29415914E0 /
  53. DATA BJ1CS( 6) / -.0000086789 48686278E0 /
  54. DATA BJ1CS( 7) / .0000002142 93917143E0 /
  55. DATA BJ1CS( 8) / -.0000000039 36093079E0 /
  56. DATA BJ1CS( 9) / .0000000000 55911823E0 /
  57. DATA BJ1CS(10) / -.0000000000 00632761E0 /
  58. DATA BJ1CS(11) / .0000000000 00005840E0 /
  59. DATA BJ1CS(12) / -.0000000000 00000044E0 /
  60. DATA BM1CS( 1) / .1047362510 931285E0 /
  61. DATA BM1CS( 2) / .0044244389 3702345E0 /
  62. DATA BM1CS( 3) / -.0000566163 9504035E0 /
  63. DATA BM1CS( 4) / .0000023134 9417339E0 /
  64. DATA BM1CS( 5) / -.0000001737 7182007E0 /
  65. DATA BM1CS( 6) / .0000000189 3209930E0 /
  66. DATA BM1CS( 7) / -.0000000026 5416023E0 /
  67. DATA BM1CS( 8) / .0000000004 4740209E0 /
  68. DATA BM1CS( 9) / -.0000000000 8691795E0 /
  69. DATA BM1CS(10) / .0000000000 1891492E0 /
  70. DATA BM1CS(11) / -.0000000000 0451884E0 /
  71. DATA BM1CS(12) / .0000000000 0116765E0 /
  72. DATA BM1CS(13) / -.0000000000 0032265E0 /
  73. DATA BM1CS(14) / .0000000000 0009450E0 /
  74. DATA BM1CS(15) / -.0000000000 0002913E0 /
  75. DATA BM1CS(16) / .0000000000 0000939E0 /
  76. DATA BM1CS(17) / -.0000000000 0000315E0 /
  77. DATA BM1CS(18) / .0000000000 0000109E0 /
  78. DATA BM1CS(19) / -.0000000000 0000039E0 /
  79. DATA BM1CS(20) / .0000000000 0000014E0 /
  80. DATA BM1CS(21) / -.0000000000 0000005E0 /
  81. DATA BTH1CS( 1) / .7406014102 6313850E0 /
  82. DATA BTH1CS( 2) / -.0045717556 59637690E0 /
  83. DATA BTH1CS( 3) / .0001198185 10964326E0 /
  84. DATA BTH1CS( 4) / -.0000069645 61891648E0 /
  85. DATA BTH1CS( 5) / .0000006554 95621447E0 /
  86. DATA BTH1CS( 6) / -.0000000840 66228945E0 /
  87. DATA BTH1CS( 7) / .0000000133 76886564E0 /
  88. DATA BTH1CS( 8) / -.0000000024 99565654E0 /
  89. DATA BTH1CS( 9) / .0000000005 29495100E0 /
  90. DATA BTH1CS(10) / -.0000000001 24135944E0 /
  91. DATA BTH1CS(11) / .0000000000 31656485E0 /
  92. DATA BTH1CS(12) / -.0000000000 08668640E0 /
  93. DATA BTH1CS(13) / .0000000000 02523758E0 /
  94. DATA BTH1CS(14) / -.0000000000 00775085E0 /
  95. DATA BTH1CS(15) / .0000000000 00249527E0 /
  96. DATA BTH1CS(16) / -.0000000000 00083773E0 /
  97. DATA BTH1CS(17) / .0000000000 00029205E0 /
  98. DATA BTH1CS(18) / -.0000000000 00010534E0 /
  99. DATA BTH1CS(19) / .0000000000 00003919E0 /
  100. DATA BTH1CS(20) / -.0000000000 00001500E0 /
  101. DATA BTH1CS(21) / .0000000000 00000589E0 /
  102. DATA BTH1CS(22) / -.0000000000 00000237E0 /
  103. DATA BTH1CS(23) / .0000000000 00000097E0 /
  104. DATA BTH1CS(24) / -.0000000000 00000040E0 /
  105. DATA PI4 / 0.7853981633 9744831E0 /
  106. DATA FIRST /.TRUE./
  107. C***FIRST EXECUTABLE STATEMENT BESJ1
  108. IF (FIRST) THEN
  109. NTJ1 = INITS (BJ1CS, 12, 0.1*R1MACH(3))
  110. NTM1 = INITS (BM1CS, 21, 0.1*R1MACH(3))
  111. NTTH1 = INITS (BTH1CS, 24, 0.1*R1MACH(3))
  112. C
  113. XSML = SQRT (8.0*R1MACH(3))
  114. XMIN = 2.0*R1MACH(1)
  115. XMAX = 1.0/R1MACH(4)
  116. ENDIF
  117. FIRST = .FALSE.
  118. C
  119. Y = ABS(X)
  120. IF (Y.GT.4.0) GO TO 20
  121. C
  122. BESJ1 = 0.
  123. IF (Y.EQ.0.0) RETURN
  124. IF (Y .LE. XMIN) CALL XERMSG ('SLATEC', 'BESJ1',
  125. + 'ABS(X) SO SMALL J1 UNDERFLOWS', 1, 1)
  126. IF (Y.GT.XMIN) BESJ1 = 0.5*X
  127. IF (Y.GT.XSML) BESJ1 = X * (.25 + CSEVL(.125*Y*Y-1., BJ1CS, NTJ1))
  128. RETURN
  129. C
  130. 20 IF (Y .GT. XMAX) CALL XERMSG ('SLATEC', 'BESJ1',
  131. + 'NO PRECISION BECAUSE ABS(X) IS TOO BIG', 2, 2)
  132. Z = 32.0/Y**2 - 1.0
  133. AMPL = (0.75 + CSEVL (Z, BM1CS, NTM1)) / SQRT(Y)
  134. THETA = Y - 3.0*PI4 + CSEVL (Z, BTH1CS, NTTH1) / Y
  135. BESJ1 = SIGN (AMPL, X) * COS (THETA)
  136. C
  137. RETURN
  138. END