123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169 |
- *DECK CBUNI
- SUBROUTINE CBUNI (Z, FNU, KODE, N, Y, NZ, NUI, NLAST, FNUL, TOL,
- + ELIM, ALIM)
- C***BEGIN PROLOGUE CBUNI
- C***SUBSIDIARY
- C***PURPOSE Subsidiary to CBESI and CBESK
- C***LIBRARY SLATEC
- C***TYPE ALL (CBUNI-A, ZBUNI-A)
- C***AUTHOR Amos, D. E., (SNL)
- C***DESCRIPTION
- C
- C CBUNI COMPUTES THE I BESSEL FUNCTION FOR LARGE ABS(Z).GT.
- C FNUL AND FNU+N-1.LT.FNUL. THE ORDER IS INCREASED FROM
- C FNU+N-1 GREATER THAN FNUL BY ADDING NUI AND COMPUTING
- C ACCORDING TO THE UNIFORM ASYMPTOTIC EXPANSION FOR I(FNU,Z)
- C ON IFORM=1 AND THE EXPANSION FOR J(FNU,Z) ON IFORM=2
- C
- C***SEE ALSO CBESI, CBESK
- C***ROUTINES CALLED CUNI1, CUNI2, R1MACH
- C***REVISION HISTORY (YYMMDD)
- C 830501 DATE WRITTEN
- C 910415 Prologue converted to Version 4.0 format. (BAB)
- C***END PROLOGUE CBUNI
- COMPLEX CSCL, CSCR, CY, RZ, ST, S1, S2, Y, Z
- REAL ALIM, AX, AY, DFNU, ELIM, FNU, FNUI, FNUL, GNU, TOL, XX, YY,
- * ASCLE, BRY, STR, STI, STM, R1MACH
- INTEGER I, IFLAG, IFORM, K, KODE, N, NL, NLAST, NUI, NW, NZ
- DIMENSION Y(N), CY(2), BRY(3)
- C***FIRST EXECUTABLE STATEMENT CBUNI
- NZ = 0
- XX = REAL(Z)
- YY = AIMAG(Z)
- AX = ABS(XX)*1.7321E0
- AY = ABS(YY)
- IFORM = 1
- IF (AY.GT.AX) IFORM = 2
- IF (NUI.EQ.0) GO TO 60
- FNUI = NUI
- DFNU = FNU + (N-1)
- GNU = DFNU + FNUI
- IF (IFORM.EQ.2) GO TO 10
- C-----------------------------------------------------------------------
- C ASYMPTOTIC EXPANSION FOR I(FNU,Z) FOR LARGE FNU APPLIED IN
- C -PI/3.LE.ARG(Z).LE.PI/3
- C-----------------------------------------------------------------------
- CALL CUNI1(Z, GNU, KODE, 2, CY, NW, NLAST, FNUL, TOL, ELIM, ALIM)
- GO TO 20
- 10 CONTINUE
- C-----------------------------------------------------------------------
- C ASYMPTOTIC EXPANSION FOR J(FNU,Z*EXP(M*HPI)) FOR LARGE FNU
- C APPLIED IN PI/3.LT.ABS(ARG(Z)).LE.PI/2 WHERE M=+I OR -I
- C AND HPI=PI/2
- C-----------------------------------------------------------------------
- CALL CUNI2(Z, GNU, KODE, 2, CY, NW, NLAST, FNUL, TOL, ELIM, ALIM)
- 20 CONTINUE
- IF (NW.LT.0) GO TO 50
- IF (NW.NE.0) GO TO 90
- AY = ABS(CY(1))
- C----------------------------------------------------------------------
- C SCALE BACKWARD RECURRENCE, BRY(3) IS DEFINED BUT NEVER USED
- C----------------------------------------------------------------------
- BRY(1) = 1.0E+3*R1MACH(1)/TOL
- BRY(2) = 1.0E0/BRY(1)
- BRY(3) = BRY(2)
- IFLAG = 2
- ASCLE = BRY(2)
- AX = 1.0E0
- CSCL = CMPLX(AX,0.0E0)
- IF (AY.GT.BRY(1)) GO TO 21
- IFLAG = 1
- ASCLE = BRY(1)
- AX = 1.0E0/TOL
- CSCL = CMPLX(AX,0.0E0)
- GO TO 25
- 21 CONTINUE
- IF (AY.LT.BRY(2)) GO TO 25
- IFLAG = 3
- ASCLE = BRY(3)
- AX = TOL
- CSCL = CMPLX(AX,0.0E0)
- 25 CONTINUE
- AY = 1.0E0/AX
- CSCR = CMPLX(AY,0.0E0)
- S1 = CY(2)*CSCL
- S2 = CY(1)*CSCL
- RZ = CMPLX(2.0E0,0.0E0)/Z
- DO 30 I=1,NUI
- ST = S2
- S2 = CMPLX(DFNU+FNUI,0.0E0)*RZ*S2 + S1
- S1 = ST
- FNUI = FNUI - 1.0E0
- IF (IFLAG.GE.3) GO TO 30
- ST = S2*CSCR
- STR = REAL(ST)
- STI = AIMAG(ST)
- STR = ABS(STR)
- STI = ABS(STI)
- STM = MAX(STR,STI)
- IF (STM.LE.ASCLE) GO TO 30
- IFLAG = IFLAG+1
- ASCLE = BRY(IFLAG)
- S1 = S1*CSCR
- S2 = ST
- AX = AX*TOL
- AY = 1.0E0/AX
- CSCL = CMPLX(AX,0.0E0)
- CSCR = CMPLX(AY,0.0E0)
- S1 = S1*CSCL
- S2 = S2*CSCL
- 30 CONTINUE
- Y(N) = S2*CSCR
- IF (N.EQ.1) RETURN
- NL = N - 1
- FNUI = NL
- K = NL
- DO 40 I=1,NL
- ST = S2
- S2 = CMPLX(FNU+FNUI,0.0E0)*RZ*S2 + S1
- S1 = ST
- ST = S2*CSCR
- Y(K) = ST
- FNUI = FNUI - 1.0E0
- K = K - 1
- IF (IFLAG.GE.3) GO TO 40
- STR = REAL(ST)
- STI = AIMAG(ST)
- STR = ABS(STR)
- STI = ABS(STI)
- STM = MAX(STR,STI)
- IF (STM.LE.ASCLE) GO TO 40
- IFLAG = IFLAG+1
- ASCLE = BRY(IFLAG)
- S1 = S1*CSCR
- S2 = ST
- AX = AX*TOL
- AY = 1.0E0/AX
- CSCL = CMPLX(AX,0.0E0)
- CSCR = CMPLX(AY,0.0E0)
- S1 = S1*CSCL
- S2 = S2*CSCL
- 40 CONTINUE
- RETURN
- 50 CONTINUE
- NZ = -1
- IF(NW.EQ.(-2)) NZ=-2
- RETURN
- 60 CONTINUE
- IF (IFORM.EQ.2) GO TO 70
- C-----------------------------------------------------------------------
- C ASYMPTOTIC EXPANSION FOR I(FNU,Z) FOR LARGE FNU APPLIED IN
- C -PI/3.LE.ARG(Z).LE.PI/3
- C-----------------------------------------------------------------------
- CALL CUNI1(Z, FNU, KODE, N, Y, NW, NLAST, FNUL, TOL, ELIM, ALIM)
- GO TO 80
- 70 CONTINUE
- C-----------------------------------------------------------------------
- C ASYMPTOTIC EXPANSION FOR J(FNU,Z*EXP(M*HPI)) FOR LARGE FNU
- C APPLIED IN PI/3.LT.ABS(ARG(Z)).LE.PI/2 WHERE M=+I OR -I
- C AND HPI=PI/2
- C-----------------------------------------------------------------------
- CALL CUNI2(Z, FNU, KODE, N, Y, NW, NLAST, FNUL, TOL, ELIM, ALIM)
- 80 CONTINUE
- IF (NW.LT.0) GO TO 50
- NZ = NW
- RETURN
- 90 CONTINUE
- NLAST = N
- RETURN
- END
|