mirror of
https://git.planet-casio.com/Lephenixnoir/OpenLibm.git
synced 2025-01-01 06:23:39 +01:00
c977aa998f
Replace amos with slatec
169 lines
5.1 KiB
Fortran
169 lines
5.1 KiB
Fortran
*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
|