SUBROUTINE VRADBG (MP,IDO,IP,L1,IDL1,CC,C1,C2,CH,CH2, C C VRFFTPK, VERSION 1, AUGUST 1985 C * MDIMC,WA) DIMENSION CH(MDIMC,IDO,L1,IP) ,CC(MDIMC,IDO,IP,L1) , 1 C1(MDIMC,IDO,L1,IP) ,C2(MDIMC,IDL1,IP), 2 CH2(MDIMC,IDL1,IP) ,WA(IDO) TPI=2.*PIMACH(1.0) ARG = TPI/FLOAT(IP) DCP = COS(ARG) DSP = SIN(ARG) IDP2 = IDO+2 NBD = (IDO-1)/2 IPP2 = IP+2 IPPH = (IP+1)/2 IF (IDO .LT. L1) GO TO 103 DO 102 K=1,L1 DO 101 I=1,IDO DO 1001 M=1,MP CH(M,I,K,1) = CC(M,I,1,K) 1001 CONTINUE 101 CONTINUE 102 CONTINUE GO TO 106 103 DO 105 I=1,IDO DO 104 K=1,L1 DO 1004 M=1,MP CH(M,I,K,1) = CC(M,I,1,K) 1004 CONTINUE 104 CONTINUE 105 CONTINUE 106 DO 108 J=2,IPPH JC = IPP2-J J2 = J+J DO 107 K=1,L1 DO 1007 M=1,MP CH(M,1,K,J) = CC(M,IDO,J2-2,K)+CC(M,IDO,J2-2,K) CH(M,1,K,JC) = CC(M,1,J2-1,K)+CC(M,1,J2-1,K) 1007 CONTINUE 107 CONTINUE 108 CONTINUE IF (IDO .EQ. 1) GO TO 116 IF (NBD .LT. L1) GO TO 112 DO 111 J=2,IPPH JC = IPP2-J DO 110 K=1,L1 DO 109 I=3,IDO,2 IC = IDP2-I DO 1009 M=1,MP CH(M,I-1,K,J) = CC(M,I-1,2*J-1,K)+CC(M,IC-1,2*J-2,K) CH(M,I-1,K,JC) = CC(M,I-1,2*J-1,K)-CC(M,IC-1,2*J-2,K) CH(M,I,K,J) = CC(M,I,2*J-1,K)-CC(M,IC,2*J-2,K) CH(M,I,K,JC) = CC(M,I,2*J-1,K)+CC(M,IC,2*J-2,K) 1009 CONTINUE 109 CONTINUE 110 CONTINUE 111 CONTINUE GO TO 116 112 DO 115 J=2,IPPH JC = IPP2-J DO 114 I=3,IDO,2 IC = IDP2-I DO 113 K=1,L1 DO 1013 M=1,MP CH(M,I-1,K,J) = CC(M,I-1,2*J-1,K)+CC(M,IC-1,2*J-2,K) CH(M,I-1,K,JC) = CC(M,I-1,2*J-1,K)-CC(M,IC-1,2*J-2,K) CH(M,I,K,J) = CC(M,I,2*J-1,K)-CC(M,IC,2*J-2,K) CH(M,I,K,JC) = CC(M,I,2*J-1,K)+CC(M,IC,2*J-2,K) 1013 CONTINUE 113 CONTINUE 114 CONTINUE 115 CONTINUE 116 AR1 = 1. AI1 = 0. DO 120 L=2,IPPH LC = IPP2-L AR1H = DCP*AR1-DSP*AI1 AI1 = DCP*AI1+DSP*AR1 AR1 = AR1H DO 117 IK=1,IDL1 DO 1017 M=1,MP C2(M,IK,L) = CH2(M,IK,1)+AR1*CH2(M,IK,2) C2(M,IK,LC) = AI1*CH2(M,IK,IP) 1017 CONTINUE 117 CONTINUE DC2 = AR1 DS2 = AI1 AR2 = AR1 AI2 = AI1 DO 119 J=3,IPPH JC = IPP2-J AR2H = DC2*AR2-DS2*AI2 AI2 = DC2*AI2+DS2*AR2 AR2 = AR2H DO 118 IK=1,IDL1 DO 1018 M=1,MP C2(M,IK,L) = C2(M,IK,L)+AR2*CH2(M,IK,J) C2(M,IK,LC) = C2(M,IK,LC)+AI2*CH2(M,IK,JC) 1018 CONTINUE 118 CONTINUE 119 CONTINUE 120 CONTINUE DO 122 J=2,IPPH DO 121 IK=1,IDL1 DO 1021 M=1,MP CH2(M,IK,1) = CH2(M,IK,1)+CH2(M,IK,J) 1021 CONTINUE 121 CONTINUE 122 CONTINUE DO 124 J=2,IPPH JC = IPP2-J DO 123 K=1,L1 DO 1023 M=1,MP CH(M,1,K,J) = C1(M,1,K,J)-C1(M,1,K,JC) CH(M,1,K,JC) = C1(M,1,K,J)+C1(M,1,K,JC) 1023 CONTINUE 123 CONTINUE 124 CONTINUE IF (IDO .EQ. 1) GO TO 132 IF (NBD .LT. L1) GO TO 128 DO 127 J=2,IPPH JC = IPP2-J DO 126 K=1,L1 DO 125 I=3,IDO,2 DO 1025 M=1,MP CH(M,I-1,K,J) = C1(M,I-1,K,J)-C1(M,I,K,JC) CH(M,I-1,K,JC) = C1(M,I-1,K,J)+C1(M,I,K,JC) CH(M,I,K,J) = C1(M,I,K,J)+C1(M,I-1,K,JC) CH(M,I,K,JC) = C1(M,I,K,J)-C1(M,I-1,K,JC) 1025 CONTINUE 125 CONTINUE 126 CONTINUE 127 CONTINUE GO TO 132 128 DO 131 J=2,IPPH JC = IPP2-J DO 130 I=3,IDO,2 DO 129 K=1,L1 DO 1029 M=1,MP CH(M,I-1,K,J) = C1(M,I-1,K,J)-C1(M,I,K,JC) CH(M,I-1,K,JC) = C1(M,I-1,K,J)+C1(M,I,K,JC) CH(M,I,K,J) = C1(M,I,K,J)+C1(M,I-1,K,JC) CH(M,I,K,JC) = C1(M,I,K,J)-C1(M,I-1,K,JC) 1029 CONTINUE 129 CONTINUE 130 CONTINUE 131 CONTINUE 132 CONTINUE IF (IDO .EQ. 1) RETURN DO 133 IK=1,IDL1 DO 1033 M=1,MP C2(M,IK,1) = CH2(M,IK,1) 1033 CONTINUE 133 CONTINUE DO 135 J=2,IP DO 134 K=1,L1 DO 1034 M=1,MP C1(M,1,K,J) = CH(M,1,K,J) 1034 CONTINUE 134 CONTINUE 135 CONTINUE IF (NBD .GT. L1) GO TO 139 IS = -IDO DO 138 J=2,IP IS = IS+IDO IDIJ = IS DO 137 I=3,IDO,2 IDIJ = IDIJ+2 DO 136 K=1,L1 DO 1036 M=1,MP C1(M,I-1,K,J) = WA(IDIJ-1)*CH(M,I-1,K,J)-WA(IDIJ)* 1 CH(M,I,K,J) C1(M,I,K,J) = WA(IDIJ-1)*CH(M,I,K,J)+WA(IDIJ)* 1 CH(M,I-1,K,J) 1036 CONTINUE 136 CONTINUE 137 CONTINUE 138 CONTINUE GO TO 143 139 IS = -IDO DO 142 J=2,IP IS = IS+IDO DO 141 K=1,L1 IDIJ = IS DO 140 I=3,IDO,2 IDIJ = IDIJ+2 DO 1040 M=1,MP C1(M,I-1,K,J) = WA(IDIJ-1)*CH(M,I-1,K,J)-WA(IDIJ)* 1 CH(M,I,K,J) C1(M,I,K,J) = WA(IDIJ-1)*CH(M,I,K,J)+WA(IDIJ)* 1 CH(M,I-1,K,J) 1040 CONTINUE 140 CONTINUE 141 CONTINUE 142 CONTINUE 143 RETURN END .