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

  ViewVC Help
Powered by ViewVC 1.1.21