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

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

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

trunk/libf/phylmd/Radlwsw/radlwsw.f revision 24 by guez, Wed Mar 3 13:23:49 2010 UTC trunk/Sources/phylmd/Radlwsw/radlwsw.f revision 213 by guez, Mon Feb 27 15:44:55 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 YOMCST      ! ATTENTION: swai and swad have to be interpreted in the following manner:
21        use raddim, only: kflev, kdlon  
22        use yoethf      ! 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) ! chauffage solaire ciel clair
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  
72  c                        aerosol direct forcing is F_{AD} = topswai-topswad      real, intent(out):: cool0(klon, klev)
73  c      ! refroidissement infrarouge ciel clair
74          
75  c======================================================================      real, intent(out):: radsol(klon)
76  c      ! bilan radiatif net au sol (W/m**2) (+ vers le bas)
77        real rmu0(klon), fract(klon), dist  
78  cIM   real co2_ppm      real, intent(out):: albpla(klon) ! albedo planetaire (entre 0 et 1)
79  cIM   real solaire      real, intent(out):: topsw(klon) ! flux solaire net au sommet de l'atm.
80  c  
81        real, intent(in):: paprs(klon,klev+1)      real, intent(out):: toplw(klon)
82        real, intent(in):: pplay(klon,klev)      ! rayonnement infrarouge montant au sommet de l'atmosphère
83        real albedo(klon), alblw(klon), tsol(klon)  
84        real t(klon,klev), q(klon,klev)      real, intent(out):: solsw(klon) ! flux solaire net à la surface
85        real, intent(in):: wo(klon,klev)  
86        real cldfra(klon,klev), cldemi(klon,klev), cldtaupd(klon,klev)      real, intent(out):: sollw(klon)
87        real heat(klon,klev), cool(klon,klev)      ! rayonnement infrarouge montant à la surface
88        real heat0(klon,klev), cool0(klon,klev)  
89        real radsol(klon), topsw(klon), toplw(klon)      real, intent(out):: sollwdown(klon)
90        real solsw(klon), sollw(klon), albpla(klon)      real, intent(out):: topsw0(klon)
91        real topsw0(klon), toplw0(klon), solsw0(klon), sollw0(klon)      real, intent(out):: toplw0(klon)
92        real sollwdown(klon)      real, intent(out):: solsw0(klon), sollw0(klon)
93  cIM output 3D      REAL, intent(out):: lwdn0(klon, klev+1), lwdn(klon, klev+1)
94        REAL*8 ZFSUP(KDLON,KFLEV+1)      REAL, intent(out):: lwup0(klon, klev+1), lwup(klon, klev+1)
95        REAL*8 ZFSDN(KDLON,KFLEV+1)      REAL, intent(out):: swdn0(klon, klev+1), swdn(klon, klev+1)
96        REAL*8 ZFSUP0(KDLON,KFLEV+1)      REAL, intent(out):: swup0(klon, klev+1), swup(klon, klev+1)
97        REAL*8 ZFSDN0(KDLON,KFLEV+1)  
98  c      logical, intent(in):: ok_ade ! apply the Aerosol Direct Effect
99        REAL*8 ZFLUP(KDLON,KFLEV+1)      logical, intent(in):: ok_aie ! apply the Aerosol Indirect Effect
100        REAL*8 ZFLDN(KDLON,KFLEV+1)  
101        REAL*8 ZFLUP0(KDLON,KFLEV+1)      ! aerosol optical properties (calculated in aeropt.F):
102        REAL*8 ZFLDN0(KDLON,KFLEV+1)      real, intent(in):: tau_ae(klon, klev, 2), piz_ae(klon, klev, 2)
103  c      real, intent(in):: cg_ae(klon, klev, 2)
104        REAL*8 zx_alpha1, zx_alpha2  
105  c      real, intent(out):: topswad(klon), solswad(klon)
106  c      ! aerosol direct forcing at TOA and surface
107        INTEGER k, kk, i, j, iof, nb_gr      ! ray. solaire net absorbe
108        EXTERNAL lw, sw      
109  c      real, intent(in):: cldtaupi(klon, klev)
110  cIM ctes ds clesphys.h  REAL*8 RCO2, RCH4, RN2O, RCFC11, RCFC12      ! cloud visible optical thickness for pre-industrial aerosol concentrations
111        REAL*8 PSCT      ! i.e. with smaller droplet concentration, thus larger droplets,
112  c      ! thus generally cdltaupi cldtaupd it is needed for the
113        REAL*8 PALBD(kdlon,2), PALBP(kdlon,2)      ! diagnostics of the aerosol indirect radiative forcing
114        REAL*8 PEMIS(kdlon), PDT0(kdlon), PVIEW(kdlon)  
115        REAL*8 PPSOL(kdlon), PDP(kdlon,klev)      real, intent(out):: topswai(klon), solswai(klon)
116        REAL*8 PTL(kdlon,kflev+1), PPMB(kdlon,kflev+1)      ! aerosol indirect forcing at TOA and surface
117        REAL*8 PTAVE(kdlon,kflev)      ! ray. solaire net absorbe
118        REAL*8 PWV(kdlon,kflev), PQS(kdlon,kflev), POZON(kdlon,kflev)  
119        REAL*8 PAER(kdlon,kflev,5)      ! Local:
120        REAL*8 PCLDLD(kdlon,kflev)  
121        REAL*8 PCLDLU(kdlon,kflev)      double precision tauae(kdlon, klev, 2) ! aer opt properties
122        REAL*8 PCLDSW(kdlon,kflev)      double precision pizae(kdlon, klev, 2)
123        REAL*8 PTAU(kdlon,2,kflev)      double precision cgae(kdlon, klev, 2)
124        REAL*8 POMEGA(kdlon,2,kflev)  
125        REAL*8 PCG(kdlon,2,kflev)      DOUBLE PRECISION ZFSUP(KDLON, KLEV+1)
126  c      DOUBLE PRECISION ZFSDN(KDLON, KLEV+1)
127        REAL*8 zfract(kdlon), zrmu0(kdlon), zdist      DOUBLE PRECISION ZFSUP0(KDLON, KLEV+1)
128  c      DOUBLE PRECISION ZFSDN0(KDLON, KLEV+1)
129        REAL*8 zheat(kdlon,kflev), zcool(kdlon,kflev)  
130        REAL*8 zheat0(kdlon,kflev), zcool0(kdlon,kflev)      DOUBLE PRECISION ZFLUP(KDLON, KLEV+1)
131        REAL*8 ztopsw(kdlon), ztoplw(kdlon)      DOUBLE PRECISION ZFLDN(KDLON, KLEV+1)
132        REAL*8 zsolsw(kdlon), zsollw(kdlon), zalbpla(kdlon)      DOUBLE PRECISION ZFLUP0(KDLON, KLEV+1)
133  cIM      DOUBLE PRECISION ZFLDN0(KDLON, KLEV+1)
134        REAL*8 zsollwdown(kdlon)  
135  c      DOUBLE PRECISION zx_alpha1, zx_alpha2
136        REAL*8 ztopsw0(kdlon), ztoplw0(kdlon)      INTEGER k, kk, i, iof, nb_gr
137        REAL*8 zsolsw0(kdlon), zsollw0(kdlon)      DOUBLE PRECISION PSCT
138        REAL*8 zznormcp  
139  cIM output 3D : SWup, SWdn, LWup, LWdn      DOUBLE PRECISION PALBD(kdlon, 2), PALBP(kdlon, 2)
140        REAL swdn(klon,kflev+1),swdn0(klon,kflev+1)      DOUBLE PRECISION PEMIS(kdlon), PDT0(kdlon), PVIEW(kdlon)
141        REAL swup(klon,kflev+1),swup0(klon,kflev+1)      DOUBLE PRECISION PPSOL(kdlon), PDP(kdlon, klev)
142        REAL lwdn(klon,kflev+1),lwdn0(klon,kflev+1)      DOUBLE PRECISION PTL(kdlon, klev+1), PPMB(kdlon, klev+1)
143        REAL lwup(klon,kflev+1),lwup0(klon,kflev+1)      DOUBLE PRECISION PTAVE(kdlon, klev)
144  c-OB      DOUBLE PRECISION PWV(kdlon, klev), PQS(kdlon, klev)
145  cjq the following quantities are needed for the aerosol radiative forcings      DOUBLE PRECISION POZON(kdlon, klev) ! mass fraction of ozone
146        DOUBLE PRECISION PAER(kdlon, klev, 5) ! AEROSOLS' OPTICAL THICKNESS
147        real topswad(klon), solswad(klon) ! output: aerosol direct forcing at TOA and surface      DOUBLE PRECISION PCLDLD(kdlon, klev)
148        real topswai(klon), solswai(klon) ! output: aerosol indirect forcing atTOA and surface      DOUBLE PRECISION PCLDLU(kdlon, klev)
149        real tau_ae(klon,klev,2), piz_ae(klon,klev,2), cg_ae(klon,klev,2) ! aerosol optical properties (see aeropt.F)      DOUBLE PRECISION PCLDSW(kdlon, klev)
150        real cldtaupi(klon,klev)  ! cloud optical thickness for pre-industrial aerosol concentrations      DOUBLE PRECISION PTAU(kdlon, 2, klev)
151                                  ! (i.e., with a smaller droplet concentrationand thus larger droplet radii)      DOUBLE PRECISION POMEGA(kdlon, 2, klev)
152        logical ok_ade, ok_aie    ! switches whether to use aerosol direct (indirect) effects or not      DOUBLE PRECISION PCG(kdlon, 2, klev)
153        real*8 tauae(kdlon,kflev,2) ! aer opt properties  
154        real*8 pizae(kdlon,kflev,2)      DOUBLE PRECISION zfract(kdlon), zrmu0(kdlon)
155        real*8 cgae(kdlon,kflev,2)  
156        REAL*8 PTAUA(kdlon,2,kflev) ! present-day value of cloud opt thickness (PTAU is pre-industrial value), local use      DOUBLE PRECISION zheat(kdlon, klev), zcool(kdlon, klev)
157        REAL*8 POMEGAA(kdlon,2,kflev) ! dito for single scatt albedo      DOUBLE PRECISION zheat0(kdlon, klev), zcool0(kdlon, klev)
158        REAL*8 ztopswad(kdlon), zsolswad(kdlon) ! Aerosol direct forcing at TOAand surface      DOUBLE PRECISION ztopsw(kdlon), ztoplw(kdlon)
159        REAL*8 ztopswai(kdlon), zsolswai(kdlon) ! dito, indirect      DOUBLE PRECISION zsolsw(kdlon), zsollw(kdlon), zalbpla(kdlon)
160  cjq-end      DOUBLE PRECISION zsollwdown(kdlon)
161  !rv  
162        tauae(:,:,:)=0.      DOUBLE PRECISION ztopsw0(kdlon), ztoplw0(kdlon)
163        pizae(:,:,:)=0.      DOUBLE PRECISION zsolsw0(kdlon), zsollw0(kdlon)
164        cgae(:,:,:)=0.      DOUBLE PRECISION zznormcp
165  !rv  
166              !jq the following quantities are needed for the aerosol radiative forcings
167  c  
168  c-------------------------------------------      DOUBLE PRECISION PTAUA(kdlon, 2, klev)
169        nb_gr = klon / kdlon      ! present-day value of cloud opt thickness (PTAU is pre-industrial
170        IF (nb_gr*kdlon .NE. klon) THEN      ! value), local use
171           PRINT*, "kdlon mauvais:", klon, kdlon, nb_gr  
172           stop 1      DOUBLE PRECISION POMEGAA(kdlon, 2, klev) ! dito for single scatt albedo
173        ENDIF  
174        IF (kflev .NE. klev) THEN      DOUBLE PRECISION ztopswad(kdlon), zsolswad(kdlon)
175            PRINT*, "kflev differe de klev, kflev, klev"      ! Aerosol direct forcing at TOAand surface
176            stop 1  
177        ENDIF      DOUBLE PRECISION ztopswai(kdlon), zsolswai(kdlon) ! dito, indirect
178  c-------------------------------------------      real, parameter:: dobson_u = 2.1415e-05 ! Dobson unit, in kg m-2
179        DO k = 1, klev  
180        DO i = 1, klon      !----------------------------------------------------------------------
181           heat(i,k)=0.  
182           cool(i,k)=0.      tauae = 0.
183           heat0(i,k)=0.      pizae = 0.
184           cool0(i,k)=0.      cgae = 0.
185        ENDDO  
186        ENDDO      nb_gr = klon / kdlon
187  c      IF (nb_gr * kdlon /= klon) THEN
188        zdist = dist         PRINT *, "kdlon mauvais :", klon, kdlon, nb_gr
189  c         stop 1
190  cIM anciennes valeurs      ENDIF
191  c     RCO2 = co2_ppm * 1.0e-06  * 44.011/28.97      
192  c      heat = 0.
193  cIM : on met RCO2, RCH4, RN2O, RCFC11 et RCFC12 dans clesphys.h /lecture ds conf_phys.F90      cool = 0.
194  c     RCH4 = 1.65E-06* 16.043/28.97      heat0 = 0.
195  c     RN2O = 306.E-09* 44.013/28.97      cool0 = 0.
196  c     RCFC11 = 280.E-12* 137.3686/28.97      PSCT = solaire / dist**2
197  c     RCFC12 = 484.E-12* 120.9140/28.97  
198  cIM anciennes valeurs      loop_iof: DO iof = 0, klon - kdlon, kdlon
199  c     RCH4 = 1.72E-06* 16.043/28.97         DO i = 1, kdlon
200  c     RN2O = 310.E-09* 44.013/28.97            zfract(i) = fract(iof+i)
201  c            zrmu0(i) = mu0(iof+i)
202  c     PRINT*,'IMradlwsw : solaire, co2= ', solaire, co2_ppm            PALBD(i, 1) = albedo(iof+i)
203        PSCT = solaire/zdist/zdist            PALBD(i, 2) = albedo(iof+i)
204  c            PALBP(i, 1) = albedo(iof+i)
205        DO 99999 j = 1, nb_gr            PALBP(i, 2) = albedo(iof+i)
206        iof = kdlon*(j-1)            ! cf. JLD pour etre en accord avec ORCHIDEE il faut mettre
207  c            ! PEMIS(i) = 0.96
208        DO i = 1, kdlon            PEMIS(i) = 1.0
209           zfract(i) = fract(iof+i)            PVIEW(i) = 1.66
210           zrmu0(i) = rmu0(iof+i)            PPSOL(i) = paprs(iof+i, 1)
211           PALBD(i,1) = albedo(iof+i)            zx_alpha1 = (paprs(iof+i, 1)-play(iof+i, 2))  &
212  !         PALBD(i,2) = albedo(iof+i)                 / (play(iof+i, 1)-play(iof+i, 2))
213           PALBD(i,2) = alblw(iof+i)            zx_alpha2 = 1.0 - zx_alpha1
214           PALBP(i,1) = albedo(iof+i)            PTL(i, 1) = t(iof+i, 1) * zx_alpha1 + t(iof+i, 2) * zx_alpha2
215  !         PALBP(i,2) = albedo(iof+i)            PTL(i, klev+1) = t(iof+i, klev)
216           PALBP(i,2) = alblw(iof+i)            PDT0(i) = tsol(iof+i) - PTL(i, 1)
217  cIM cf. JLD pour etre en accord avec ORCHIDEE il faut mettre PEMIS(i) = 0.96         ENDDO
218           PEMIS(i) = 1.0         DO k = 2, klev
219           PVIEW(i) = 1.66            DO i = 1, kdlon
220           PPSOL(i) = paprs(iof+i,1)               PTL(i, k) = (t(iof+i, k)+t(iof+i, k-1))*0.5
221           zx_alpha1 = (paprs(iof+i,1)-pplay(iof+i,2))            ENDDO
222       .             / (pplay(iof+i,1)-pplay(iof+i,2))         ENDDO
223           zx_alpha2 = 1.0 - zx_alpha1         DO k = 1, klev
224           PTL(i,1) = t(iof+i,1) * zx_alpha1 + t(iof+i,2) * zx_alpha2            DO i = 1, kdlon
225           PTL(i,klev+1) = t(iof+i,klev)               PDP(i, k) = paprs(iof+i, k)-paprs(iof+i, k+1)
226           PDT0(i) = tsol(iof+i) - PTL(i,1)               PTAVE(i, k) = t(iof+i, k)
227        ENDDO               PWV(i, k) = MAX (q(iof+i, k), 1.0e-12)
228        DO k = 2, kflev               PQS(i, k) = PWV(i, k)
229        DO i = 1, kdlon               POZON(i, k) = wo(iof+i, k) * RG * dobson_u * 1e3 &
230           PTL(i,k) = (t(iof+i,k)+t(iof+i,k-1))*0.5                    / (paprs(iof+i, k) - paprs(iof+i, k+1))
231        ENDDO               PCLDLD(i, k) = cldfra(iof+i, k)*cldemi(iof+i, k)
232        ENDDO               PCLDLU(i, k) = cldfra(iof+i, k)*cldemi(iof+i, k)
233        DO k = 1, kflev               PCLDSW(i, k) = cldfra(iof+i, k)
234        DO i = 1, kdlon               PTAU(i, 1, k) = MAX(cldtaupi(iof+i, k), 1.0e-05)
235           PDP(i,k) = paprs(iof+i,k)-paprs(iof+i,k+1)               ! (1e-12 serait instable)
236           PTAVE(i,k) = t(iof+i,k)               PTAU(i, 2, k) = MAX(cldtaupi(iof+i, k), 1.0e-05)
237           PWV(i,k) = MAX (q(iof+i,k), 1.0e-12)               ! (pour 32-bit machines)
238           PQS(i,k) = PWV(i,k)               POMEGA(i, 1, k) = 0.9999 - 5.0e-04 * EXP(-0.5 * PTAU(i, 1, k))
239  c wo:    cm.atm (epaisseur en cm dans la situation standard)               POMEGA(i, 2, k) = 0.9988 - 2.5e-03 * EXP(-0.05 * PTAU(i, 2, k))
240  c POZON: kg/kg               PCG(i, 1, k) = 0.865
241           IF (bug_ozone) then               PCG(i, 2, k) = 0.910
242             POZON(i,k) = MAX(wo(iof+i,k),1.0e-12)*RG/46.6968  
243       .               /(paprs(iof+i,k)-paprs(iof+i,k+1))               ! Introduced for aerosol indirect forcings.  The
244       .               *(paprs(iof+i,1)/101325.0)               ! following values use the cloud optical thickness
245           ELSE               ! calculated from present-day aerosol concentrations
246  c le calcul qui suit est maintenant fait dans ozonecm (MPL)               ! whereas the quantities without the "A" at the end are
247             POZON(i,k) = wo(i,k)               ! for pre-industial (natural-only) aerosol concentrations
248           ENDIF               PTAUA(i, 1, k) = MAX(cldtaupd(iof+i, k), 1.0e-05)
249           PCLDLD(i,k) = cldfra(iof+i,k)*cldemi(iof+i,k)               ! (1e-12 serait instable)
250           PCLDLU(i,k) = cldfra(iof+i,k)*cldemi(iof+i,k)               PTAUA(i, 2, k) = MAX(cldtaupd(iof+i, k), 1.0e-05)
251           PCLDSW(i,k) = cldfra(iof+i,k)               ! (pour 32-bit machines)
252           PTAU(i,1,k) = MAX(cldtaupi(iof+i,k), 1.0e-05)! 1e-12 serait instable               POMEGAA(i, 1, k) = 0.9999 - 5.0e-04 * EXP(-0.5 * PTAUA(i, 1, k))
253           PTAU(i,2,k) = MAX(cldtaupi(iof+i,k), 1.0e-05)! pour 32-bit machines               POMEGAA(i, 2, k) = 0.9988 - 2.5e-03 * EXP(-0.05 * PTAUA(i, 2, k))
254           POMEGA(i,1,k) = 0.9999 - 5.0e-04 * EXP(-0.5 * PTAU(i,1,k))               !jq-end
255           POMEGA(i,2,k) = 0.9988 - 2.5e-03 * EXP(-0.05 * PTAU(i,2,k))            ENDDO
256           PCG(i,1,k) = 0.865         ENDDO
257           PCG(i,2,k) = 0.910  
258  c-OB         DO k = 1, klev+1
259  cjq Introduced for aerosol indirect forcings.            DO i = 1, kdlon
260  cjq The following values use the cloud optical thickness calculated from               PPMB(i, k) = paprs(iof+i, k)/100.0
261  cjq present-day aerosol concentrations whereas the quantities without the            ENDDO
262  cjq "A" at the end are for pre-industial (natural-only) aerosol concentrations         ENDDO
263  cjq  
264           PTAUA(i,1,k) = MAX(cldtaupd(iof+i,k), 1.0e-05)! 1e-12 serait instable         DO kk = 1, 5
265           PTAUA(i,2,k) = MAX(cldtaupd(iof+i,k), 1.0e-05)! pour 32-bit machines            DO k = 1, klev
266           POMEGAA(i,1,k) = 0.9999 - 5.0e-04 * EXP(-0.5 * PTAUA(i,1,k))               DO i = 1, kdlon
267           POMEGAA(i,2,k) = 0.9988 - 2.5e-03 * EXP(-0.05 * PTAUA(i,2,k))                  PAER(i, k, kk) = 1.0E-15
268  cjq-end               ENDDO
269        ENDDO            ENDDO
270        ENDDO         ENDDO
271  c  
272        DO k = 1, kflev+1         DO k = 1, klev
273        DO i = 1, kdlon            DO i = 1, kdlon
274           PPMB(i,k) = paprs(iof+i,k)/100.0               tauae(i, k, 1) = tau_ae(iof+i, k, 1)
275        ENDDO               pizae(i, k, 1) = piz_ae(iof+i, k, 1)
276        ENDDO               cgae(i, k, 1) =cg_ae(iof+i, k, 1)
277  c               tauae(i, k, 2) = tau_ae(iof+i, k, 2)
278        DO kk = 1, 5               pizae(i, k, 2) = piz_ae(iof+i, k, 2)
279        DO k = 1, kflev               cgae(i, k, 2) =cg_ae(iof+i, k, 2)
280        DO i = 1, kdlon            ENDDO
281           PAER(i,k,kk) = 1.0E-15         ENDDO
282        ENDDO  
283        ENDDO         CALL LW(PPMB, PDP, PDT0, PEMIS, PTL, PTAVE, PWV, POZON, PAER, PCLDLD, &
284        ENDDO              PCLDLU, PVIEW, zcool, zcool0, ztoplw, zsollw, ztoplw0, zsollw0, &
285  c-OB              zsollwdown, ZFLUP, ZFLDN, ZFLUP0, ZFLDN0)
286        DO k = 1, kflev         CALL SW(PSCT, zrmu0, zfract, PPMB, PDP, PPSOL, PALBD, PALBP, PTAVE, &
287        DO i = 1, kdlon              PWV, PQS, POZON, PCLDSW, PTAU, POMEGA, PCG, zheat, zheat0, &
288          tauae(i,k,1)=tau_ae(iof+i,k,1)              zalbpla, ztopsw, zsolsw, ztopsw0, zsolsw0, ZFSUP, ZFSDN, ZFSUP0, &
289          pizae(i,k,1)=piz_ae(iof+i,k,1)              ZFSDN0, tauae, pizae, cgae, PTAUA, POMEGAA, ztopswad, zsolswad, &
290          cgae(i,k,1) =cg_ae(iof+i,k,1)              ztopswai, zsolswai, ok_ade, ok_aie)
291          tauae(i,k,2)=tau_ae(iof+i,k,2)  
292          pizae(i,k,2)=piz_ae(iof+i,k,2)         DO i = 1, kdlon
293          cgae(i,k,2) =cg_ae(iof+i,k,2)            radsol(iof+i) = zsolsw(i) + zsollw(i)
294        ENDDO            topsw(iof+i) = ztopsw(i)
295        ENDDO            toplw(iof+i) = ztoplw(i)
296  c            solsw(iof+i) = zsolsw(i)
297  c======================================================================            sollw(iof+i) = zsollw(i)
298  cIM ctes ds clesphys.h   CALL LW(RCO2,RCH4,RN2O,RCFC11,RCFC12,            sollwdown(iof+i) = zsollwdown(i)
299        CALL LW(  
300       .        PPMB, PDP,            DO k = 1, klev+1
301       .        PPSOL,PDT0,PEMIS,               lwdn0 ( iof+i, k)   = ZFLDN0 ( i, k)
302       .        PTL, PTAVE, PWV, POZON, PAER,               lwdn  ( iof+i, k)   = ZFLDN  ( i, k)
303       .        PCLDLD,PCLDLU,               lwup0 ( iof+i, k)   = ZFLUP0 ( i, k)
304       .        PVIEW,               lwup  ( iof+i, k)   = ZFLUP  ( i, k)
305       .        zcool, zcool0,            ENDDO
306       .        ztoplw,zsollw,ztoplw0,zsollw0,  
307       .        zsollwdown,            topsw0(iof+i) = ztopsw0(i)
308       .        ZFLUP, ZFLDN, ZFLUP0,ZFLDN0)            toplw0(iof+i) = ztoplw0(i)
309  cIM ctes ds clesphys.h   CALL SW(PSCT, RCO2, zrmu0, zfract,            solsw0(iof+i) = zsolsw0(i)
310        CALL SW(PSCT, zrmu0, zfract,            sollw0(iof+i) = zsollw0(i)
311       S        PPMB, PDP,            albpla(iof+i) = zalbpla(i)
312       S        PPSOL, PALBD, PALBP,  
313       S        PTAVE, PWV, PQS, POZON, PAER,            DO k = 1, klev+1
314       S        PCLDSW, PTAU, POMEGA, PCG,               swdn0 ( iof+i, k)   = ZFSDN0 ( i, k)
315       S        zheat, zheat0,               swdn  ( iof+i, k)   = ZFSDN  ( i, k)
316       S        zalbpla,ztopsw,zsolsw,ztopsw0,zsolsw0,               swup0 ( iof+i, k)   = ZFSUP0 ( i, k)
317       S        ZFSUP,ZFSDN,ZFSUP0,ZFSDN0,               swup  ( iof+i, k)   = ZFSUP  ( i, k)
318       S        tauae, pizae, cgae, ! aerosol optical properties            ENDDO
319       s        PTAUA, POMEGAA,         ENDDO
320       s        ztopswad,zsolswad,ztopswai,zsolswai, ! diagnosed aerosol forcing         ! transform the aerosol forcings, if they have to be calculated
321       J        ok_ade, ok_aie) ! apply aerosol effects or not?         IF (ok_ade) THEN
322              DO i = 1, kdlon
323  c======================================================================               topswad(iof+i) = ztopswad(i)
324        DO i = 1, kdlon               solswad(iof+i) = zsolswad(i)
325           radsol(iof+i) = zsolsw(i) + zsollw(i)            ENDDO
326           topsw(iof+i) = ztopsw(i)         ELSE
327           toplw(iof+i) = ztoplw(i)            DO i = 1, kdlon
328           solsw(iof+i) = zsolsw(i)               topswad(iof+i) = 0.0
329           sollw(iof+i) = zsollw(i)               solswad(iof+i) = 0.0
330           sollwdown(iof+i) = zsollwdown(i)            ENDDO
331  cIM         ENDIF
332           DO k = 1, kflev+1         IF (ok_aie) THEN
333           lwdn0 ( iof+i,k)   = ZFLDN0 ( i,k)            DO i = 1, kdlon
334           lwdn  ( iof+i,k)   = ZFLDN  ( i,k)               topswai(iof+i) = ztopswai(i)
335           lwup0 ( iof+i,k)   = ZFLUP0 ( i,k)               solswai(iof+i) = zsolswai(i)
336           lwup  ( iof+i,k)   = ZFLUP  ( i,k)            ENDDO
337           ENDDO         ELSE
338  c            DO i = 1, kdlon
339           topsw0(iof+i) = ztopsw0(i)               topswai(iof+i) = 0.0
340           toplw0(iof+i) = ztoplw0(i)               solswai(iof+i) = 0.0
341           solsw0(iof+i) = zsolsw0(i)            ENDDO
342           sollw0(iof+i) = zsollw0(i)         ENDIF
343           albpla(iof+i) = zalbpla(i)  
344  cIM         DO k = 1, klev
345           DO k = 1, kflev+1            DO i = 1, kdlon
346           swdn0 ( iof+i,k)   = ZFSDN0 ( i,k)               ! scale factor to take into account the difference
347           swdn  ( iof+i,k)   = ZFSDN  ( i,k)               ! between dry air and water vapour specific heat capacity
348           swup0 ( iof+i,k)   = ZFSUP0 ( i,k)               zznormcp = 1. + RVTMP2 * PWV(i, k)
349           swup  ( iof+i,k)   = ZFSUP  ( i,k)               heat(iof+i, k) = zheat(i, k) / zznormcp
350           ENDDO !k=1, kflev+1               cool(iof+i, k) = zcool(i, k)/zznormcp
351        ENDDO               heat0(iof+i, k) = zheat0(i, k)/zznormcp
352  cjq-transform the aerosol forcings, if they have               cool0(iof+i, k) = zcool0(i, k)/zznormcp
353  cjq to be calculated            ENDDO
354        IF (ok_ade) THEN         ENDDO
355        DO i = 1, kdlon      end DO loop_iof
356           topswad(iof+i) = ztopswad(i)  
357           solswad(iof+i) = zsolswad(i)    END SUBROUTINE radlwsw
358        ENDDO  
359        ELSE  end module radlwsw_m
       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.24  
changed lines
  Added in v.213

  ViewVC Help
Powered by ViewVC 1.1.21