mirror of
https://git.planet-casio.com/Lephenixnoir/OpenLibm.git
synced 2025-01-01 06:23:39 +01:00
c977aa998f
Replace amos with slatec
68 lines
1.8 KiB
Fortran
68 lines
1.8 KiB
Fortran
*DECK CMPCSG
|
|
SUBROUTINE CMPCSG (N, IJUMP, FNUM, FDEN, A)
|
|
C***BEGIN PROLOGUE CMPCSG
|
|
C***SUBSIDIARY
|
|
C***PURPOSE Subsidiary to CMGNBN
|
|
C***LIBRARY SLATEC
|
|
C***TYPE COMPLEX (COSGEN-S, CMPCSG-C)
|
|
C***AUTHOR (UNKNOWN)
|
|
C***DESCRIPTION
|
|
C
|
|
C This subroutine computes required cosine values in ascending
|
|
C order. When IJUMP .GT. 1 the routine computes values
|
|
C
|
|
C 2*COS(J*PI/L) , J=1,2,...,L and J .NE. 0(MOD N/IJUMP+1)
|
|
C
|
|
C where L = IJUMP*(N/IJUMP+1).
|
|
C
|
|
C
|
|
C when IJUMP = 1 it computes
|
|
C
|
|
C 2*COS((J-FNUM)*PI/(N+FDEN)) , J=1, 2, ... ,N
|
|
C
|
|
C where
|
|
C FNUM = 0.5, FDEN = 0.0, for regular reduction values.
|
|
C FNUM = 0.0, FDEN = 1.0, for B-R and C-R when ISTAG = 1
|
|
C FNUM = 0.0, FDEN = 0.5, for B-R and C-R when ISTAG = 2
|
|
C FNUM = 0.5, FDEN = 0.5, for B-R and C-R when ISTAG = 2
|
|
C in CMPOSN only.
|
|
C
|
|
C***SEE ALSO CMGNBN
|
|
C***ROUTINES CALLED PIMACH
|
|
C***REVISION HISTORY (YYMMDD)
|
|
C 801001 DATE WRITTEN
|
|
C 890531 Changed all specific intrinsics to generic. (WRB)
|
|
C 891214 Prologue converted to Version 4.0 format. (BAB)
|
|
C 900402 Added TYPE section. (WRB)
|
|
C***END PROLOGUE CMPCSG
|
|
COMPLEX A
|
|
DIMENSION A(*)
|
|
C
|
|
C
|
|
C***FIRST EXECUTABLE STATEMENT CMPCSG
|
|
PI = PIMACH(DUM)
|
|
IF (N .EQ. 0) GO TO 105
|
|
IF (IJUMP .EQ. 1) GO TO 103
|
|
K3 = N/IJUMP+1
|
|
K4 = K3-1
|
|
PIBYN = PI/(N+IJUMP)
|
|
DO 102 K=1,IJUMP
|
|
K1 = (K-1)*K3
|
|
K5 = (K-1)*K4
|
|
DO 101 I=1,K4
|
|
X = K1+I
|
|
K2 = K5+I
|
|
A(K2) = CMPLX(-2.*COS(X*PIBYN),0.)
|
|
101 CONTINUE
|
|
102 CONTINUE
|
|
GO TO 105
|
|
103 CONTINUE
|
|
NP1 = N+1
|
|
Y = PI/(N+FDEN)
|
|
DO 104 I=1,N
|
|
X = NP1-I-FNUM
|
|
A(I) = CMPLX(2.*COS(X*Y),0.)
|
|
104 CONTINUE
|
|
105 CONTINUE
|
|
RETURN
|
|
END
|