source: LMDZ5/branches/testing/libf/phylmd/rrtm/swr.F90 @ 2542

Last change on this file since 2542 was 2056, checked in by Laurent Fairhead, 11 years ago

Merged trunk changes r1997:2055 into testing branch

  • Property copyright set to
    Name of program: LMDZ
    Creation date: 1984
    Version: LMDZ5
    License: CeCILL version 2
    Holder: Laboratoire de m\'et\'eorologie dynamique, CNRS, UMR 8539
    See the license file in the root directory
File size: 14.2 KB
Line 
1SUBROUTINE SWR &
2 & ( KIDIA , KFDIA , KLON , KLEV  , KNU,&
3 & PALBD , PCG   , PCLD , POMEGA, PSEC , PTAU,&
4 & PCGAZ , PPIZAZ, PRAY1, PRAY2 , PREFZ, PRJ  , PRK , PRMUE,&
5 & PTAUAZ, PTRA1 , PTRA2, PTRCLD &
6 & ) 
7
8!**** *SWR* - CONTINUUM SCATTERING COMPUTATIONS
9
10!     PURPOSE.
11!     --------
12!           COMPUTES THE REFLECTIVITY AND TRANSMISSIVITY IN CASE OF
13!     CONTINUUM SCATTERING
14
15!**   INTERFACE.
16!     ----------
17
18!          *SWR* IS CALLED EITHER FROM *SW1S*
19!                              OR FROM *SWNI*
20
21!        IMPLICIT ARGUMENTS :
22!        --------------------
23
24!     ==== INPUTS ===
25!     ==== OUTPUTS ===
26
27!     METHOD.
28!     -------
29
30!          1. COMPUTES CONTINUUM FLUXES CORRESPONDING TO AEROSOL
31!     OR/AND RAYLEIGH SCATTERING (NO MOLECULAR GAS ABSORPTION)
32
33!     EXTERNALS.
34!     ----------
35
36!          *SWDE*
37
38!     REFERENCE.
39!     ----------
40
41!        SEE RADIATION'S PART OF THE ECMWF RESEARCH DEPARTMENT
42!        DOCUMENTATION, AND FOUQUART AND BONNEL (1980)
43
44!     AUTHOR.
45!     -------
46!        JEAN-JACQUES MORCRETTE  *ECMWF*
47
48!     MODIFICATIONS.
49!     --------------
50!        ORIGINAL : 89-07-14
51!        Ph. DANDIN Meteo-France 05-96 : Effect of cloud layer
52!        JJMorcrette 990128 : sunshine duration
53!        JJMorcrette 001218 : 6 spectral intervals
54!        03-10-10 Deborah Salmond and Marta Janiskova Optimisation
55!        M.Hamrud      01-Oct-2003 CY28 Cleaning
56!        Y.Seity 06-09-09 : add modset from O.Thouron (MesoNH) under NOVLP tests
57!     ------------------------------------------------------------------
58
59USE PARKIND1  ,ONLY : JPIM     ,JPRB
60USE YOMHOOK   ,ONLY : LHOOK,   DR_HOOK
61
62!USE YOERAD   , ONLY : NOVLP    ,NSW
63! NSW mis dans ;def MPL 20140211
64USE YOERAD   , ONLY : NOVLP   
65USE YOECLD   , ONLY : REPSEC
66USE YOEOVLP  , ONLY : RA1OVLP
67USE write_field_phy
68
69IMPLICIT NONE
70
71include "clesphys.h"
72INTEGER(KIND=JPIM),INTENT(IN)    :: KLON
73INTEGER(KIND=JPIM),INTENT(IN)    :: KLEV
74INTEGER(KIND=JPIM),INTENT(IN)    :: KIDIA
75INTEGER(KIND=JPIM),INTENT(IN)    :: KFDIA
76INTEGER(KIND=JPIM),INTENT(IN)    :: KNU
77REAL(KIND=JPRB)   ,INTENT(IN)    :: PALBD(KLON,NSW)
78REAL(KIND=JPRB)   ,INTENT(IN)    :: PCG(KLON,NSW,KLEV)
79REAL(KIND=JPRB)   ,INTENT(IN)    :: PCLD(KLON,KLEV)
80REAL(KIND=JPRB)   ,INTENT(IN)    :: POMEGA(KLON,NSW,KLEV)
81REAL(KIND=JPRB)   ,INTENT(IN)    :: PSEC(KLON)
82REAL(KIND=JPRB)   ,INTENT(IN)    :: PTAU(KLON,NSW,KLEV)
83REAL(KIND=JPRB)   ,INTENT(IN)    :: PCGAZ(KLON,KLEV)
84REAL(KIND=JPRB)   ,INTENT(IN)    :: PPIZAZ(KLON,KLEV)
85REAL(KIND=JPRB)   ,INTENT(OUT)   :: PRAY1(KLON,KLEV+1)
86REAL(KIND=JPRB)   ,INTENT(OUT)   :: PRAY2(KLON,KLEV+1)
87REAL(KIND=JPRB)   ,INTENT(OUT)   :: PREFZ(KLON,2,KLEV+1)
88REAL(KIND=JPRB)   ,INTENT(OUT)   :: PRJ(KLON,6,KLEV+1)
89REAL(KIND=JPRB)   ,INTENT(OUT)   :: PRK(KLON,6,KLEV+1)
90REAL(KIND=JPRB)   ,INTENT(OUT)   :: PRMUE(KLON,KLEV+1)
91REAL(KIND=JPRB)   ,INTENT(IN)    :: PTAUAZ(KLON,KLEV)
92REAL(KIND=JPRB)   ,INTENT(OUT)   :: PTRA1(KLON,KLEV+1)
93REAL(KIND=JPRB)   ,INTENT(OUT)   :: PTRA2(KLON,KLEV+1)
94REAL(KIND=JPRB)   ,INTENT(OUT)   :: PTRCLD(KLON)
95!     ------------------------------------------------------------------
96
97!*       0.1   ARGUMENTS
98!              ---------
99
100!     ------------------------------------------------------------------
101
102!              ------------
103
104REAL(KIND=JPRB) :: ZC1I(KLON,KLEV+1)    , ZCLEQ(KLON,KLEV)&
105 & ,  ZCLEAR(KLON)         , ZCLOUD(KLON) &
106 & ,  ZGG(KLON)            , ZREF(KLON)&
107 & ,  ZRE1(KLON)           , ZRE2(KLON)&
108 & ,  ZRMUZ(KLON)          , ZRNEB(KLON)&
109 & ,  ZR21(KLON)           , ZR22(KLON)&
110 & ,  ZR23(KLON)           , ZSS1(KLON)&
111 & ,  ZTO1(KLON)           , ZTR(KLON,2,KLEV+1)&
112 & ,  ZTR1(KLON)           , ZTR2(KLON)&
113 & ,  ZW(KLON) 
114
115INTEGER(KIND=JPIM) :: IKL, IKLP1, JA, JAJ, JK, JKM1, JL, INU1
116
117REAL(KIND=JPRB) :: ZBMU0, ZBMU1, ZCORAE, ZCORCD, ZDEN, ZDEN1,&
118 & ZFACOA, ZFACOC, ZGAP, ZMU1, ZMUE, ZRE11, &
119 & ZTO, ZWW, ZALPHA1, ZCHKAE, ZCHKCD 
120REAL(KIND=JPRB) :: ZRR,ZIMU1,ZI2MU1,ZIDEN,ZIDEN1
121REAL(KIND=JPRB) :: ZHOOK_HANDLE
122LOGICAL         :: LLDEBUG
123
124#include "swde.intfb.h"
125
126!     ------------------------------------------------------------------
127
128!*         1.    INITIALIZATION
129!                --------------
130
131IF (LHOOK) CALL DR_HOOK('SWR',0,ZHOOK_HANDLE)
132LLDEBUG=.FALSE.
133DO JK = 1 , KLEV+1
134  DO JA = 1 , 6
135    DO JL = KIDIA,KFDIA
136      PRJ(JL,JA,JK) = 0.0_JPRB
137      PRK(JL,JA,JK) = 0.0_JPRB
138    ENDDO
139  ENDDO
140ENDDO
141
142REPSEC=1.E-12_JPRB    !!!!! A REVOIR (MPL) 220109
143
144!     ------------------------------------------------------------------
145
146!*         2.    TOTAL EFFECTIVE CLOUDINESS ABOVE A GIVEN LEVEL
147!                ----------------------------------------------
148
149DO JL = KIDIA,KFDIA
150  ZR23(JL) = 0.0_JPRB
151  ZC1I(JL,KLEV+1) = 0.0_JPRB
152  ZCLEAR(JL) = 1.0_JPRB
153  ZCLOUD(JL) = 0.0_JPRB
154ENDDO
155
156JK = 1
157IKL = KLEV+1 - JK
158IKLP1 = IKL + 1
159ZALPHA1=RA1OVLP( IKL )
160DO JL = KIDIA,KFDIA
161!++MODIFCODE
162  IF (NOVLP >= 5) THEN !MESONH VERSION
163   stop 'provisoire pour verifier option novlp=1'
164   ZFACOA =PTAUAZ(JL,IKL)
165   ZFACOC = 1.0_JPRB - POMEGA(JL,KNU,IKL) * PCG(JL,KNU,IKL)* PCG(JL,KNU,IKL)
166   ZCORAE = ZFACOA * PSEC(JL)
167   ZCORCD = ZFACOC * PTAU(JL,KNU,IKL) * PSEC(JL)
168  ELSE !ECMWF VERSION
169ZFACOA = 1.0_JPRB - PPIZAZ(JL,IKL)*PCGAZ(JL,IKL)*PCGAZ(JL,IKL)
170  ZFACOC = 1.0_JPRB - POMEGA(JL,KNU,IKL) * PCG(JL,KNU,IKL)* PCG(JL,KNU,IKL)
171  ZCORAE = ZFACOA * PTAUAZ(JL,IKL) * PSEC(JL)
172  ZCORCD = ZFACOC * PTAU(JL,KNU,IKL) * PSEC(JL)
173  ENDIF
174!--MODIFCODE
175  ZCHKAE = MIN( 200._JPRB, ZCORAE )
176  ZCHKCD = MIN( 200._JPRB, ZCORCD )
177  ZR21(JL) = EXP( - ZCHKAE )
178  ZR22(JL) = EXP( - ZCHKCD )
179 
180  ZSS1(JL) = PCLD(JL,IKL)*(1.0_JPRB-ZR21(JL)*ZR22(JL))&
181   & + (1.0_JPRB-PCLD(JL,IKL))*(1.0_JPRB-ZR21(JL)) 
182  ZCLEQ(JL,IKL) = ZSS1(JL)
183
184!++MODIFCODE
185  IF ((NOVLP == 1).OR.(NOVLP == 8)) THEN
186!--MODIFCODE
187!* maximum-random     
188    ZCLEAR(JL) = ZCLEAR(JL)&
189     & *(1.0_JPRB-MAX(ZSS1(JL),ZCLOUD(JL)))&
190     & /(1.0_JPRB-MIN(ZCLOUD(JL),1.0_JPRB-REPSEC)) 
191    ZC1I(JL,IKL) = 1.0_JPRB - ZCLEAR(JL)
192    ZCLOUD(JL) = ZSS1(JL)
193  ELSEIF (NOVLP == 2) THEN
194   stop 'provisoire pour verifier option novlp=1b'
195!* maximum
196    ZCLOUD(JL) = MAX( ZSS1(JL) , ZCLOUD(JL) )
197    ZC1I(JL,IKL) = ZCLOUD(JL)
198!++MODIFCODE
199  ELSEIF ((NOVLP == 3).OR.((NOVLP  >=  5).AND.(NOVLP /= 8))) THEN
200   stop 'provisoire pour verifier option novlp=1c'
201!--MODIFCODE
202!* random
203    ZCLEAR(JL) = ZCLEAR(JL)*(1.0_JPRB - ZSS1(JL))
204    ZCLOUD(JL) = 1.0_JPRB - ZCLEAR(JL)
205    ZC1I(JL,IKL) = ZCLOUD(JL)
206  ELSEIF (NOVLP == 4) THEN
207   stop 'provisoire pour verifier option novlp=1d'
208!* Hogan & Illingworth, 2001 
209    ZCLEAR(JL)=ZCLEAR(JL)*( &
210     & ZALPHA1*(1.0_JPRB-MAX(ZSS1(JL),ZCLOUD(JL))) &
211     & /(1.0_JPRB-MIN(ZCLOUD(JL),1.0_JPRB-REPSEC)) &
212     & +(1.0_JPRB-ZALPHA1)*(1.0_JPRB-ZSS1(JL)) ) 
213    ZC1I(JL,IKL) = 1.0_JPRB - ZCLEAR(JL)
214    ZCLOUD(JL) = ZSS1(JL)
215  ENDIF
216ENDDO
217
218DO JK = 2 , KLEV
219  IKL = KLEV+1 - JK
220  IKLP1 = IKL + 1
221  ZALPHA1=RA1OVLP( IKL )
222  DO JL = KIDIA,KFDIA
223!++MODIFCODE
224    IF (NOVLP >= 5) THEN !MESONH VERSION
225     ZFACOA =PTAUAZ(JL,IKL)
226     ZFACOC = 1.0_JPRB - POMEGA(JL,KNU,IKL) * PCG(JL,KNU,IKL)* PCG(JL,KNU,IKL)
227     ZCORAE = ZFACOA * PSEC(JL)
228     ZCORCD = ZFACOC * PTAU(JL,KNU,IKL) * PSEC(JL)
229    ELSE !ECMWF VERSION
230    ZFACOA = 1.0_JPRB - PPIZAZ(JL,IKL)*PCGAZ(JL,IKL)*PCGAZ(JL,IKL)
231    ZFACOC = 1.0_JPRB - POMEGA(JL,KNU,IKL) * PCG(JL,KNU,IKL)* PCG(JL,KNU,IKL)
232    ZCORAE = ZFACOA * PTAUAZ(JL,IKL) * PSEC(JL)
233    ZCORCD = ZFACOC * PTAU(JL,KNU,IKL) * PSEC(JL)
234    ENDIF
235!--MODIFCODE
236!    ZR21(JL) = EXP(-ZCORAE   )
237!    ZR22(JL) = EXP(-ZCORCD   )
238
239    ZCHKAE = MIN( 200._JPRB, ZCORAE )
240    ZCHKCD = MIN( 200._JPRB, ZCORCD )
241    ZR21(JL) = EXP( - ZCHKAE )
242    ZR22(JL) = EXP( - ZCHKCD )
243
244    ZSS1(JL) = PCLD(JL,IKL)*(1.0_JPRB-ZR21(JL)*ZR22(JL))&
245     & + (1.0_JPRB-PCLD(JL,IKL))*(1.0_JPRB-ZR21(JL)) 
246    ZCLEQ(JL,IKL) = ZSS1(JL)
247
248!++MODIFCODE
249    IF ((NOVLP == 1).OR.(NOVLP == 8)) THEN
250!--MODIFCODE
251!* maximum-random     
252      ZCLEAR(JL) = ZCLEAR(JL)&
253       & *(1.0_JPRB-MAX(ZSS1(JL),ZCLOUD(JL)))&
254       & /(1.0_JPRB-MIN(ZCLOUD(JL),1.0_JPRB-REPSEC)) 
255      ZC1I(JL,IKL) = 1.0_JPRB - ZCLEAR(JL)
256      ZCLOUD(JL) = ZSS1(JL)
257    ELSEIF (NOVLP == 2) THEN
258!* maximum
259      ZCLOUD(JL) = MAX( ZSS1(JL) , ZCLOUD(JL) )
260      ZC1I(JL,IKL) = ZCLOUD(JL)
261!++MODIFCODE
262  ELSEIF ((NOVLP == 3).OR.((NOVLP  >=  5).AND.(NOVLP /= 8))) THEN
263!--MODIFCODE
264!* random
265      ZCLEAR(JL) = ZCLEAR(JL)*(1.0_JPRB - ZSS1(JL))
266      ZCLOUD(JL) = 1.0_JPRB - ZCLEAR(JL)
267      ZC1I(JL,IKL) = ZCLOUD(JL)
268    ELSEIF (NOVLP == 4) THEN
269!* Hogan & Illingworth, 2001 
270      ZCLEAR(JL)=ZCLEAR(JL)*( &
271       & ZALPHA1*(1.0_JPRB-MAX(ZSS1(JL),ZCLOUD(JL))) &
272       & /(1.0_JPRB-MIN(ZCLOUD(JL),1.0_JPRB-REPSEC)) &
273       & +(1.0_JPRB-ZALPHA1)*(1.0_JPRB-ZSS1(JL)) ) 
274      ZC1I(JL,IKL) = 1.0_JPRB - ZCLEAR(JL)
275      ZCLOUD(JL) = ZSS1(JL)
276    ENDIF
277  ENDDO
278ENDDO
279
280!     ------------------------------------------------------------------
281
282!*         3.    REFLECTIVITY/TRANSMISSIVITY FOR PURE SCATTERING
283!                -----------------------------------------------
284
285DO JL = KIDIA,KFDIA
286  PRAY1(JL,KLEV+1) = 0.0_JPRB
287  PRAY2(JL,KLEV+1) = 0.0_JPRB
288  PREFZ(JL,2,1) = PALBD(JL,KNU)
289  PREFZ(JL,1,1) = PALBD(JL,KNU)
290  PTRA1(JL,KLEV+1) = 1.0_JPRB
291  PTRA2(JL,KLEV+1) = 1.0_JPRB
292ENDDO
293
294DO JK = 2 , KLEV+1
295  JKM1 = JK-1
296  DO JL = KIDIA,KFDIA
297    ZRNEB(JL)= PCLD(JL,JKM1)
298    ZRE1(JL)=0.0_JPRB
299    ZTR1(JL)=0.0_JPRB
300    ZRE2(JL)=0.0_JPRB
301    ZTR2(JL)=0.0_JPRB
302
303!     ------------------------------------------------------------------
304
305!*         3.1  EQUIVALENT ZENITH ANGLE
306!               -----------------------
307
308    ZMUE = (1.0_JPRB-ZC1I(JL,JK)) * PSEC(JL)+ ZC1I(JL,JK) * 1.66_JPRB
309    PRMUE(JL,JK) = 1.0_JPRB/ZMUE
310
311!     ------------------------------------------------------------------
312
313!*         3.2  REFLECT./TRANSMISSIVITY DUE TO RAYLEIGH AND AEROSOLS
314!               ----------------------------------------------------
315
316    ZGAP = PCGAZ(JL,JKM1)
317    ZBMU0 = 0.5_JPRB - 0.75_JPRB * ZGAP / ZMUE
318    ZWW = PPIZAZ(JL,JKM1)
319    ZTO = PTAUAZ(JL,JKM1)
320    ZDEN = 1.0_JPRB + (1.0_JPRB - ZWW + ZBMU0 * ZWW) * ZTO * ZMUE &
321     & + (1-ZWW) * (1.0_JPRB - ZWW +2.0_JPRB*ZBMU0*ZWW)*ZTO*ZTO*ZMUE*ZMUE 
322    ZIDEN=1.0_JPRB/ZDEN
323    PRAY1(JL,JKM1) = ZBMU0 * ZWW * ZTO * ZMUE * ZIDEN
324    PTRA1(JL,JKM1) = ZIDEN
325
326    ZMU1 = 0.5_JPRB
327    ZIMU1=2.0_JPRB
328    ZI2MU1=4.0_JPRB
329    ZBMU1 = 0.5_JPRB - 0.75_JPRB * ZGAP * ZMU1
330    ZDEN1= 1.0_JPRB + (1.0_JPRB - ZWW + ZBMU1 * ZWW) * ZTO * ZIMU1 &
331     & + (1-ZWW) * (1.0_JPRB - ZWW +2.0_JPRB*ZBMU1*ZWW)*ZTO*ZTO*ZI2MU1 
332    ZIDEN1=1.0_JPRB/ZDEN1
333    PRAY2(JL,JKM1) = ZBMU1 * ZWW * ZTO * ZIMU1 * ZIDEN1
334    PTRA2(JL,JKM1) = ZIDEN1
335
336!     ------------------------------------------------------------------
337
338!*         3.3  EFFECT OF CLOUD LAYER
339!               ---------------------
340
341
342!++MODIFCODE
343    IF (NOVLP >= 5)THEN !MESONH VERSION
344     ZW(JL) =PCG(JL,KNU,JKM1)*PCG(JL,KNU,JKM1)
345     ZTO1(JL) = PTAU(JL,KNU,JKM1)*(1-(POMEGA(JL,KNU,JKM1)*ZW(JL)))
346     ZW(JL) =POMEGA(JL,KNU,JKM1)*(1-ZW(JL))/(1-(POMEGA(JL,KNU,JKM1)*ZW(JL)))
347     ZGG(JL) = PCG(JL,KNU,JKM1)/(1+PCG(JL,KNU,JKM1))
348     ZGG(JL)=ZTO1(JL)*ZW(JL)*ZGG(JL)+PTAUAZ(JL,JKM1)*PPIZAZ(JL,JKM1)*PCGAZ(JL,JKM1)
349     ZW(JL) =ZTO1(JL)*ZW(JL)+PTAUAZ(JL,JKM1)*PPIZAZ(JL,JKM1)
350     ZTO1(JL) = ZTO1(JL) +  PTAUAZ(JL,JKM1)
351     ZGG(JL)=ZGG(JL)/ZW(JL)
352     ZW(JL) =ZW(JL)/ZTO1(JL)
353    ELSE !ECMWF VERSION
354    ZW(JL) = POMEGA(JL,KNU,JKM1)
355    ZTO1(JL) = PTAU(JL,KNU,JKM1)/ZW(JL)+ PTAUAZ(JL,JKM1)/PPIZAZ(JL,JKM1)
356    ZR21(JL) = PTAU(JL,KNU,JKM1) + PTAUAZ(JL,JKM1)
357    ZR22(JL) = PTAU(JL,KNU,JKM1) / ZR21(JL)
358    ZGG(JL) = ZR22(JL) * PCG(JL,KNU,JKM1)&
359     & + (1.0_JPRB - ZR22(JL)) * PCGAZ(JL,JKM1) 
360    IF (ZW(JL) == 1.0_JPRB .AND. PPIZAZ(JL,JKM1) == 1.0_JPRB) THEN
361      ZW(JL)=1.0_JPRB
362    ELSE
363      ZW(JL) = ZR21(JL) / ZTO1(JL)
364     ENDIF
365    ENDIF
366!--MODIFCODE
367    ZREF(JL) = PREFZ(JL,1,JKM1)
368    ZRMUZ(JL) = PRMUE(JL,JK)
369    ENDDO
370
371  CALL SWDE ( KIDIA, KFDIA , KLON,&
372   & ZGG  , ZREF  , ZRMUZ , ZTO1 , ZW,&
373   & ZRE1 , ZRE2  , ZTR1  , ZTR2      ) 
374
375   DO JL = KIDIA,KFDIA
376
377    ZRR=1.0_JPRB/(1.0_JPRB-PRAY2(JL,JKM1)*PREFZ(JL,1,JKM1))
378
379    PREFZ(JL,1,JK) = (1.0_JPRB-ZRNEB(JL)) * (PRAY1(JL,JKM1)&
380     & + PREFZ(JL,1,JKM1) * PTRA1(JL,JKM1)&
381     & * PTRA2(JL,JKM1)&
382     & * ZRR ) &
383     & + ZRNEB(JL) * ZRE2(JL) 
384
385    ZTR(JL,1,JKM1) = ZRNEB(JL) * ZTR2(JL) + (PTRA1(JL,JKM1)&
386     & * ZRR ) &
387     & * (1.0_JPRB-ZRNEB(JL)) 
388
389    PREFZ(JL,2,JK) = (1.0_JPRB-ZRNEB(JL)) * (PRAY1(JL,JKM1)&
390     & + PREFZ(JL,2,JKM1) * PTRA1(JL,JKM1)&
391     & * PTRA2(JL,JKM1) )&
392     & + ZRNEB(JL) * ZRE1(JL) 
393
394    ZTR(JL,2,JKM1) = ZRNEB(JL) * ZTR1(JL)+ PTRA1(JL,JKM1) * (1.0_JPRB-ZRNEB(JL))
395
396  ENDDO
397ENDDO
398DO JL = KIDIA,KFDIA
399  ZMUE = (1.0_JPRB-ZC1I(JL,1))*PSEC(JL)+ZC1I(JL,1)*1.66_JPRB
400  PRMUE(JL,1)=1.0_JPRB/ZMUE
401  PTRCLD(JL)=1.0_JPRB-ZC1I(JL,1)
402ENDDO
403
404!     ------------------------------------------------------------------
405
406!*         3.5    REFLECT./TRANSMISSIVITY BETWEEN SURFACE AND LEVEL
407!                 -------------------------------------------------
408
409IF (NSW <= 4) THEN
410  INU1=1
411ELSEIF (NSW == 6) THEN
412  INU1=3
413ENDIF   
414
415IF (KNU <= INU1) THEN
416  JAJ = 2
417  DO JL = KIDIA,KFDIA
418    PRJ(JL,JAJ,KLEV+1) = 1.0_JPRB
419    PRK(JL,JAJ,KLEV+1) = PREFZ(JL, 1,KLEV+1)
420  ENDDO
421
422  DO JK = 1 , KLEV
423    IKL = KLEV+1 - JK
424    IKLP1 = IKL + 1
425    DO JL = KIDIA,KFDIA
426      ZRE11= PRJ(JL,JAJ,IKLP1) * ZTR(JL,  1,IKL)
427      PRJ(JL,JAJ,IKL) = ZRE11
428      PRK(JL,JAJ,IKL) = ZRE11 * PREFZ(JL,  1,IKL)
429    ENDDO
430  ENDDO
431
432ELSE
433
434  DO JAJ = 1 , 2
435    DO JL = KIDIA,KFDIA
436      PRJ(JL,JAJ,KLEV+1) = 1.0_JPRB
437      PRK(JL,JAJ,KLEV+1) = PREFZ(JL,JAJ,KLEV+1)
438    ENDDO
439
440    DO JK = 1 , KLEV
441      IKL = KLEV+1 - JK
442      IKLP1 = IKL + 1
443      DO JL = KIDIA,KFDIA
444        ZRE11= PRJ(JL,JAJ,IKLP1) * ZTR(JL,JAJ,IKL)
445        PRJ(JL,JAJ,IKL) = ZRE11
446        PRK(JL,JAJ,IKL) = ZRE11 * PREFZ(JL,JAJ,IKL)
447      ENDDO
448    ENDDO
449  ENDDO
450
451ENDIF
452IF(LLDEBUG) THEN
453 call writefield_phy ('swr_zc1i',ZC1I,KLEV+1)
454 call writefield_phy ('swr_zss1',ZSS1,1)
455 call writefield_phy ('swr_zclear',ZCLEAR,1)
456 call writefield_phy ('swr_prmue',PRMUE,KLEV+1)
457 call writefield_phy ('swr_psec',PSEC,1)
458 call writefield_phy ('swr_prmue',PRMUE,KLEV+1)
459 call writefield_phy ('swr_ppizaz',PPIZAZ,KLEV)
460 call writefield_phy ('swr_pcgaz',PCGAZ,KLEV)
461 call writefield_phy ('swr_pcg',PCG,KLEV)
462 call writefield_phy ('swr_ptau',PTAU(:,1,:),KLEV)
463 call writefield_phy ('swr_ptauaz',PTAUAZ,KLEV)
464 call writefield_phy ('swr_pcld',PCLD,KLEV)
465ENDIF
466!     ------------------------------------------------------------------
467
468IF (LHOOK) CALL DR_HOOK('SWR',1,ZHOOK_HANDLE)
469END SUBROUTINE SWR
Note: See TracBrowser for help on using the repository browser.