asyik.f 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. *DECK ASYIK
  2. SUBROUTINE ASYIK (X, FNU, KODE, FLGIK, RA, ARG, IN, Y)
  3. C***BEGIN PROLOGUE ASYIK
  4. C***SUBSIDIARY
  5. C***PURPOSE Subsidiary to BESI and BESK
  6. C***LIBRARY SLATEC
  7. C***TYPE SINGLE PRECISION (ASYIK-S, DASYIK-D)
  8. C***AUTHOR Amos, D. E., (SNLA)
  9. C***DESCRIPTION
  10. C
  11. C ASYIK computes Bessel functions I and K
  12. C for arguments X.GT.0.0 and orders FNU.GE.35
  13. C on FLGIK = 1 and FLGIK = -1 respectively.
  14. C
  15. C INPUT
  16. C
  17. C X - argument, X.GT.0.0E0
  18. C FNU - order of first Bessel function
  19. C KODE - a parameter to indicate the scaling option
  20. C KODE=1 returns Y(I)= I/SUB(FNU+I-1)/(X), I=1,IN
  21. C or Y(I)= K/SUB(FNU+I-1)/(X), I=1,IN
  22. C on FLGIK = 1.0E0 or FLGIK = -1.0E0
  23. C KODE=2 returns Y(I)=EXP(-X)*I/SUB(FNU+I-1)/(X), I=1,IN
  24. C or Y(I)=EXP( X)*K/SUB(FNU+I-1)/(X), I=1,IN
  25. C on FLGIK = 1.0E0 or FLGIK = -1.0E0
  26. C FLGIK - selection parameter for I or K function
  27. C FLGIK = 1.0E0 gives the I function
  28. C FLGIK = -1.0E0 gives the K function
  29. C RA - SQRT(1.+Z*Z), Z=X/FNU
  30. C ARG - argument of the leading exponential
  31. C IN - number of functions desired, IN=1 or 2
  32. C
  33. C OUTPUT
  34. C
  35. C Y - a vector whose first in components contain the sequence
  36. C
  37. C Abstract
  38. C ASYIK implements the uniform asymptotic expansion of
  39. C the I and K Bessel functions for FNU.GE.35 and real
  40. C X.GT.0.0E0. The forms are identical except for a change
  41. C in sign of some of the terms. This change in sign is
  42. C accomplished by means of the flag FLGIK = 1 or -1.
  43. C
  44. C***SEE ALSO BESI, BESK
  45. C***ROUTINES CALLED R1MACH
  46. C***REVISION HISTORY (YYMMDD)
  47. C 750101 DATE WRITTEN
  48. C 890531 Changed all specific intrinsics to generic. (WRB)
  49. C 891214 Prologue converted to Version 4.0 format. (BAB)
  50. C 900328 Added TYPE section. (WRB)
  51. C 910408 Updated the AUTHOR section. (WRB)
  52. C***END PROLOGUE ASYIK
  53. C
  54. INTEGER IN, J, JN, K, KK, KODE, L
  55. REAL AK,AP,ARG,C, COEF,CON,ETX,FLGIK,FN, FNU,GLN,RA,S1,S2,
  56. 1 T, TOL, T2, X, Y, Z
  57. REAL R1MACH
  58. DIMENSION Y(*), C(65), CON(2)
  59. SAVE CON, C
  60. DATA CON(1), CON(2) /
  61. 1 3.98942280401432678E-01, 1.25331413731550025E+00/
  62. DATA C(1), C(2), C(3), C(4), C(5), C(6), C(7), C(8), C(9), C(10),
  63. 1 C(11), C(12), C(13), C(14), C(15), C(16), C(17), C(18),
  64. 2 C(19), C(20), C(21), C(22), C(23), C(24)/
  65. 3 -2.08333333333333E-01, 1.25000000000000E-01,
  66. 4 3.34201388888889E-01, -4.01041666666667E-01,
  67. 5 7.03125000000000E-02, -1.02581259645062E+00,
  68. 6 1.84646267361111E+00, -8.91210937500000E-01,
  69. 7 7.32421875000000E-02, 4.66958442342625E+00,
  70. 8 -1.12070026162230E+01, 8.78912353515625E+00,
  71. 9 -2.36408691406250E+00, 1.12152099609375E-01,
  72. 1 -2.82120725582002E+01, 8.46362176746007E+01,
  73. 2 -9.18182415432400E+01, 4.25349987453885E+01,
  74. 3 -7.36879435947963E+00, 2.27108001708984E-01,
  75. 4 2.12570130039217E+02, -7.65252468141182E+02,
  76. 5 1.05999045252800E+03, -6.99579627376133E+02/
  77. DATA C(25), C(26), C(27), C(28), C(29), C(30), C(31), C(32),
  78. 1 C(33), C(34), C(35), C(36), C(37), C(38), C(39), C(40),
  79. 2 C(41), C(42), C(43), C(44), C(45), C(46), C(47), C(48)/
  80. 3 2.18190511744212E+02, -2.64914304869516E+01,
  81. 4 5.72501420974731E-01, -1.91945766231841E+03,
  82. 5 8.06172218173731E+03, -1.35865500064341E+04,
  83. 6 1.16553933368645E+04, -5.30564697861340E+03,
  84. 7 1.20090291321635E+03, -1.08090919788395E+02,
  85. 8 1.72772750258446E+00, 2.02042913309661E+04,
  86. 9 -9.69805983886375E+04, 1.92547001232532E+05,
  87. 1 -2.03400177280416E+05, 1.22200464983017E+05,
  88. 2 -4.11926549688976E+04, 7.10951430248936E+03,
  89. 3 -4.93915304773088E+02, 6.07404200127348E+00,
  90. 4 -2.42919187900551E+05, 1.31176361466298E+06,
  91. 5 -2.99801591853811E+06, 3.76327129765640E+06/
  92. DATA C(49), C(50), C(51), C(52), C(53), C(54), C(55), C(56),
  93. 1 C(57), C(58), C(59), C(60), C(61), C(62), C(63), C(64),
  94. 2 C(65)/
  95. 3 -2.81356322658653E+06, 1.26836527332162E+06,
  96. 4 -3.31645172484564E+05, 4.52187689813627E+04,
  97. 5 -2.49983048181121E+03, 2.43805296995561E+01,
  98. 6 3.28446985307204E+06, -1.97068191184322E+07,
  99. 7 5.09526024926646E+07, -7.41051482115327E+07,
  100. 8 6.63445122747290E+07, -3.75671766607634E+07,
  101. 9 1.32887671664218E+07, -2.78561812808645E+06,
  102. 1 3.08186404612662E+05, -1.38860897537170E+04,
  103. 2 1.10017140269247E+02/
  104. C***FIRST EXECUTABLE STATEMENT ASYIK
  105. TOL = R1MACH(3)
  106. TOL = MAX(TOL,1.0E-15)
  107. FN = FNU
  108. Z = (3.0E0-FLGIK)/2.0E0
  109. KK = INT(Z)
  110. DO 50 JN=1,IN
  111. IF (JN.EQ.1) GO TO 10
  112. FN = FN - FLGIK
  113. Z = X/FN
  114. RA = SQRT(1.0E0+Z*Z)
  115. GLN = LOG((1.0E0+RA)/Z)
  116. ETX = KODE - 1
  117. T = RA*(1.0E0-ETX) + ETX/(Z+RA)
  118. ARG = FN*(T-GLN)*FLGIK
  119. 10 COEF = EXP(ARG)
  120. T = 1.0E0/RA
  121. T2 = T*T
  122. T = T/FN
  123. T = SIGN(T,FLGIK)
  124. S2 = 1.0E0
  125. AP = 1.0E0
  126. L = 0
  127. DO 30 K=2,11
  128. L = L + 1
  129. S1 = C(L)
  130. DO 20 J=2,K
  131. L = L + 1
  132. S1 = S1*T2 + C(L)
  133. 20 CONTINUE
  134. AP = AP*T
  135. AK = AP*S1
  136. S2 = S2 + AK
  137. IF (MAX(ABS(AK),ABS(AP)) .LT. TOL) GO TO 40
  138. 30 CONTINUE
  139. 40 CONTINUE
  140. T = ABS(T)
  141. Y(JN) = S2*COEF*SQRT(T)*CON(KK)
  142. 50 CONTINUE
  143. RETURN
  144. END