1 !CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
4 ! Copyright (C) 1995-2004, Scientific Computing Division,
5 ! University Corporation for Atmospheric Research
6 ! Licensed under the GNU General Public License (GPL)
8 ! Authors: Paul N. Swarztrauber and Richard A. Valent
10 ! $Id: r1fgkb.f,v 1.2 2004/06/15 21:29:20 rodney Exp $
12 !CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
14 SUBROUTINE R1FGKB (IDO,IP,L1,IDL1,CC,C1,C2,IN1, &
16 REAL CH(IN2,IDO,L1,IP) ,CC(IN1,IDO,IP,L1) , &
17 & C1(IN1,IDO,L1,IP) ,C2(IN1,IDL1,IP), &
18 & CH2(IN2,IDL1,IP) ,WA(IDO)
28 IF (IDO .LT. L1) GO TO 103
31 CH(1,I,K,1) = CC(1,I,1,K)
37 CH(1,I,K,1) = CC(1,I,1,K)
44 CH(1,1,K,J) = CC(1,IDO,J2-2,K)+CC(1,IDO,J2-2,K)
45 CH(1,1,K,JC) = CC(1,1,J2-1,K)+CC(1,1,J2-1,K)
49 IF (IDO .EQ. 1) GO TO 116
50 IF (NBD .LT. L1) GO TO 112
56 CH(1,I-1,K,J) = CC(1,I-1,2*J-1,K)+CC(1,IC-1,2*J-2,K)
57 CH(1,I-1,K,JC) = CC(1,I-1,2*J-1,K)-CC(1,IC-1,2*J-2,K)
58 CH(1,I,K,J) = CC(1,I,2*J-1,K)-CC(1,IC,2*J-2,K)
59 CH(1,I,K,JC) = CC(1,I,2*J-1,K)+CC(1,IC,2*J-2,K)
69 CH(1,I-1,K,J) = CC(1,I-1,2*J-1,K)+CC(1,IC-1,2*J-2,K)
70 CH(1,I-1,K,JC) = CC(1,I-1,2*J-1,K)-CC(1,IC-1,2*J-2,K)
71 CH(1,I,K,J) = CC(1,I,2*J-1,K)-CC(1,IC,2*J-2,K)
72 CH(1,I,K,JC) = CC(1,I,2*J-1,K)+CC(1,IC,2*J-2,K)
80 AR1H = DCP*AR1-DSP*AI1
84 C2(1,IK,L) = CH2(1,IK,1)+AR1*CH2(1,IK,2)
85 C2(1,IK,LC) = AI1*CH2(1,IK,IP)
93 AR2H = DC2*AR2-DS2*AI2
97 C2(1,IK,L) = C2(1,IK,L)+AR2*CH2(1,IK,J)
98 C2(1,IK,LC) = C2(1,IK,LC)+AI2*CH2(1,IK,JC)
104 CH2(1,IK,1) = CH2(1,IK,1)+CH2(1,IK,J)
110 CH(1,1,K,J) = C1(1,1,K,J)-C1(1,1,K,JC)
111 CH(1,1,K,JC) = C1(1,1,K,J)+C1(1,1,K,JC)
114 IF (IDO .EQ. 1) GO TO 132
115 IF (NBD .LT. L1) GO TO 128
120 CH(1,I-1,K,J) = C1(1,I-1,K,J)-C1(1,I,K,JC)
121 CH(1,I-1,K,JC) = C1(1,I-1,K,J)+C1(1,I,K,JC)
122 CH(1,I,K,J) = C1(1,I,K,J)+C1(1,I-1,K,JC)
123 CH(1,I,K,JC) = C1(1,I,K,J)-C1(1,I-1,K,JC)
132 CH(1,I-1,K,J) = C1(1,I-1,K,J)-C1(1,I,K,JC)
133 CH(1,I-1,K,JC) = C1(1,I-1,K,J)+C1(1,I,K,JC)
134 CH(1,I,K,J) = C1(1,I,K,J)+C1(1,I-1,K,JC)
135 CH(1,I,K,JC) = C1(1,I,K,J)-C1(1,I-1,K,JC)
140 IF (IDO .EQ. 1) RETURN
142 C2(1,IK,1) = CH2(1,IK,1)
146 C1(1,1,K,J) = CH(1,1,K,J)
149 IF (NBD .GT. L1) GO TO 139
157 C1(1,I-1,K,J) = WA(IDIJ-1)*CH(1,I-1,K,J)-WA(IDIJ)* &
159 C1(1,I,K,J) = WA(IDIJ-1)*CH(1,I,K,J)+WA(IDIJ)* &
172 C1(1,I-1,K,J) = WA(IDIJ-1)*CH(1,I-1,K,J)-WA(IDIJ)* &
174 C1(1,I,K,J) = WA(IDIJ-1)*CH(1,I,K,J)+WA(IDIJ)* &