/[lmdze]/trunk/Sources/phylmd/Radlwsw/radlwsw.f
ViewVC logotype

Diff of /trunk/Sources/phylmd/Radlwsw/radlwsw.f

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

trunk/libf/phylmd/Radlwsw/radlwsw.f revision 52 by guez, Fri Sep 23 12:28:01 2011 UTC trunk/Sources/phylmd/Radlwsw/radlwsw.f revision 212 by guez, Thu Jan 12 12:31:31 2017 UTC
# Line 1  Line 1 
1  !  module radlwsw_m
2  ! $Header: /home/cvsroot/LMDZ4/libf/phylmd/radlwsw.F,v 1.4 2005/06/06 13:16:33 fairhead Exp $  
3  !    IMPLICIT none
4        SUBROUTINE radlwsw(dist, rmu0, fract,  
5       .                  paprs, pplay,tsol,albedo, alblw, t,q,wo,  contains
6       .                  cldfra, cldemi, cldtaupd,  
7       .                  heat,heat0,cool,cool0,radsol,albpla,    SUBROUTINE radlwsw(dist, mu0, fract, paprs, play, tsol, albedo, t, q, wo, &
8       .                  topsw,toplw,solsw,sollw,         cldfra, cldemi, cldtaupd, heat, heat0, cool, cool0, radsol, albpla, &
9       .                  sollwdown,         topsw, toplw, solsw, sollw, sollwdown, topsw0, toplw0, solsw0, sollw0, &
10       .                  topsw0,toplw0,solsw0,sollw0,         lwdn0, lwdn, lwup0, lwup, swdn0, swdn, swup0, swup, ok_ade, ok_aie, &
11       .                  lwdn0, lwdn, lwup0, lwup,         tau_ae, piz_ae, cg_ae, topswad, solswad, cldtaupi, topswai, solswai)
12       .                  swdn0, swdn, swup0, swup,  
13       .                  ok_ade, ok_aie,      ! From LMDZ4/libf/phylmd/radlwsw.F, version 1.4 2005/06/06 13:16:33
14       .                  tau_ae, piz_ae, cg_ae,      ! Author: Z. X. Li (LMD/CNRS)
15       .                  topswad, solswad,      ! Date: 1996/07/19
16       .                  cldtaupi, topswai, solswai)  
17  c            ! Objet : interface entre le modèle et les rayonnements solaire et
18        use dimphy      ! infrarouge
19        use clesphys  
20        use SUPHEC_M      ! ATTENTION: swai and swad have to be interpreted in the following manner:
21        use raddim, only: kflev, kdlon  
22        use yoethf_m      ! not ok_ade and not ok_aie
23        IMPLICIT none      ! both are zero
24  c======================================================================  
25  c Auteur(s): Z.X. Li (LMD/CNRS) date: 19960719      ! ok_ade and not ok_aie
26  c Objet: interface entre le modele et les rayonnements      ! aerosol direct forcing is F_{AD} = topsw - topswad
27  c Arguments:      ! indirect is zero
28  c dist-----input-R- distance astronomique terre-soleil  
29  c rmu0-----input-R- cosinus de l'angle zenithal      ! not ok_ade and ok_aie
30  c fract----input-R- duree d'ensoleillement normalisee      ! aerosol indirect forcing is F_{AI} = topsw - topswai
31  c co2_ppm--input-R- concentration du gaz carbonique (en ppm)      ! direct is zero
32  c solaire--input-R- constante solaire (W/m**2)  
33  c paprs----input-R- pression a inter-couche (Pa)      ! ok_ade and ok_aie
34  c pplay----input-R- pression au milieu de couche (Pa)      ! aerosol indirect forcing is F_{AI} = topsw - topswai
35  c tsol-----input-R- temperature du sol (en K)      ! aerosol direct forcing is F_{AD} = topswai - topswad
36  c albedo---input-R- albedo du sol (entre 0 et 1)  
37  c t--------input-R- temperature (K)      USE clesphys, ONLY: solaire
38  c q--------input-R- vapeur d'eau (en kg/kg)      USE dimphy, ONLY: klev, klon
39  c wo-------input-R- contenu en ozone (en kg/kg) correction MPL 100505      use lw_m, only: lw
40  c cldfra---input-R- fraction nuageuse (entre 0 et 1)      USE raddim, ONLY: kdlon
41  c cldtaupd---input-R- epaisseur optique des nuages dans le visible (present-day value)      USE suphec_m, ONLY: rg
42  c cldemi---input-R- emissivite des nuages dans l'IR (entre 0 et 1)      use sw_m, only: sw
43  c ok_ade---input-L- apply the Aerosol Direct Effect or not?      USE yoethf_m, ONLY: rvtmp2
44  c ok_aie---input-L- apply the Aerosol Indirect Effect or not?          
45  c tau_ae, piz_ae, cg_ae-input-R- aerosol optical properties (calculated in aeropt.F)      real, intent(in):: dist ! distance astronomique terre-soleil
46  c cldtaupi-input-R- epaisseur optique des nuages dans le visible      real, intent(in):: mu0(klon) ! cosinus de l'angle zenithal
47  c                   calculated for pre-industrial (pi) aerosol concentrations, i.e. with smaller      real, intent(in):: fract(klon) ! duree d'ensoleillement normalisee
48  c                   droplet concentration, thus larger droplets, thus generally cdltaupi cldtaupd      real, intent(in):: paprs(klon, klev+1) ! pression a inter-couche (Pa)
49  c                   it is needed for the diagnostics of the aerosol indirect radiative forcing            real, intent(in):: play(klon, klev) ! pression au milieu de couche (Pa)
50  c      real, intent(in):: tsol(klon) ! temperature du sol (en K)
51  c heat-----output-R- echauffement atmospherique (visible) (K/jour)      real, intent(in):: albedo(klon) ! albedo du sol (entre 0 et 1)
52  c cool-----output-R- refroidissement dans l'IR (K/jour)      real, intent(in):: t(klon, klev) ! temperature (K)
53  c radsol---output-R- bilan radiatif net au sol (W/m**2) (+ vers le bas)      real, intent(in):: q(klon, klev) ! vapeur d'eau (en kg/kg)
54  c albpla---output-R- albedo planetaire (entre 0 et 1)  
55  c topsw----output-R- flux solaire net au sommet de l'atm.      real, intent(in):: wo(klon, klev)
56  c toplw----output-R- ray. IR montant au sommet de l'atmosphere      ! column-density of ozone in a layer, in kilo-Dobsons
57  c solsw----output-R- flux solaire net a la surface  
58  c sollw----output-R- ray. IR montant a la surface      real, intent(in):: cldfra(klon, klev) ! fraction nuageuse (entre 0 et 1)
59  c solswad---output-R- ray. solaire net absorbe a la surface (aerosol dir)  
60  c topswad---output-R- ray. solaire absorbe au sommet de l'atm. (aerosol dir)      real, intent(in):: cldemi(klon, klev)
61  c solswai---output-R- ray. solaire net absorbe a la surface (aerosol ind)      ! emissivite des nuages dans l'IR (entre 0 et 1)
62  c topswai---output-R- ray. solaire absorbe au sommet de l'atm. (aerosol ind)  
63  c      real, intent(in):: cldtaupd(klon, klev)
64  c ATTENTION: swai and swad have to be interpreted in the following manner:      ! epaisseur optique des nuages dans le visible (present-day value)
65  c ---------  
66  c ok_ade=F & ok_aie=F -both are zero      real, intent(out):: heat(klon, klev)
67  c ok_ade=T & ok_aie=F -aerosol direct forcing is F_{AD} = topsw-topswad      ! échauffement atmosphérique (visible) (K/jour)
68  c                        indirect is zero  
69  c ok_ade=F & ok_aie=T -aerosol indirect forcing is F_{AI} = topsw-topswai      real, intent(out):: heat0(klon, klev)
70  c                        direct is zero      real, intent(out):: cool(klon, klev) ! refroidissement dans l'IR (K/jour)
71  c ok_ade=T & ok_aie=T -aerosol indirect forcing is F_{AI} = topsw-topswai      real, intent(out):: cool0(klon, klev)
72  c                        aerosol direct forcing is F_{AD} = topswai-topswad  
73  c      real, intent(out):: radsol(klon)
74              ! bilan radiatif net au sol (W/m**2) (+ vers le bas)
75  c======================================================================  
76  c      real, intent(out):: albpla(klon) ! albedo planetaire (entre 0 et 1)
77        real rmu0(klon), fract(klon), dist      real, intent(out):: topsw(klon) ! flux solaire net au sommet de l'atm.
78  cIM   real co2_ppm  
79  cIM   real solaire      real, intent(out):: toplw(klon)
80  c      ! rayonnement infrarouge montant au sommet de l'atmosphère
81        real, intent(in):: paprs(klon,klev+1)  
82        real, intent(in):: pplay(klon,klev)      real, intent(out):: solsw(klon) ! flux solaire net à la surface
83        real albedo(klon), alblw(klon), tsol(klon)  
84        real, intent(in):: t(klon,klev)      real, intent(out):: sollw(klon)
85        real q(klon,klev)      ! rayonnement infrarouge montant à la surface
86        real, intent(in):: wo(klon,klev)  
87        real cldfra(klon,klev), cldemi(klon,klev), cldtaupd(klon,klev)      real, intent(out):: sollwdown(klon)
88        real heat(klon,klev), cool(klon,klev)      real, intent(out):: topsw0(klon)
89        real heat0(klon,klev), cool0(klon,klev)      real, intent(out):: toplw0(klon)
90        real radsol(klon), topsw(klon), toplw(klon)      real, intent(out):: solsw0(klon), sollw0(klon)
91        real solsw(klon), sollw(klon), albpla(klon)      REAL, intent(out):: lwdn0(klon, klev+1), lwdn(klon, klev+1)
92        real topsw0(klon), toplw0(klon), solsw0(klon), sollw0(klon)      REAL, intent(out):: lwup0(klon, klev+1), lwup(klon, klev+1)
93        real sollwdown(klon)      REAL, intent(out):: swdn0(klon, klev+1), swdn(klon, klev+1)
94  cIM output 3D      REAL, intent(out):: swup0(klon, klev+1), swup(klon, klev+1)
95        REAL*8 ZFSUP(KDLON,KFLEV+1)  
96        REAL*8 ZFSDN(KDLON,KFLEV+1)      logical, intent(in):: ok_ade ! apply the Aerosol Direct Effect
97        REAL*8 ZFSUP0(KDLON,KFLEV+1)      logical, intent(in):: ok_aie ! apply the Aerosol Indirect Effect
98        REAL*8 ZFSDN0(KDLON,KFLEV+1)  
99  c      ! aerosol optical properties (calculated in aeropt.F):
100        REAL*8 ZFLUP(KDLON,KFLEV+1)      real, intent(in):: tau_ae(klon, klev, 2), piz_ae(klon, klev, 2)
101        REAL*8 ZFLDN(KDLON,KFLEV+1)      real, intent(in):: cg_ae(klon, klev, 2)
102        REAL*8 ZFLUP0(KDLON,KFLEV+1)  
103        REAL*8 ZFLDN0(KDLON,KFLEV+1)      real, intent(out):: topswad(klon), solswad(klon)
104  c      ! aerosol direct forcing at TOA and surface
105        REAL*8 zx_alpha1, zx_alpha2      ! ray. solaire net absorbe
106  c      
107  c      real, intent(in):: cldtaupi(klon, klev)
108        INTEGER k, kk, i, j, iof, nb_gr      ! cloud visible optical thickness for pre-industrial aerosol concentrations
109        EXTERNAL lw, sw      ! i.e. with smaller droplet concentration, thus larger droplets,
110  c      ! thus generally cdltaupi cldtaupd it is needed for the
111  cIM ctes ds clesphys.h  REAL*8 RCO2, RCH4, RN2O, RCFC11, RCFC12      ! diagnostics of the aerosol indirect radiative forcing
112        REAL*8 PSCT  
113  c      real, intent(out):: topswai(klon), solswai(klon)
114        REAL*8 PALBD(kdlon,2), PALBP(kdlon,2)      ! aerosol indirect forcing at TOA and surface
115        REAL*8 PEMIS(kdlon), PDT0(kdlon), PVIEW(kdlon)      ! ray. solaire net absorbe
116        REAL*8 PPSOL(kdlon), PDP(kdlon,klev)  
117        REAL*8 PTL(kdlon,kflev+1), PPMB(kdlon,kflev+1)      ! Local:
118        REAL*8 PTAVE(kdlon,kflev)  
119        REAL*8 PWV(kdlon,kflev), PQS(kdlon,kflev), POZON(kdlon,kflev)      double precision tauae(kdlon, klev, 2) ! aer opt properties
120        REAL*8 PAER(kdlon,kflev,5)      double precision pizae(kdlon, klev, 2)
121        REAL*8 PCLDLD(kdlon,kflev)      double precision cgae(kdlon, klev, 2)
122        REAL*8 PCLDLU(kdlon,kflev)  
123        REAL*8 PCLDSW(kdlon,kflev)      DOUBLE PRECISION ZFSUP(KDLON, KLEV+1)
124        REAL*8 PTAU(kdlon,2,kflev)      DOUBLE PRECISION ZFSDN(KDLON, KLEV+1)
125        REAL*8 POMEGA(kdlon,2,kflev)      DOUBLE PRECISION ZFSUP0(KDLON, KLEV+1)
126        REAL*8 PCG(kdlon,2,kflev)      DOUBLE PRECISION ZFSDN0(KDLON, KLEV+1)
127  c  
128        REAL*8 zfract(kdlon), zrmu0(kdlon), zdist      DOUBLE PRECISION ZFLUP(KDLON, KLEV+1)
129  c      DOUBLE PRECISION ZFLDN(KDLON, KLEV+1)
130        REAL*8 zheat(kdlon,kflev), zcool(kdlon,kflev)      DOUBLE PRECISION ZFLUP0(KDLON, KLEV+1)
131        REAL*8 zheat0(kdlon,kflev), zcool0(kdlon,kflev)      DOUBLE PRECISION ZFLDN0(KDLON, KLEV+1)
132        REAL*8 ztopsw(kdlon), ztoplw(kdlon)  
133        REAL*8 zsolsw(kdlon), zsollw(kdlon), zalbpla(kdlon)      DOUBLE PRECISION zx_alpha1, zx_alpha2
134  cIM      INTEGER k, kk, i, iof, nb_gr
135        REAL*8 zsollwdown(kdlon)      DOUBLE PRECISION PSCT
136  c  
137        REAL*8 ztopsw0(kdlon), ztoplw0(kdlon)      DOUBLE PRECISION PALBD(kdlon, 2), PALBP(kdlon, 2)
138        REAL*8 zsolsw0(kdlon), zsollw0(kdlon)      DOUBLE PRECISION PEMIS(kdlon), PDT0(kdlon), PVIEW(kdlon)
139        REAL*8 zznormcp      DOUBLE PRECISION PPSOL(kdlon), PDP(kdlon, klev)
140  cIM output 3D : SWup, SWdn, LWup, LWdn      DOUBLE PRECISION PTL(kdlon, klev+1), PPMB(kdlon, klev+1)
141        REAL swdn(klon,kflev+1),swdn0(klon,kflev+1)      DOUBLE PRECISION PTAVE(kdlon, klev)
142        REAL swup(klon,kflev+1),swup0(klon,kflev+1)      DOUBLE PRECISION PWV(kdlon, klev), PQS(kdlon, klev)
143        REAL lwdn(klon,kflev+1),lwdn0(klon,kflev+1)      DOUBLE PRECISION POZON(kdlon, klev) ! mass fraction of ozone
144        REAL lwup(klon,kflev+1),lwup0(klon,kflev+1)      DOUBLE PRECISION PAER(kdlon, klev, 5) ! AEROSOLS' OPTICAL THICKNESS
145  c-OB      DOUBLE PRECISION PCLDLD(kdlon, klev)
146  cjq the following quantities are needed for the aerosol radiative forcings      DOUBLE PRECISION PCLDLU(kdlon, klev)
147        DOUBLE PRECISION PCLDSW(kdlon, klev)
148        real topswad(klon), solswad(klon) ! output: aerosol direct forcing at TOA and surface      DOUBLE PRECISION PTAU(kdlon, 2, klev)
149        real topswai(klon), solswai(klon) ! output: aerosol indirect forcing atTOA and surface      DOUBLE PRECISION POMEGA(kdlon, 2, klev)
150        real tau_ae(klon,klev,2), piz_ae(klon,klev,2), cg_ae(klon,klev,2) ! aerosol optical properties (see aeropt.F)      DOUBLE PRECISION PCG(kdlon, 2, klev)
151        real cldtaupi(klon,klev)  ! cloud optical thickness for pre-industrial aerosol concentrations  
152                                  ! (i.e., with a smaller droplet concentrationand thus larger droplet radii)      DOUBLE PRECISION zfract(kdlon), zrmu0(kdlon)
153        logical ok_ade, ok_aie    ! switches whether to use aerosol direct (indirect) effects or not  
154        real*8 tauae(kdlon,kflev,2) ! aer opt properties      DOUBLE PRECISION zheat(kdlon, klev), zcool(kdlon, klev)
155        real*8 pizae(kdlon,kflev,2)      DOUBLE PRECISION zheat0(kdlon, klev), zcool0(kdlon, klev)
156        real*8 cgae(kdlon,kflev,2)      DOUBLE PRECISION ztopsw(kdlon), ztoplw(kdlon)
157        REAL*8 PTAUA(kdlon,2,kflev) ! present-day value of cloud opt thickness (PTAU is pre-industrial value), local use      DOUBLE PRECISION zsolsw(kdlon), zsollw(kdlon), zalbpla(kdlon)
158        REAL*8 POMEGAA(kdlon,2,kflev) ! dito for single scatt albedo      DOUBLE PRECISION zsollwdown(kdlon)
159        REAL*8 ztopswad(kdlon), zsolswad(kdlon) ! Aerosol direct forcing at TOAand surface  
160        REAL*8 ztopswai(kdlon), zsolswai(kdlon) ! dito, indirect      DOUBLE PRECISION ztopsw0(kdlon), ztoplw0(kdlon)
161  cjq-end      DOUBLE PRECISION zsolsw0(kdlon), zsollw0(kdlon)
162  !rv      DOUBLE PRECISION zznormcp
163        tauae(:,:,:)=0.  
164        pizae(:,:,:)=0.      !jq the following quantities are needed for the aerosol radiative forcings
165        cgae(:,:,:)=0.  
166  !rv      DOUBLE PRECISION PTAUA(kdlon, 2, klev)
167              ! present-day value of cloud opt thickness (PTAU is pre-industrial
168  c      ! value), local use
169  c-------------------------------------------  
170        nb_gr = klon / kdlon      DOUBLE PRECISION POMEGAA(kdlon, 2, klev) ! dito for single scatt albedo
171        IF (nb_gr*kdlon .NE. klon) THEN  
172           PRINT*, "kdlon mauvais:", klon, kdlon, nb_gr      DOUBLE PRECISION ztopswad(kdlon), zsolswad(kdlon)
173           stop 1      ! Aerosol direct forcing at TOAand surface
174        ENDIF  
175        IF (kflev .NE. klev) THEN      DOUBLE PRECISION ztopswai(kdlon), zsolswai(kdlon) ! dito, indirect
176            PRINT*, "kflev differe de klev, kflev, klev"      real, parameter:: dobson_u = 2.1415e-05 ! Dobson unit, in kg m-2
177            stop 1  
178        ENDIF      !----------------------------------------------------------------------
179  c-------------------------------------------  
180        DO k = 1, klev      tauae = 0.
181        DO i = 1, klon      pizae = 0.
182           heat(i,k)=0.      cgae = 0.
183           cool(i,k)=0.  
184           heat0(i,k)=0.      nb_gr = klon / kdlon
185           cool0(i,k)=0.      IF (nb_gr * kdlon /= klon) THEN
186        ENDDO         PRINT *, "kdlon mauvais :", klon, kdlon, nb_gr
187        ENDDO         stop 1
188  c      ENDIF
189        zdist = dist      
190  c      heat = 0.
191  cIM anciennes valeurs      cool = 0.
192  c     RCO2 = co2_ppm * 1.0e-06  * 44.011/28.97      heat0 = 0.
193  c      cool0 = 0.
194  cIM : on met RCO2, RCH4, RN2O, RCFC11 et RCFC12 dans clesphys.h /lecture ds conf_phys.F90      PSCT = solaire / dist**2
195  c     RCH4 = 1.65E-06* 16.043/28.97  
196  c     RN2O = 306.E-09* 44.013/28.97      loop_iof: DO iof = 0, klon - kdlon, kdlon
197  c     RCFC11 = 280.E-12* 137.3686/28.97         DO i = 1, kdlon
198  c     RCFC12 = 484.E-12* 120.9140/28.97            zfract(i) = fract(iof+i)
199  cIM anciennes valeurs            zrmu0(i) = mu0(iof+i)
200  c     RCH4 = 1.72E-06* 16.043/28.97            PALBD(i, 1) = albedo(iof+i)
201  c     RN2O = 310.E-09* 44.013/28.97            PALBD(i, 2) = albedo(iof+i)
202  c            PALBP(i, 1) = albedo(iof+i)
203  c     PRINT*,'IMradlwsw : solaire, co2= ', solaire, co2_ppm            PALBP(i, 2) = albedo(iof+i)
204        PSCT = solaire/zdist/zdist            ! cf. JLD pour etre en accord avec ORCHIDEE il faut mettre
205  c            ! PEMIS(i) = 0.96
206        DO 99999 j = 1, nb_gr            PEMIS(i) = 1.0
207        iof = kdlon*(j-1)            PVIEW(i) = 1.66
208  c            PPSOL(i) = paprs(iof+i, 1)
209        DO i = 1, kdlon            zx_alpha1 = (paprs(iof+i, 1)-play(iof+i, 2))  &
210           zfract(i) = fract(iof+i)                 / (play(iof+i, 1)-play(iof+i, 2))
211           zrmu0(i) = rmu0(iof+i)            zx_alpha2 = 1.0 - zx_alpha1
212           PALBD(i,1) = albedo(iof+i)            PTL(i, 1) = t(iof+i, 1) * zx_alpha1 + t(iof+i, 2) * zx_alpha2
213  !         PALBD(i,2) = albedo(iof+i)            PTL(i, klev+1) = t(iof+i, klev)
214           PALBD(i,2) = alblw(iof+i)            PDT0(i) = tsol(iof+i) - PTL(i, 1)
215           PALBP(i,1) = albedo(iof+i)         ENDDO
216  !         PALBP(i,2) = albedo(iof+i)         DO k = 2, klev
217           PALBP(i,2) = alblw(iof+i)            DO i = 1, kdlon
218  cIM cf. JLD pour etre en accord avec ORCHIDEE il faut mettre PEMIS(i) = 0.96               PTL(i, k) = (t(iof+i, k)+t(iof+i, k-1))*0.5
219           PEMIS(i) = 1.0            ENDDO
220           PVIEW(i) = 1.66         ENDDO
221           PPSOL(i) = paprs(iof+i,1)         DO k = 1, klev
222           zx_alpha1 = (paprs(iof+i,1)-pplay(iof+i,2))            DO i = 1, kdlon
223       .             / (pplay(iof+i,1)-pplay(iof+i,2))               PDP(i, k) = paprs(iof+i, k)-paprs(iof+i, k+1)
224           zx_alpha2 = 1.0 - zx_alpha1               PTAVE(i, k) = t(iof+i, k)
225           PTL(i,1) = t(iof+i,1) * zx_alpha1 + t(iof+i,2) * zx_alpha2               PWV(i, k) = MAX (q(iof+i, k), 1.0e-12)
226           PTL(i,klev+1) = t(iof+i,klev)               PQS(i, k) = PWV(i, k)
227           PDT0(i) = tsol(iof+i) - PTL(i,1)               POZON(i, k) = wo(iof+i, k) * RG * dobson_u * 1e3 &
228        ENDDO                    / (paprs(iof+i, k) - paprs(iof+i, k+1))
229        DO k = 2, kflev               PCLDLD(i, k) = cldfra(iof+i, k)*cldemi(iof+i, k)
230        DO i = 1, kdlon               PCLDLU(i, k) = cldfra(iof+i, k)*cldemi(iof+i, k)
231           PTL(i,k) = (t(iof+i,k)+t(iof+i,k-1))*0.5               PCLDSW(i, k) = cldfra(iof+i, k)
232        ENDDO               PTAU(i, 1, k) = MAX(cldtaupi(iof+i, k), 1.0e-05)
233        ENDDO               ! (1e-12 serait instable)
234        DO k = 1, kflev               PTAU(i, 2, k) = MAX(cldtaupi(iof+i, k), 1.0e-05)
235        DO i = 1, kdlon               ! (pour 32-bit machines)
236           PDP(i,k) = paprs(iof+i,k)-paprs(iof+i,k+1)               POMEGA(i, 1, k) = 0.9999 - 5.0e-04 * EXP(-0.5 * PTAU(i, 1, k))
237           PTAVE(i,k) = t(iof+i,k)               POMEGA(i, 2, k) = 0.9988 - 2.5e-03 * EXP(-0.05 * PTAU(i, 2, k))
238           PWV(i,k) = MAX (q(iof+i,k), 1.0e-12)               PCG(i, 1, k) = 0.865
239           PQS(i,k) = PWV(i,k)               PCG(i, 2, k) = 0.910
240  c wo:    cm.atm (epaisseur en cm dans la situation standard)  
241  c POZON: kg/kg               ! Introduced for aerosol indirect forcings.  The
242           IF (bug_ozone) then               ! following values use the cloud optical thickness
243             POZON(i,k) = MAX(wo(iof+i,k),1.0e-12)*RG/46.6968               ! calculated from present-day aerosol concentrations
244       .               /(paprs(iof+i,k)-paprs(iof+i,k+1))               ! whereas the quantities without the "A" at the end are
245       .               *(paprs(iof+i,1)/101325.0)               ! for pre-industial (natural-only) aerosol concentrations
246           ELSE               PTAUA(i, 1, k) = MAX(cldtaupd(iof+i, k), 1.0e-05)
247  c le calcul qui suit est maintenant fait dans ozonecm (MPL)               ! (1e-12 serait instable)
248             POZON(i,k) = wo(i,k)               PTAUA(i, 2, k) = MAX(cldtaupd(iof+i, k), 1.0e-05)
249           ENDIF               ! (pour 32-bit machines)
250           PCLDLD(i,k) = cldfra(iof+i,k)*cldemi(iof+i,k)               POMEGAA(i, 1, k) = 0.9999 - 5.0e-04 * EXP(-0.5 * PTAUA(i, 1, k))
251           PCLDLU(i,k) = cldfra(iof+i,k)*cldemi(iof+i,k)               POMEGAA(i, 2, k) = 0.9988 - 2.5e-03 * EXP(-0.05 * PTAUA(i, 2, k))
252           PCLDSW(i,k) = cldfra(iof+i,k)               !jq-end
253           PTAU(i,1,k) = MAX(cldtaupi(iof+i,k), 1.0e-05)! 1e-12 serait instable            ENDDO
254           PTAU(i,2,k) = MAX(cldtaupi(iof+i,k), 1.0e-05)! pour 32-bit machines         ENDDO
255           POMEGA(i,1,k) = 0.9999 - 5.0e-04 * EXP(-0.5 * PTAU(i,1,k))  
256           POMEGA(i,2,k) = 0.9988 - 2.5e-03 * EXP(-0.05 * PTAU(i,2,k))         DO k = 1, klev+1
257           PCG(i,1,k) = 0.865            DO i = 1, kdlon
258           PCG(i,2,k) = 0.910               PPMB(i, k) = paprs(iof+i, k)/100.0
259  c-OB            ENDDO
260  cjq Introduced for aerosol indirect forcings.         ENDDO
261  cjq The following values use the cloud optical thickness calculated from  
262  cjq present-day aerosol concentrations whereas the quantities without the         DO kk = 1, 5
263  cjq "A" at the end are for pre-industial (natural-only) aerosol concentrations            DO k = 1, klev
264  cjq               DO i = 1, kdlon
265           PTAUA(i,1,k) = MAX(cldtaupd(iof+i,k), 1.0e-05)! 1e-12 serait instable                  PAER(i, k, kk) = 1.0E-15
266           PTAUA(i,2,k) = MAX(cldtaupd(iof+i,k), 1.0e-05)! pour 32-bit machines               ENDDO
267           POMEGAA(i,1,k) = 0.9999 - 5.0e-04 * EXP(-0.5 * PTAUA(i,1,k))            ENDDO
268           POMEGAA(i,2,k) = 0.9988 - 2.5e-03 * EXP(-0.05 * PTAUA(i,2,k))         ENDDO
269  cjq-end  
270        ENDDO         DO k = 1, klev
271        ENDDO            DO i = 1, kdlon
272  c               tauae(i, k, 1) = tau_ae(iof+i, k, 1)
273        DO k = 1, kflev+1               pizae(i, k, 1) = piz_ae(iof+i, k, 1)
274        DO i = 1, kdlon               cgae(i, k, 1) =cg_ae(iof+i, k, 1)
275           PPMB(i,k) = paprs(iof+i,k)/100.0               tauae(i, k, 2) = tau_ae(iof+i, k, 2)
276        ENDDO               pizae(i, k, 2) = piz_ae(iof+i, k, 2)
277        ENDDO               cgae(i, k, 2) =cg_ae(iof+i, k, 2)
278  c            ENDDO
279        DO kk = 1, 5         ENDDO
280        DO k = 1, kflev  
281        DO i = 1, kdlon         CALL LW(PPMB, PDP, PDT0, PEMIS, PTL, PTAVE, PWV, POZON, PAER, PCLDLD, &
282           PAER(i,k,kk) = 1.0E-15              PCLDLU, PVIEW, zcool, zcool0, ztoplw, zsollw, ztoplw0, zsollw0, &
283        ENDDO              zsollwdown, ZFLUP, ZFLDN, ZFLUP0, ZFLDN0)
284        ENDDO         CALL SW(PSCT, zrmu0, zfract, PPMB, PDP, PPSOL, PALBD, PALBP, PTAVE, &
285        ENDDO              PWV, PQS, POZON, PCLDSW, PTAU, POMEGA, PCG, zheat, zheat0, &
286  c-OB              zalbpla, ztopsw, zsolsw, ztopsw0, zsolsw0, ZFSUP, ZFSDN, ZFSUP0, &
287        DO k = 1, kflev              ZFSDN0, tauae, pizae, cgae, PTAUA, POMEGAA, ztopswad, zsolswad, &
288        DO i = 1, kdlon              ztopswai, zsolswai, ok_ade, ok_aie)
289          tauae(i,k,1)=tau_ae(iof+i,k,1)  
290          pizae(i,k,1)=piz_ae(iof+i,k,1)         DO i = 1, kdlon
291          cgae(i,k,1) =cg_ae(iof+i,k,1)            radsol(iof+i) = zsolsw(i) + zsollw(i)
292          tauae(i,k,2)=tau_ae(iof+i,k,2)            topsw(iof+i) = ztopsw(i)
293          pizae(i,k,2)=piz_ae(iof+i,k,2)            toplw(iof+i) = ztoplw(i)
294          cgae(i,k,2) =cg_ae(iof+i,k,2)            solsw(iof+i) = zsolsw(i)
295        ENDDO            sollw(iof+i) = zsollw(i)
296        ENDDO            sollwdown(iof+i) = zsollwdown(i)
297  c  
298  c======================================================================            DO k = 1, klev+1
299  cIM ctes ds clesphys.h   CALL LW(RCO2,RCH4,RN2O,RCFC11,RCFC12,               lwdn0 ( iof+i, k)   = ZFLDN0 ( i, k)
300        CALL LW(               lwdn  ( iof+i, k)   = ZFLDN  ( i, k)
301       .        PPMB, PDP,               lwup0 ( iof+i, k)   = ZFLUP0 ( i, k)
302       .        PPSOL,PDT0,PEMIS,               lwup  ( iof+i, k)   = ZFLUP  ( i, k)
303       .        PTL, PTAVE, PWV, POZON, PAER,            ENDDO
304       .        PCLDLD,PCLDLU,  
305       .        PVIEW,            topsw0(iof+i) = ztopsw0(i)
306       .        zcool, zcool0,            toplw0(iof+i) = ztoplw0(i)
307       .        ztoplw,zsollw,ztoplw0,zsollw0,            solsw0(iof+i) = zsolsw0(i)
308       .        zsollwdown,            sollw0(iof+i) = zsollw0(i)
309       .        ZFLUP, ZFLDN, ZFLUP0,ZFLDN0)            albpla(iof+i) = zalbpla(i)
310  cIM ctes ds clesphys.h   CALL SW(PSCT, RCO2, zrmu0, zfract,  
311        CALL SW(PSCT, zrmu0, zfract,            DO k = 1, klev+1
312       S        PPMB, PDP,               swdn0 ( iof+i, k)   = ZFSDN0 ( i, k)
313       S        PPSOL, PALBD, PALBP,               swdn  ( iof+i, k)   = ZFSDN  ( i, k)
314       S        PTAVE, PWV, PQS, POZON, PAER,               swup0 ( iof+i, k)   = ZFSUP0 ( i, k)
315       S        PCLDSW, PTAU, POMEGA, PCG,               swup  ( iof+i, k)   = ZFSUP  ( i, k)
316       S        zheat, zheat0,            ENDDO
317       S        zalbpla,ztopsw,zsolsw,ztopsw0,zsolsw0,         ENDDO
318       S        ZFSUP,ZFSDN,ZFSUP0,ZFSDN0,         ! transform the aerosol forcings, if they have to be calculated
319       S        tauae, pizae, cgae, ! aerosol optical properties         IF (ok_ade) THEN
320       s        PTAUA, POMEGAA,            DO i = 1, kdlon
321       s        ztopswad,zsolswad,ztopswai,zsolswai, ! diagnosed aerosol forcing               topswad(iof+i) = ztopswad(i)
322       J        ok_ade, ok_aie) ! apply aerosol effects or not?               solswad(iof+i) = zsolswad(i)
323              ENDDO
324  c======================================================================         ELSE
325        DO i = 1, kdlon            DO i = 1, kdlon
326           radsol(iof+i) = zsolsw(i) + zsollw(i)               topswad(iof+i) = 0.0
327           topsw(iof+i) = ztopsw(i)               solswad(iof+i) = 0.0
328           toplw(iof+i) = ztoplw(i)            ENDDO
329           solsw(iof+i) = zsolsw(i)         ENDIF
330           sollw(iof+i) = zsollw(i)         IF (ok_aie) THEN
331           sollwdown(iof+i) = zsollwdown(i)            DO i = 1, kdlon
332  cIM               topswai(iof+i) = ztopswai(i)
333           DO k = 1, kflev+1               solswai(iof+i) = zsolswai(i)
334           lwdn0 ( iof+i,k)   = ZFLDN0 ( i,k)            ENDDO
335           lwdn  ( iof+i,k)   = ZFLDN  ( i,k)         ELSE
336           lwup0 ( iof+i,k)   = ZFLUP0 ( i,k)            DO i = 1, kdlon
337           lwup  ( iof+i,k)   = ZFLUP  ( i,k)               topswai(iof+i) = 0.0
338           ENDDO               solswai(iof+i) = 0.0
339  c            ENDDO
340           topsw0(iof+i) = ztopsw0(i)         ENDIF
341           toplw0(iof+i) = ztoplw0(i)  
342           solsw0(iof+i) = zsolsw0(i)         DO k = 1, klev
343           sollw0(iof+i) = zsollw0(i)            DO i = 1, kdlon
344           albpla(iof+i) = zalbpla(i)               ! scale factor to take into account the difference
345  cIM               ! between dry air and water vapour specific heat capacity
346           DO k = 1, kflev+1               zznormcp = 1. + RVTMP2 * PWV(i, k)
347           swdn0 ( iof+i,k)   = ZFSDN0 ( i,k)               heat(iof+i, k) = zheat(i, k) / zznormcp
348           swdn  ( iof+i,k)   = ZFSDN  ( i,k)               cool(iof+i, k) = zcool(i, k)/zznormcp
349           swup0 ( iof+i,k)   = ZFSUP0 ( i,k)               heat0(iof+i, k) = zheat0(i, k)/zznormcp
350           swup  ( iof+i,k)   = ZFSUP  ( i,k)               cool0(iof+i, k) = zcool0(i, k)/zznormcp
351           ENDDO !k=1, kflev+1            ENDDO
352        ENDDO         ENDDO
353  cjq-transform the aerosol forcings, if they have      end DO loop_iof
354  cjq to be calculated  
355        IF (ok_ade) THEN    END SUBROUTINE radlwsw
356        DO i = 1, kdlon  
357           topswad(iof+i) = ztopswad(i)  end module radlwsw_m
          solswad(iof+i) = zsolswad(i)  
       ENDDO  
       ELSE  
       DO i = 1, kdlon  
          topswad(iof+i) = 0.0  
          solswad(iof+i) = 0.0  
       ENDDO  
       ENDIF  
       IF (ok_aie) THEN  
       DO i = 1, kdlon  
          topswai(iof+i) = ztopswai(i)  
          solswai(iof+i) = zsolswai(i)  
       ENDDO  
       ELSE  
       DO i = 1, kdlon  
          topswai(iof+i) = 0.0  
          solswai(iof+i) = 0.0  
       ENDDO  
       ENDIF  
 cjq-end  
       DO k = 1, kflev  
 c      DO i = 1, kdlon  
 c         heat(iof+i,k) = zheat(i,k)  
 c         cool(iof+i,k) = zcool(i,k)  
 c         heat0(iof+i,k) = zheat0(i,k)  
 c         cool0(iof+i,k) = zcool0(i,k)  
 c      ENDDO  
       DO i = 1, kdlon  
 C        scale factor to take into account the difference between  
 C        dry air and watter vapour scpecific heat capacity  
          zznormcp=1.0+RVTMP2*PWV(i,k)  
          heat(iof+i,k) = zheat(i,k)/zznormcp  
          cool(iof+i,k) = zcool(i,k)/zznormcp  
          heat0(iof+i,k) = zheat0(i,k)/zznormcp  
          cool0(iof+i,k) = zcool0(i,k)/zznormcp  
       ENDDO  
       ENDDO  
 c  
 99999 CONTINUE  
       RETURN  
       END  

Legend:
Removed from v.52  
changed lines
  Added in v.212

  ViewVC Help
Powered by ViewVC 1.1.21