source: LMDZ5/branches/IPSLCM6.0.8/libf/phylmd/rrtm/sw.F90

Last change on this file 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: 11.1 KB
Line 
1SUBROUTINE SW &
2 & ( KIDIA, KFDIA , KLON  , KLEV , KAER,&
3 & PSCT , PCARDI, PPSOL , PALBD, PALBP , PWV, PQS,&
4 & PRMU0, PCG   , PCLDSW, PDP  , POMEGA, POZ, PPMB,&
5 & PTAU , PTAVE , PAER,&
6 & PFDOWN, PFUP,&
7 & PCDOWN, PCUP,&
8 & PFDNN, PFDNV , PFUPN, PFUPV,&
9 & PCDNN, PCDNV , PCUPN, PCUPV,&
10 & PSUDU, PUVDF , PPARF, PPARCF, PDIFFS , PDIRFS, &
11 & LRDUST, PPIZA_DST,PCGA_DST,PTAUREL_DST &
12 & )
13
14
15!**** *SW* - COMPUTES THE SHORTWAVE RADIATION FLUXES.
16
17!     PURPOSE.
18!     --------
19
20!          THIS ROUTINE COMPUTES THE SHORTWAVE RADIATION FLUXES IN TWO
21!     SPECTRAL INTERVALS FOLLOWING FOUQUART AND BONNEL (1980).
22
23!**   INTERFACE.
24!     ----------
25
26!          *SW* IS CALLED FROM *RADLSW*
27
28!        IMPLICIT ARGUMENTS :
29!        --------------------
30
31!     ==== INPUTS ===
32!     ==== OUTPUTS ===
33
34!     METHOD.
35!     -------
36
37!          1. COMPUTES ABSORBER AMOUNTS                 (SWU)
38!          2. COMPUTES FLUXES IN U.V./VISIBLE  SPECTRAL INTERVAL (SW1S)
39!          3. COMPUTES FLUXES IN NEAR-INFRARED SPECTRAL INTERVAL (SWNI)
40
41!     EXTERNALS.
42!     ----------
43
44!          *SWU*, *SW1S*, *SWNI*
45
46!     REFERENCE.
47!     ----------
48
49!        SEE RADIATION'S PART OF THE ECMWF RESEARCH DEPARTMENT
50!        DOCUMENTATION, AND FOUQUART AND BONNEL (1980)
51
52!     AUTHOR.
53!     -------
54!        JEAN-JACQUES MORCRETTE  *ECMWF*
55
56!     MODIFICATIONS.
57!     --------------
58!        ORIGINAL : 89-07-14
59!        95-01-01   J.-J. MORCRETTE  Direct/Diffuse Albedo
60!        95-12-07   J.-J. MORCRETTE  Near-Infrared in nsw-1 Intervals
61!        990128     JJMorcrette      sunshine duration
62!        99-05-25   JJMorcrette      Revised aerosols
63!        00-12-18   JJMorcrette      6 spectral intervals
64!        02-09-01   JJMorcrette      UV and PAR
65!        M.Hamrud      01-Oct-2003 CY28 Cleaning
66!        Y.Seity  04-11-18 : add two arguments for AROME extern. surface
67!        Y.Seity  05-10-10 : add add 3 optional arg. for dust SW properties
68!        JJMorcrette 20060721 PP of clear-sky PAR
69!     ------------------------------------------------------------------
70
71USE PARKIND1  ,ONLY : JPIM     ,JPRB
72USE YOMHOOK   ,ONLY : LHOOK,   DR_HOOK
73!USE YOERAD   , ONLY : NSW
74! NSW mis dans .def MPL 20140211
75USE write_field_phy
76
77IMPLICIT NONE
78
79include "clesphys.h"
80
81integer, save :: icount=0
82!$OMP THREADPRIVATE(icount)
83INTEGER(KIND=JPIM),INTENT(IN)    :: KLON
84INTEGER(KIND=JPIM),INTENT(IN)    :: KLEV
85INTEGER(KIND=JPIM),INTENT(IN)    :: KIDIA
86INTEGER(KIND=JPIM),INTENT(IN)    :: KFDIA
87INTEGER(KIND=JPIM),INTENT(IN)    :: KAER
88REAL(KIND=JPRB)   ,INTENT(IN)    :: PSCT
89REAL(KIND=JPRB)   ,INTENT(IN)    :: PCARDI
90REAL(KIND=JPRB)   ,INTENT(IN)    :: PPSOL(KLON)
91REAL(KIND=JPRB)   ,INTENT(IN)    :: PALBD(KLON,NSW)
92REAL(KIND=JPRB)   ,INTENT(IN)    :: PALBP(KLON,NSW)
93REAL(KIND=JPRB)   ,INTENT(IN)    :: PWV(KLON,KLEV)
94REAL(KIND=JPRB)   ,INTENT(IN)    :: PQS(KLON,KLEV)
95REAL(KIND=JPRB)   ,INTENT(IN)    :: PRMU0(KLON)
96REAL(KIND=JPRB)   ,INTENT(IN)    :: PCG(KLON,NSW,KLEV)
97REAL(KIND=JPRB)   ,INTENT(IN)    :: PCLDSW(KLON,KLEV)
98REAL(KIND=JPRB)                  :: PDP(KLON,KLEV) ! Argument NOT used
99REAL(KIND=JPRB)   ,INTENT(IN)    :: POMEGA(KLON,NSW,KLEV)
100REAL(KIND=JPRB)   ,INTENT(IN)    :: POZ(KLON,KLEV)
101REAL(KIND=JPRB)   ,INTENT(IN)    :: PPMB(KLON,KLEV+1)
102REAL(KIND=JPRB)   ,INTENT(IN)    :: PTAU(KLON,NSW,KLEV)
103REAL(KIND=JPRB)   ,INTENT(IN)    :: PTAVE(KLON,KLEV)
104REAL(KIND=JPRB)   ,INTENT(IN)    :: PAER(KLON,6,KLEV)
105!++MODIFCODE
106LOGICAL           ,INTENT(IN)    :: LRDUST
107REAL(KIND=JPRB)   ,INTENT(IN)    :: PPIZA_DST(KLON,KLEV,NSW)
108REAL(KIND=JPRB)   ,INTENT(IN)    :: PCGA_DST(KLON,KLEV,NSW)
109REAL(KIND=JPRB)   ,INTENT(IN)    :: PTAUREL_DST(KLON,KLEV,NSW)
110!--MODIFCODE
111REAL(KIND=JPRB)   ,INTENT(OUT)   :: PFDOWN(KLON,KLEV+1)
112REAL(KIND=JPRB)   ,INTENT(OUT)   :: PFUP(KLON,KLEV+1)
113REAL(KIND=JPRB)   ,INTENT(OUT)   :: PCDOWN(KLON,KLEV+1)
114REAL(KIND=JPRB)   ,INTENT(OUT)   :: PCUP(KLON,KLEV+1)
115REAL(KIND=JPRB)   ,INTENT(OUT)   :: PFDNN(KLON)
116REAL(KIND=JPRB)   ,INTENT(OUT)   :: PFDNV(KLON)
117REAL(KIND=JPRB)   ,INTENT(OUT)   :: PFUPN(KLON)
118REAL(KIND=JPRB)   ,INTENT(OUT)   :: PFUPV(KLON)
119REAL(KIND=JPRB)   ,INTENT(OUT)   :: PCDNN(KLON)
120REAL(KIND=JPRB)   ,INTENT(OUT)   :: PCDNV(KLON)
121REAL(KIND=JPRB)   ,INTENT(OUT)   :: PCUPN(KLON)
122REAL(KIND=JPRB)   ,INTENT(OUT)   :: PCUPV(KLON)
123REAL(KIND=JPRB)   ,INTENT(OUT)   :: PSUDU(KLON)
124REAL(KIND=JPRB)   ,INTENT(OUT)   :: PUVDF(KLON)
125REAL(KIND=JPRB)   ,INTENT(OUT)   :: PPARF(KLON)
126REAL(KIND=JPRB)   ,INTENT(OUT)   :: PPARCF(KLON)
127REAL(KIND=JPRB)   ,INTENT(OUT)   :: PDIFFS(KLON,NSW)
128REAL(KIND=JPRB)   ,INTENT(OUT)   :: PDIRFS(KLON,NSW)
129!     ------------------------------------------------------------------
130
131!*       0.1   ARGUMENTS
132!              ---------
133
134!     ------------------------------------------------------------------
135
136!              ------------
137
138REAL(KIND=JPRB) :: ZAKI(KLON,2,NSW)&
139 & ,  ZCLD(KLON,KLEV)    , ZCLEAR(KLON) &
140 & ,  ZDSIG(KLON,KLEV)   , ZFACT(KLON)&
141 & ,  ZFD(KLON,KLEV+1)   , ZCD(KLON,KLEV+1)&
142 & ,  ZCDOWN(KLON,KLEV+1), ZCDNIR(KLON,KLEV+1), ZCDUVS(KLON,KLEV+1)&
143 & ,  ZFDOWN(KLON,KLEV+1), ZFDNIR(KLON,KLEV+1), ZFDUVS(KLON,KLEV+1)&
144 & ,  ZFU(KLON,KLEV+1)   , ZCU(KLON,KLEV+1)&
145 & ,  ZCUP(KLON,KLEV+1)  , ZCUNIR(KLON,KLEV+1), ZCUUVS(KLON,KLEV+1)&
146 & ,  ZFUP(KLON,KLEV+1)  , ZFUNIR(KLON,KLEV+1), ZFUUVS(KLON,KLEV+1)&
147 & ,  ZRMU(KLON)         , ZSEC(KLON)         &
148 & ,  ZSUDU1(KLON)       , ZSUDU2(KLON)       &
149 & ,  ZSUDU1T(KLON)      , ZSUDU2T(KLON)      &
150 & ,  ZUD(KLON,5,KLEV+1) ,ZDIFF(KLON,KLEV)   ,ZDIRF(KLON,KLEV)    &
151 & ,  ZDIFF2(KLON,KLEV)  , ZDIRF2(KLON,KLEV)
152
153INTEGER(KIND=JPIM) ::  JK, JL, JNU, INUVS, INUIR
154
155REAL(KIND=JPRB) :: ZHOOK_HANDLE
156LOGICAL         :: LLDEBUG
157character*1 str1
158
159#include "sw1s.intfb.h"
160#include "swni.intfb.h"
161#include "swu.intfb.h"
162
163!     ------------------------------------------------------------------
164
165!*         1.     ABSORBER AMOUNTS AND OTHER USEFUL QUANTITIES
166!                 --------------------------------------------
167
168IF (LHOOK) CALL DR_HOOK('SW',0,ZHOOK_HANDLE)
169LLDEBUG=.FALSE.
170CALL SWU ( KIDIA,KFDIA ,KLON  ,KLEV,&
171 & PSCT ,PCARDI,PCLDSW,PPMB ,PPSOL,&
172 & PRMU0,PTAVE ,PWV,&
173 & ZAKI ,ZCLD  ,ZCLEAR,ZDSIG,ZFACT,ZRMU,ZSEC,ZUD ) 
174
175!     ------------------------------------------------------------------
176!*         2.     INTERVAL (0.185/0.25-0.68 MICRON): U.V. AND VISIBLE
177!                 ---------------------------------------------------
178IF (NSW <= 4) THEN
179  INUVS=1
180  INUIR=2
181ELSEIF (NSW == 6) THEN
182  INUVS=1
183  INUIR=4
184ENDIF     
185
186DO JK = 1 , KLEV+1
187  DO JL = KIDIA,KFDIA
188    ZFD(JL,JK) =0.0_JPRB
189    ZFU(JL,JK) =0.0_JPRB
190    ZCD(JL,JK) =0.0_JPRB
191    ZCU(JL,JK) =0.0_JPRB
192  ENDDO
193ENDDO
194DO JL = KIDIA,KFDIA
195  ZSUDU1T(JL)=0.0_JPRB
196  PUVDF(JL)  =0.0_JPRB
197  PPARF(JL)  =0.0_JPRB
198  PPARCF(JL) =0.0_JPRB
199ENDDO
200
201IF(LLDEBUG) THEN
202call writefield_phy('sw_zsec',ZSEC,1)
203call writefield_phy('sw_zrmu',ZRMU,1)
204call writefield_phy('sw_prmu0',PRMU0,1)
205call writefield_phy('sw_zfact',ZFACT,1)
206ENDIF
207
208icount=icount+1
209DO JNU = INUVS , INUIR-1
210   !++MODIFCODE
211     CALL SW1S &
212           &( KIDIA , KFDIA, KLON , KLEV , KAER  , JNU &
213           &,  PAER , PALBD , PALBP, PCG  , ZCLD , ZCLEAR &
214           &,  ZDSIG, POMEGA, POZ  , ZRMU , ZSEC , PTAU  , ZUD  &
215           &,  ZFDUVS,ZFUUVS, ZCDUVS,ZCUUVS, ZSUDU1, ZDIFF,ZDIRF &
216           &,  LRDUST,PPIZA_DST(:,:,JNU) &       ! SSA for this wavelength
217           &,  PCGA_DST(:,:,JNU)   &            ! GCA for this wavelengt
218           &,  PTAUREL_DST(:,:,JNU) )           ! TAUREL for this wavelength
219  !--MODIFCODE
220IF(LLDEBUG) THEN
221! Ecriture des champs avec un indicage du fichier par l'intervalle spectral
222  write(str1,'(i1)') jnu
223  call writefield_phy("sw_zcduvs"//str1,zcduvs,klev+1)
224ENDIF
225
226
227  DO JL=KIDIA,KFDIA
228  PDIFFS(JL,JNU)=ZDIFF(JL,1)*ZFACT(JL)
229  PDIRFS(JL,JNU)=ZDIRF(JL,1)*ZFACT(JL)
230  ENDDO
231  DO JK = 1 , KLEV+1
232    DO JL = KIDIA,KFDIA
233      ZFD(JL,JK)=ZFD(JL,JK)+ZFDUVS(JL,JK)
234      ZFU(JL,JK)=ZFU(JL,JK)+ZFUUVS(JL,JK)
235      ZCD(JL,JK)=ZCD(JL,JK)+ZCDUVS(JL,JK)
236      ZCU(JL,JK)=ZCU(JL,JK)+ZCUUVS(JL,JK)
237    ENDDO
238  ENDDO
239  DO JL = KIDIA,KFDIA
240    ZSUDU1T(JL)=ZSUDU1T(JL)+ZSUDU1(JL)
241  ENDDO
242
243  IF (NSW == 6) THEN
244    IF (JNU <= 2) THEN
245      DO JL = KIDIA,KFDIA
246        PUVDF(JL)=PUVDF(JL)+ZFDUVS(JL,1)
247      ENDDO
248    ELSEIF (JNU == 3) THEN
249      DO JL=KIDIA,KFDIA
250        PPARF(JL)=PPARF(JL)+ZFDUVS(JL,1)
251        PPARCF(JL)=PPARCF(JL)+ZCDUVS(JL,1)
252      ENDDO
253    ENDIF   
254  ENDIF 
255ENDDO
256
257!if (icount==5) stop'on arrete dans sw.F90 au bout de 5 appels'
258!     ------------------------------------------------------------------
259
260!*         3.     INTERVAL (0.68-4.00 MICRON): NEAR-INFRARED
261!                 ------------------------------------------
262
263DO JK = 1 , KLEV+1
264  DO JL = KIDIA,KFDIA
265    ZFDOWN(JL,JK)=0.0_JPRB
266    ZFUP  (JL,JK)=0.0_JPRB
267    ZCDOWN(JL,JK)=0.0_JPRB
268    ZCUP  (JL,JK)=0.0_JPRB
269    ZSUDU2T(JL)  =0.0_JPRB
270  ENDDO
271ENDDO
272
273DO JNU = INUIR , NSW
274   !++MODIFCODE
275      CALL SWNI &
276           &(  KIDIA ,KFDIA , KLON , KLEV , KAER , JNU &
277           &,  PAER  ,ZAKI  , PALBD, PALBP, PCG  , ZCLD, ZCLEAR &
278           &,  ZDSIG ,POMEGA, POZ  , ZRMU , ZSEC , PTAU, ZUD      &
279           &,  PWV   ,PQS &
280           &,  ZFDNIR,ZFUNIR,ZCDNIR,ZCUNIR,ZSUDU2,ZDIFF2,ZDIRF2 &
281           &,  LRDUST,PPIZA_DST(:,:,JNU)  &
282           &,  PCGA_DST(:,:,JNU)    &
283           &,  PTAUREL_DST(:,:,JNU) &
284           &)
285    !--MODIFCODE
286
287IF(LLDEBUG) THEN
288! Ecriture des champs avec un indicage du fichier par l'intervalle spectral
289  write(str1,'(i1)') jnu
290  call writefield_phy("sw_zcdnir"//str1,zcdnir,klev+1)
291ENDIF
292
293  DO JL=KIDIA,KFDIA
294    PDIFFS(JL,JNU)=ZDIFF2(JL,1)*ZFACT(JL)
295    PDIRFS(JL,JNU)=ZDIRF2(JL,1)*ZFACT(JL)
296  ENDDO
297  DO JK = 1 , KLEV+1
298    DO JL = KIDIA,KFDIA
299      ZFDOWN(JL,JK)=ZFDOWN(JL,JK)+ZFDNIR(JL,JK)
300      ZFUP  (JL,JK)=ZFUP  (JL,JK)+ZFUNIR(JL,JK)
301      ZCDOWN(JL,JK)=ZCDOWN(JL,JK)+ZCDNIR(JL,JK)
302      ZCUP  (JL,JK)=ZCUP  (JL,JK)+ZCUNIR(JL,JK)
303    ENDDO
304  ENDDO
305  DO JL = KIDIA,KFDIA
306    ZSUDU2T(JL)=ZSUDU2T(JL)+ZSUDU2(JL)
307  ENDDO
308ENDDO
309
310!     ------------------------------------------------------------------
311
312!*         4.     FILL THE DIAGNOSTIC ARRAYS
313!                 --------------------------
314
315DO JL = KIDIA,KFDIA
316  PFDNN(JL)=ZFDOWN(JL,1)*ZFACT(JL)
317  PFDNV(JL)=ZFD(JL,1)*ZFACT(JL)
318  PFUPN(JL)=ZFUP(JL,KLEV+1)*ZFACT(JL)
319  PFUPV(JL)=ZFU(JL,KLEV+1)*ZFACT(JL)
320
321  PCDNN(JL)=ZCDOWN(JL,1)*ZFACT(JL)
322  PCDNV(JL)=ZCD(JL,1)*ZFACT(JL)
323  PCUPN(JL)=ZCUP(JL,KLEV+1)*ZFACT(JL)
324  PCUPV(JL)=ZCU(JL,KLEV+1)*ZFACT(JL)
325
326  PSUDU(JL)=(ZSUDU1T(JL)+ZSUDU2T(JL))*ZFACT(JL)
327  PUVDF(JL)=PUVDF(JL)*ZFACT(JL)
328  PPARF(JL)=PPARF(JL)*ZFACT(JL)
329  PPARCF(JL)=PPARCF(JL)*ZFACT(JL)
330ENDDO
331
332!WRITE(*,'("---> Dans SW:")')
333!WRITE(*,'("ZFUP  ",10E12.5)') (ZFUP(1,JK),JK=1,KLEV+1)
334!WRITE(*,'("ZFU   ",10E12.5)') (ZFU(1,JK),JK=1,KLEV+1)
335!WRITE(*,'("ZFUNIR",10E12.5)') (ZFUNIR(1,JK),JK=1,KLEV+1)
336!WRITE(*,'("ZFACT ",E12.5)') ZFACT(1)
337
338DO JK = 1 , KLEV+1
339  DO JL = KIDIA,KFDIA
340    PFUP(JL,JK)   = (ZFUP(JL,JK)   + ZFU(JL,JK)) * ZFACT(JL)
341    PFDOWN(JL,JK) = (ZFDOWN(JL,JK) + ZFD(JL,JK)) * ZFACT(JL)
342    PCUP(JL,JK)   = (ZCUP(JL,JK)   + ZCU(JL,JK)) * ZFACT(JL)
343    PCDOWN(JL,JK) = (ZCDOWN(JL,JK) + ZCD(JL,JK)) * ZFACT(JL)
344  ENDDO
345ENDDO
346IF(LLDEBUG) THEN
347call writefield_phy('sw_pcdown',PCDOWN,KLEV+1)
348ENDIF
349
350!     ------------------------------------------------------------------
351
352IF (LHOOK) CALL DR_HOOK('SW',1,ZHOOK_HANDLE)
353END SUBROUTINE SW
Note: See TracBrowser for help on using the repository browser.