source: LMDZ4/branches/V3_test/libf/phylmd/physiq.F @ 720

Last change on this file since 720 was 720, checked in by Laurent Fairhead, 18 years ago

Corrections bugs divers YM
LF

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 117.1 KB
Line 
1!
2! $Header$
3!
4c
5c#define IO_DEBUG
6
7      SUBROUTINE physiq (nlon,nlev,nqmax,
8     .            debut,lafin,rjourvrai,gmtime,pdtphys,
9     .            paprs,pplay,pphi,pphis,presnivs,clesphy0,
10     .            u,v,t,qx,
11     .            omega,
12#ifdef INCA
13     .            flxmass_w,
14#endif
15     .            d_u, d_v, d_t, d_qx, d_ps
16cIM Amip2
17     .            , dudyn
18     .            , PVteta)
19
20      USE ioipsl
21      USE comgeomphy
22      USE write_field_phy
23      USE dimphy
24      USE iophy
25      USE misc_mod, mydebug=>debug
26      USE vampir
27#ifdef INCA
28cym      USE chemshut
29      USE species_names
30#ifdef INCA_CH4
31!      USE obs_pos
32#endif
33#endif
34      IMPLICIT none
35c======================================================================
36c
37c Auteur(s) Z.X. Li (LMD/CNRS) date: 19930818
38c
39c Objet: Moniteur general de la physique du modele
40cAA      Modifications quant aux traceurs :
41cAA                  -  uniformisation des parametrisations ds phytrac
42cAA                  -  stockage des moyennes des champs necessaires
43cAA                     en mode traceur off-line
44c======================================================================
45c   CLEFS CPP POUR LES IO
46c   =====================
47c#define histhf
48c#define histday
49C#define histmth
50c#define histins
51c#define histmthNMC
52c#define histISCCP
53c======================================================================
54c    modif   ( P. Le Van ,  12/10/98 )
55c
56c  Arguments:
57c
58c nlon----input-I-nombre de points horizontaux
59c nlev----input-I-nombre de couches verticales
60c nqmax---input-I-nombre de traceurs (y compris vapeur d'eau) = 1
61c debut---input-L-variable logique indiquant le premier passage
62c lafin---input-L-variable logique indiquant le dernier passage
63c rjour---input-R-numero du jour de l'experience
64c gmtime--input-R-temps universel dans la journee (0 a 86400 s)
65c pdtphys-input-R-pas d'integration pour la physique (seconde)
66c paprs---input-R-pression pour chaque inter-couche (en Pa)
67c pplay---input-R-pression pour le mileu de chaque couche (en Pa)
68c pphi----input-R-geopotentiel de chaque couche (g z) (reference sol)
69c pphis---input-R-geopotentiel du sol
70c presnivs-input_R_pressions approximat. des milieux couches ( en PA)
71c u-------input-R-vitesse dans la direction X (de O a E) en m/s
72c v-------input-R-vitesse Y (de S a N) en m/s
73c t-------input-R-temperature (K)
74c qx------input-R-humidite specifique (kg/kg) et d'autres traceurs
75c d_t_dyn-input-R-tendance dynamique pour "t" (K/s)
76c d_q_dyn-input-R-tendance dynamique pour "q" (kg/kg/s)
77c omega---input-R-vitesse verticale en Pa/s
78cIM comgeomphy.h BEG
79c cuphy----input-R-resolution des mailles en x (m)
80c cvphy----input-R-resolution des mailles en y (m)
81cIM comgeomphy.h END
82c d_u-----output-R-tendance physique de "u" (m/s/s)
83c d_v-----output-R-tendance physique de "v" (m/s/s)
84c d_t-----output-R-tendance physique de "t" (K/s)
85c d_qx----output-R-tendance physique de "qx" (kg/kg/s)
86c d_ps----output-R-tendance physique de la pression au sol
87cIM
88c PVteta--output-R-vorticite potentielle a des thetas constantes
89c======================================================================
90#include "dimensions.h"
91      integer jjmp1
92      parameter (jjmp1=jjm+1-1/jjm)
93      integer iip1
94      parameter (iip1=iim+1)
95cym#include "dimphy.h"
96#include "regdim.h"
97#include "indicesol.h"
98#include "dimsoil.h"
99#include "clesphys.h"
100#include "control.h"
101#include "logic.h"
102#include "temps.h"
103cym#include "comgeomphy.h"
104#include "advtrac.h"
105#include "iniprint.h"
106#include "thermcell.h"
107c======================================================================
108      LOGICAL ok_cvl  ! pour activer le nouveau driver pour convection KE
109      PARAMETER (ok_cvl=.TRUE.)
110      LOGICAL ok_gust ! pour activer l'effet des gust sur flux surface
111      PARAMETER (ok_gust=.FALSE.)
112c======================================================================
113      LOGICAL check ! Verifier la conservation du modele en eau
114      PARAMETER (check=.FALSE.)
115      LOGICAL ok_stratus ! Ajouter artificiellement les stratus
116      PARAMETER (ok_stratus=.FALSE.)
117c======================================================================
118c Parametres lies au coupleur OASIS:
119#include "oasis.h"
120      INTEGER,SAVE :: npas, nexca
121c$OMP THREADPRIVATE(npas, nexca)
122      logical rnpb
123#ifdef INCA
124      parameter(rnpb=.false.)
125#else
126      parameter(rnpb=.true.)
127#endif
128c      ocean = type de modele ocean a utiliser: force, slab, couple
129      character*6 ocean
130      SAVE ocean
131c$OMP THREADPRIVATE(ocean)
132c      parameter (ocean = 'force ')
133c     parameter (ocean = 'couple')
134      logical ok_ocean
135      SAVE ok_ocean
136c$OMP THREADPRIVATE(ok_ocean)
137c
138cIM "slab" ocean
139      REAL tslab(klon)    !Temperature du slab-ocean
140cIM      SAVE tslab
141      REAL seaice(klon)   !glace de mer (kg/m2)
142cIM      SAVE seaice
143      REAL fluxo(klon)    !flux turbulents ocean-glace de mer
144      REAL fluxg(klon)    !flux turbulents ocean-atmosphere
145cIM
146      REAL amn, amx
147c======================================================================
148c Clef controlant l'activation du cycle diurne:
149ccc      LOGICAL cycle_diurne
150ccc      PARAMETER (cycle_diurne=.FALSE.)
151c======================================================================
152c Modele thermique du sol, a activer pour le cycle diurne:
153ccc      LOGICAL soil_model
154ccc      PARAMETER (soil_model=.FALSE.)
155      logical ok_veget
156      save ok_veget
157c$OMP THREADPRIVATE(ok_veget)
158c     parameter (ok_veget = .true.)
159c      parameter (ok_veget = .false.)
160c======================================================================
161c Dans les versions precedentes, l'eau liquide nuageuse utilisee dans
162c le calcul du rayonnement est celle apres la precipitation des nuages.
163c Si cette cle new_oliq est activee, ce sera une valeur moyenne entre
164c la condensation et la precipitation. Cette cle augmente les impacts
165c radiatifs des nuages.
166ccc      LOGICAL new_oliq
167ccc      PARAMETER (new_oliq=.FALSE.)
168c======================================================================
169c Clefs controlant deux parametrisations de l'orographie:
170cc      LOGICAL ok_orodr
171ccc      PARAMETER (ok_orodr=.FALSE.)
172ccc      LOGICAL ok_orolf
173ccc      PARAMETER (ok_orolf=.FALSE.)
174c======================================================================
175      LOGICAL ok_journe ! sortir le fichier journalier
176      save ok_journe
177c$OMP THREADPRIVATE(ok_journe)
178c      PARAMETER (ok_journe=.true.)
179c
180      LOGICAL ok_mensuel ! sortir le fichier mensuel
181      save ok_mensuel
182c$OMP THREADPRIVATE(ok_mensuel)
183c      PARAMETER (ok_mensuel=.true.)
184c
185      LOGICAL ok_instan ! sortir le fichier instantane
186      save ok_instan
187c$OMP THREADPRIVATE(ok_instan)
188c      PARAMETER (ok_instan=.true.)
189c
190      LOGICAL ok_region ! sortir le fichier regional
191      PARAMETER (ok_region=.FALSE.)
192c======================================================================
193c     pour phsystoke avec thermiques
194      REAL fm_therm(klon,klev+1)
195      REAL entr_therm(klon,klev)
196      real,allocatable,save :: q2(:,:,:)
197c$OMP THREADPRIVATE(q2)
198cym      save q2
199c======================================================================
200c
201      INTEGER ivap          ! indice de traceurs pour vapeur d'eau
202      PARAMETER (ivap=1)
203      INTEGER iliq          ! indice de traceurs pour eau liquide
204      PARAMETER (iliq=2)
205
206c
207c
208c Variables argument:
209c
210      INTEGER nlon
211      INTEGER nlev
212      INTEGER nqmax
213      REAL rjourvrai
214      REAL gmtime
215      REAL pdtphys
216      LOGICAL debut, lafin
217      REAL paprs(klon,klev+1)
218      REAL pplay(klon,klev)
219      REAL pphi(klon,klev)
220      REAL pphis(klon)
221      REAL presnivs(klev)
222      REAL znivsig(klev)
223      REAL zsurf(nbsrf)
224cIM
225      INTEGER kinv
226      real pir
227cMI
228      REAL u(klon,klev)
229      REAL v(klon,klev)
230      REAL t(klon,klev)
231      REAL qx(klon,klev,nqmax)
232
233      REAL,allocatable,save :: t_ancien(:,:), q_ancien(:,:)
234c$OMP THREADPRIVATE(t_ancien, q_ancien)
235cym      SAVE t_ancien, q_ancien
236      LOGICAL ancien_ok
237      SAVE ancien_ok
238c$OMP THREADPRIVATE(ancien_ok)
239      REAL d_t_dyn(klon,klev)
240      REAL d_q_dyn(klon,klev)
241
242      REAL omega(klon,klev)
243
244#ifdef INCA
245      REAL flxmass_w(klon,klev)
246#endif
247      REAL d_u(klon,klev)
248      REAL d_v(klon,klev)
249      REAL d_t(klon,klev)
250      REAL d_qx(klon,klev,nqmax)
251      REAL d_ps(klon)
252      real da(klon,klev),phi(klon,klev,klev),mp(klon,klev)
253c
254cIM Amip2 PV a theta constante
255c
256      INTEGER nbteta
257      PARAMETER(nbteta=3)
258      CHARACTER*3 ctetaSTD(nbteta)
259      DATA ctetaSTD/'350','380','405'/
260c$OMP THREADPRIVATE(ctetaSTD)
261      REAL rtetaSTD(nbteta)
262      DATA rtetaSTD/350., 380., 405./
263c$OMP THREADPRIVATE(rtetaSTD)     
264c
265      REAL PVteta(klon,nbteta)
266      REAL zx_tmp_3dte(iim,jjmp1,nbteta)
267c
268cMI Amip2 PV a theta constante
269
270cym      INTEGER klevp1, klevm1
271cym      PARAMETER(klevp1=klev+1,klevm1=klev-1)
272cym#include "raddim.h"
273c
274
275      REAL,allocatable,save :: swdn0(:,:), swdn(:,:)
276      REAL,allocatable,save :: swup0(:,:), swup(:,:)
277c$OMP THREADPRIVATE(swdn0 , swdn, swup0, swup)
278cym      SAVE swdn0 , swdn, swup0, swup
279c
280      REAL,allocatable,save :: SWdn200clr(:), SWdn200(:)
281      REAL,allocatable,save :: SWup200clr(:), SWup200(:)
282c$OMP THREADPRIVATE(SWdn200clr, SWdn200, SWup200clr, SWup200)
283cym      SAVE SWdn200clr, SWdn200, SWup200clr, SWup200
284c
285      REAL,allocatable,save :: lwdn0(:,:), lwdn(:,:)
286      REAL,allocatable,save :: lwup0(:,:), lwup(:,:)
287c$OMP THREADPRIVATE(lwdn0 , lwdn, lwup0, lwup)
288cym      SAVE lwdn0 , lwdn, lwup0, lwup
289c
290      REAL,allocatable,save :: LWdn200clr(:), LWdn200(:)
291      REAL,allocatable,save :: LWup200clr(:), LWup200(:)
292c$OMP THREADPRIVATE(LWdn200clr, LWdn200, LWup200clr, LWup200)
293cym      SAVE LWdn200clr, LWdn200, LWup200clr, LWup200
294c
295      REAL,allocatable,save :: LWdnTOA(:), LWdnTOAclr(:)
296c$OMP THREADPRIVATE(LWdnTOA, LWdnTOAclr)
297cym      SAVE LWdnTOA, LWdnTOAclr
298c
299cIM Amip2
300c variables a une pression donnee
301c
302      integer nlevSTD
303      PARAMETER(nlevSTD=17)
304      real rlevSTD(nlevSTD)
305      DATA rlevSTD/100000., 92500., 85000., 70000.,
306     .60000., 50000., 40000., 30000., 25000., 20000.,
307     .15000., 10000., 7000., 5000., 3000., 2000., 1000./
308c$OMP THREADPRIVATE(rlevSTD)
309      CHARACTER*4 clevSTD(nlevSTD)
310      DATA clevSTD/'1000','925 ','850 ','700 ','600 ',
311     .'500 ','400 ','300 ','250 ','200 ','150 ','100 ',
312     .'70  ','50  ','30  ','20  ','10  '/
313c$OMP THREADPRIVATE(clevSTD)
314c
315      CHARACTER*3 bb2
316      CHARACTER*2 bb3
317c
318      real tlevSTD(klon,nlevSTD), qlevSTD(klon,nlevSTD)
319      real rhlevSTD(klon,nlevSTD), philevSTD(klon,nlevSTD)
320      real ulevSTD(klon,nlevSTD), vlevSTD(klon,nlevSTD)
321      real wlevSTD(klon,nlevSTD)
322c
323c nout : niveau de output des variables a une pression donnee
324      INTEGER nout
325      PARAMETER(nout=3) !nout=1 : day; =2 : mth; =3 : NMC
326c
327      REAL,SAVE,ALLOCATABLE :: tsumSTD(:,:,:)
328      REAL,SAVE,ALLOCATABLE :: usumSTD(:,:,:), vsumSTD(:,:,:)
329      REAL,SAVE,ALLOCATABLE :: wsumSTD(:,:,:), phisumSTD(:,:,:)
330      REAL,SAVE,ALLOCATABLE :: qsumSTD(:,:,:), rhsumSTD(:,:,:)
331c
332cym      SAVE tsumSTD, usumSTD, vsumSTD, wsumSTD, phisumSTD,
333cym     .     qsumSTD, rhsumSTD
334c$OMP THREADPRIVATE(tsumSTD, usumSTD, vsumSTD, wsumSTD, phisumSTD)
335c$OMP THREADPRIVATE(qsumSTD, rhsumSTD)
336c
337      logical oknondef(klon,nlevSTD,nout)
338      real,SAVE,ALLOCATABLE :: tnondef(:,:,:)
339c$OMP THREADPRIVATE(tnondef)
340cym      save tnondef
341c
342c les produits uvSTD, vqSTD, .., T2STD sont calcules
343c a partir des valeurs instantannees toutes les 6 h
344c qui sont moyennees sur le mois
345c
346      real uvSTD(klon,nlevSTD)
347      real vqSTD(klon,nlevSTD)
348      real vTSTD(klon,nlevSTD)
349      real wqSTD(klon,nlevSTD)
350c
351      real,save,allocatable :: uvsumSTD(:,:,:)
352      real,save,allocatable :: vqsumSTD(:,:,:)
353      real,save,allocatable :: vTsumSTD(:,:,:)
354      real,save,allocatable :: wqsumSTD(:,:,:)
355c
356      real vphiSTD(klon,nlevSTD)
357      real wTSTD(klon,nlevSTD)
358      real u2STD(klon,nlevSTD)
359      real v2STD(klon,nlevSTD)
360      real T2STD(klon,nlevSTD)
361c
362      real,save,allocatable :: vphisumSTD(:,:,:)
363      real,save,allocatable :: wTsumSTD(:,:,:)
364      real,save,allocatable :: u2sumSTD(:,:,:)
365      real,save,allocatable :: v2sumSTD(:,:,:)
366      real,save,allocatable :: T2sumSTD(:,:,:)
367c
368cym      SAVE uvsumSTD, vqsumSTD, vTsumSTD, wqsumSTD
369cym      SAVE vphisumSTD, wTsumSTD, u2sumSTD, v2sumSTD, T2sumSTD
370c$OMP THREADPRIVATE(uvsumSTD, vqsumSTD, vTsumSTD, wqsumSTD)
371c$OMP THREADPRIVATE(vphisumSTD, wTsumSTD, u2sumSTD, v2sumSTD, T2sumSTD)
372
373cMI Amip2
374c
375#include "radepsi.h"
376#include "radopt.h"
377c
378c
379c prw: precipitable water
380      real prw(klon)
381
382      REAL convliq(klon,klev)  ! eau liquide nuageuse convective
383      REAL convfra(klon,klev)  ! fraction nuageuse convective
384
385      REAL cldl_c(klon),cldm_c(klon),cldh_c(klon) !nuages bas, moyen et haut
386      REAL cldt_c(klon),cldq_c(klon) !nuage total, eau liquide integree
387      REAL cldl_s(klon),cldm_s(klon),cldh_s(klon) !nuages bas, moyen et haut
388      REAL cldt_s(klon),cldq_s(klon) !nuage total, eau liquide integree
389
390      INTEGER linv, kp1
391c flwp, fiwp = Liquid Water Path & Ice Water Path (kg/m2)
392c flwc, fiwc = Liquid Water Content & Ice Water Content (kg/kg)
393      REAL flwp(klon), fiwp(klon)
394      REAL flwc(klon,klev), fiwc(klon,klev)
395      REAL flwp_c(klon), fiwp_c(klon)
396      REAL flwc_c(klon,klev), fiwc_c(klon,klev)
397      REAL flwp_s(klon), fiwp_s(klon)
398      REAL flwc_s(klon,klev), fiwc_s(klon,klev)
399
400cIM ISCCP simulator v3.4
401c dans clesphys.h top_height, overlap
402cv3.4
403      INTEGER debug, debugcol
404cym      INTEGER npoints
405cym      PARAMETER(npoints=klon)
406c
407      INTEGER sunlit(klon) !sunlit=1 if day; sunlit=0 if night
408      INTEGER nregISCtot
409      PARAMETER(nregISCtot=1)
410c
411c imin_debut, nbpti, jmin_debut, nbptj : parametres pour sorties sur 1 region rectangulaire
412c y compris pour 1 point
413c imin_debut : indice minimum de i; nbpti : nombre de points en direction i (longitude)
414c jmin_debut : indice minimum de j; nbptj : nombre de points en direction j (latitude)
415      INTEGER imin_debut, nbpti
416      INTEGER jmin_debut, nbptj
417cIM parametres ISCCP BEG
418      INTEGER nbapp_isccp,isccppas
419      INTEGER n, napisccp
420c     PARAMETER(napisccp=3)
421      PARAMETER(napisccp=1)
422      INTEGER ifreq_isccp(napisccp), freqin_pdt(napisccp)
423      DATA ifreq_isccp/3/
424      SAVE ifreq_isccp
425c$OMP THREAPRIVATE(ifreq_isccp)
426      CHARACTER*5 typinout(napisccp)
427      DATA typinout/'i3od'/
428c$OMP THREAPRIVATE(typinout)
429cIM verif boxptop BEG
430      CHARACTER*1 verticaxe(napisccp)
431      DATA verticaxe/'1'/
432c$OMP THREAPRIVATE(verticaxe)
433cIM verif boxptop END
434      INTEGER nvlev(napisccp)
435c     INTEGER nvlev
436      REAL t1, aa
437      REAL seed_re(klon,napisccp)
438      INTEGER,ALLOCATABLE,SAVE :: seed_old(:,:)
439cym      SAVE seed_old
440c$OMP THREADPRIVATE(seed_old)
441cym !!!! A voir plus tard
442cym      INTEGER iphy(iim,jjmp1)
443cIM parametres ISCCP END
444c
445c ncol = nb. de sous-colonnes pour chaque maille du GCM
446c ncolmx = No. max. de sous-colonnes pour chaque maille du GCM
447      INTEGER ncol(napisccp), ncolmx, seed(klon,napisccp)
448      REAL nbsunlit(nregISCtot,klon,napisccp)  !nbsunlit : moyenne de sunlit
449      PARAMETER(ncolmx=1500)
450c
451cIM verif boxptop BEG
452      REAL vertlev(ncolmx,napisccp)
453cIM verif boxptop END
454c
455      REAL tautab(0:255)
456      INTEGER invtau(-20:45000)
457      REAL emsfc_lw
458      PARAMETER(emsfc_lw=0.99)
459c     REAL    ran0                      ! type for random number fuction
460c
461      REAL cldtot(klon,klev)
462c variables de haut en bas pour le simulateur ISCCP
463      REAL dtau_s(klon,klev) !tau nuages startiformes
464      REAL dtau_c(klon,klev) !tau nuages convectifs
465      REAL dem_s(klon,klev)  !emissivite nuages startiformes
466      REAL dem_c(klon,klev)  !emissivite nuages convectifs
467c
468c variables de haut en bas pour le simulateur ISCCP
469      REAL pfull(klon,klev)
470      REAL phalf(klon,klev+1)
471      REAL qv(klon,klev)
472      REAL cc(klon,klev)
473      REAL conv(klon,klev)
474      REAL dtau_sH2B(klon,klev)
475      REAL dtau_cH2B(klon,klev)
476      REAL at(klon,klev)
477      REAL dem_sH2B(klon,klev)
478      REAL dem_cH2B(klon,klev)
479c
480      INTEGER kmax, lmax, lmax3
481      PARAMETER(kmax=8, lmax=8, lmax3=3)
482      INTEGER kmaxm1, lmaxm1
483      PARAMETER(kmaxm1=kmax-1, lmaxm1=lmax-1)
484      INTEGER iimx7, jjmx7, jjmp1x7
485      PARAMETER(iimx7=iim*kmaxm1, jjmx7=jjm*lmaxm1,
486     .jjmp1x7=jjmp1*lmaxm1)
487c
488c output from ISCCP simulator
489      REAL fq_isccp(klon,kmaxm1,lmaxm1,napisccp)
490      REAL fq_is_true(klon,kmaxm1,lmaxm1,napisccp)
491      REAL totalcldarea(klon,napisccp)
492      REAL meanptop(klon,napisccp)
493      REAL meantaucld(klon,napisccp)
494      REAL boxtau(klon,ncolmx,napisccp)
495      REAL boxptop(klon,ncolmx,napisccp)
496      REAL zx_tmp_fi3d_bx(klon,ncolmx)
497      REAL zx_tmp_3d_bx(iim,jjmp1,ncolmx)
498c
499      REAL cld_fi3d(klon,lmax3)
500      REAL cld_3d(iim,jjmp1,lmax3)
501c
502      INTEGER iw, iwmax
503      REAL wmin, pas_w
504c     PARAMETER(wmin=-100.,pas_w=10.,iwmax=30)
505cIM 051005     PARAMETER(wmin=-200.,pas_w=10.,iwmax=40)
506      PARAMETER(wmin=-100.,pas_w=10.,iwmax=20)
507      REAL o500(klon)
508c
509cIM: nbregdyn = nbre regions pour calculs statistiques sur output du ISCCP
510cIM: dynamiques 
511      INTEGER nreg, nbregdyn
512      PARAMETER(nbregdyn=5)
513cIM 051005 BEG
514c     REAL histoW(iwmax,nbregdyn,napisccp)
515c     REAL nhistoW(iwmax,nbregdyn,napisccp)
516c     REAL histoWn(iwmax,nbregdyn)
517c     REAL nhistoWn(iwmax,nbregdyn)
518cIM 090905 END
519
520      INTEGER linv
521      INTEGER,ALLOCATABLE,SAVE :: pct_ocean(:,:)
522c$OMP THREADPRIVATE(pct_ocean)
523cym      SAVE pct_ocean
524 
525c sorties ISCCP
526
527c     logical ok_isccp
528c     real ecrit_isccp
529      integer nid_isccp
530c     save ok_isccp, ecrit_isccp, nid_isccp       
531      save nid_isccp       
532c$OMP THREADPRIVATE(ok_isccp, ecrit_isccp, nid_isccp,nid_isccp)
533c     data ok_isccp,ecrit_isccp/.true.,0.125/     
534c     data ok_isccp,ecrit_isccp/.true.,1./     
535cIM 190504     data ok_isccp/.true./     
536cIM 190504 #else
537cIM 190504     data ok_isccp/.false./
538cIM 190504 #endif
539
540      REAL zx_tau(kmaxm1), zx_pc(lmaxm1), zx_o500(iwmax)
541      DATA zx_tau/0.0, 0.3, 1.3, 3.6, 9.4, 23., 60./
542cIM bad 151205     DATA zx_pc/50., 180., 310., 440., 560., 680., 800./
543      DATA zx_pc/180., 310., 440., 560., 680., 800., 1000./
544c$OMP THREADPRIVATE(zx_tau,zx_pc)
545c cldtopres pression au sommet des nuages
546      REAL cldtopres(lmaxm1), cldtopres3(lmax3)
547cIM 151205 erreur     DATA cldtopres/50., 180., 310., 440., 560., 680., 800./
548      DATA cldtopres/180., 310., 440., 560., 680., 800., 1000./
549      DATA cldtopres3/440., 680., 1000./
550c$OMP THREADPRIVATE(cldtopres,cldtopres3)
551cIM 051005 BEG
552      REAL tmp_his1_3d(iwmax,kmaxm1,lmaxm1,nbregdyn,napisccp)
553      REAL tmp_his2_3d(iwmax,kmaxm1,lmaxm1,nbregdyn,napisccp)
554      REAL tmp_his3_3d(iwmax,kmaxm1,lmaxm1,nbregdyn,napisccp)
555cIM 051005 END
556
557      INTEGER komega, nhoriRD
558
559c taulev: numero du niveau de tau dans les sorties ISCCP
560      CHARACTER *4 taulev(kmaxm1)
561c     DATA taulev/'tau1','tau2','tau3','tau4','tau5','tau6','tau7'/
562      DATA taulev/'tau0','tau1','tau2','tau3','tau4','tau5','tau6'/
563      CHARACTER *3 pclev(lmaxm1)
564      DATA pclev/'pc1','pc2','pc3','pc4','pc5','pc6','pc7'/
565c$OMP THREADPRIVATE(taulev,pclev)
566c
567c cnameisccp
568      CHARACTER *27 cnameisccp(lmaxm1,kmaxm1)
569cIM bad 151205     DATA cnameisccp/'pc< 50hPa, tau< 0.3',
570      DATA cnameisccp/'pc= 50-180hPa, tau< 0.3',
571     .                'pc= 180-310hPa, tau< 0.3',
572     .                'pc= 310-440hPa, tau< 0.3',
573     .                'pc= 440-560hPa, tau< 0.3',
574     .                'pc= 560-680hPa, tau< 0.3',
575     .                'pc= 680-800hPa, tau< 0.3',
576     .                'pc= 800-1000hPa, tau< 0.3',
577     .                'pc= 50-180hPa, tau= 0.3-1.3',
578     .                'pc= 180-310hPa, tau= 0.3-1.3',
579     .                'pc= 310-440hPa, tau= 0.3-1.3',
580     .                'pc= 440-560hPa, tau= 0.3-1.3',
581     .                'pc= 560-680hPa, tau= 0.3-1.3',
582     .                'pc= 680-800hPa, tau= 0.3-1.3',
583     .                'pc= 800-1000hPa, tau= 0.3-1.3',
584     .                'pc= 50-180hPa, tau= 1.3-3.6',
585     .                'pc= 180-310hPa, tau= 1.3-3.6',
586     .                'pc= 310-440hPa, tau= 1.3-3.6',
587     .                'pc= 440-560hPa, tau= 1.3-3.6',
588     .                'pc= 560-680hPa, tau= 1.3-3.6',
589     .                'pc= 680-800hPa, tau= 1.3-3.6',
590     .                'pc= 800-1000hPa, tau= 1.3-3.6',
591     .                'pc= 50-180hPa, tau= 3.6-9.4',
592     .                'pc= 180-310hPa, tau= 3.6-9.4',
593     .                'pc= 310-440hPa, tau= 3.6-9.4',
594     .                'pc= 440-560hPa, tau= 3.6-9.4',
595     .                'pc= 560-680hPa, tau= 3.6-9.4',
596     .                'pc= 680-800hPa, tau= 3.6-9.4',
597     .                'pc= 800-1000hPa, tau= 3.6-9.4',
598     .                'pc= 50-180hPa, tau= 9.4-23',
599     .                'pc= 180-310hPa, tau= 9.4-23',
600     .                'pc= 310-440hPa, tau= 9.4-23',
601     .                'pc= 440-560hPa, tau= 9.4-23',
602     .                'pc= 560-680hPa, tau= 9.4-23',
603     .                'pc= 680-800hPa, tau= 9.4-23',
604     .                'pc= 800-1000hPa, tau= 9.4-23',
605     .                'pc= 50-180hPa, tau= 23-60',
606     .                'pc= 180-310hPa, tau= 23-60',
607     .                'pc= 310-440hPa, tau= 23-60',
608     .                'pc= 440-560hPa, tau= 23-60',
609     .                'pc= 560-680hPa, tau= 23-60',
610     .                'pc= 680-800hPa, tau= 23-60',
611     .                'pc= 800-1000hPa, tau= 23-60',
612     .                'pc= 50-180hPa, tau> 60.',
613     .                'pc= 180-310hPa, tau> 60.',
614     .                'pc= 310-440hPa, tau> 60.',
615     .                'pc= 440-560hPa, tau> 60.',
616     .                'pc= 560-680hPa, tau> 60.',
617     .                'pc= 680-800hPa, tau> 60.',
618     .                'pc= 800-1000hPa, tau> 60.'/
619c$OMP THREADPRIVATE(cnameisccp)
620c
621c     REAL zx_lonx7(iimx7), zx_latx7(jjmp1x7)
622c     INTEGER nhorix7
623cIM: region='3d' <==> sorties en global
624      CHARACTER*3 region
625      PARAMETER(region='3d')
626c
627cIM ISCCP simulator v3.4
628c
629      logical ok_hf
630c
631      integer nid_hf, nid_hf3d
632      save ok_hf, nid_hf, nid_hf3d
633c$OMP THREADPRIVATE(ok_hf, nid_hf, nid_hf3d)
634c  QUESTION : noms de variables ?
635
636#ifdef histhf
637cIM 130904   data ok_hf,ecrit_hf/.true.,0.25/
638      data ok_hf/.true./
639#else
640      data ok_hf/.false./
641#endif
642      INTEGER        longcles
643      PARAMETER    ( longcles = 20 )
644      REAL clesphy0( longcles      )
645c
646c Variables quasi-arguments
647c
648      REAL xjour
649      SAVE xjour
650c$OMP THREADPRIVATE(xjour)
651c
652c
653c Variables propres a la physique
654c
655      REAL dtime
656      SAVE dtime                  ! pas temporel de la physique
657c$OMP THREADPRIVATE(dtime)
658c
659      INTEGER radpas
660      SAVE radpas                 ! frequence d'appel rayonnement
661c$OMP THREADPRIVATE(radpas)
662c
663      REAL,allocatable,save :: radsol(:)
664c$OMP THREADPRIVATE(radsol)
665cym      SAVE radsol               ! bilan radiatif au sol calcule par code radiatif
666c
667      REAL,allocatable,save :: rlat(:)
668c$OMP THREADPRIVATE(rlat)
669cym      SAVE rlat                   ! latitude pour chaque point
670c
671      REAL,allocatable,save :: rlon(:)
672c$OMP THREADPRIVATE(rlon)
673cym      SAVE rlon                   ! longitude pour chaque point
674
675      REAL,SAVE,ALLOCATABLE :: rlonPOS(:)
676c$OMP THREADPRIVATE(rlonPOS)   
677cym      SAVE rlonPOS                ! longitudes > 0. pour chaque point
678c
679cc      INTEGER iflag_con
680cc      SAVE iflag_con              ! indicateur de la convection
681c
682      INTEGER itap
683      SAVE itap                   ! compteur pour la physique
684c$OMP THREADPRIVATE(itap)
685c
686      REAL co2_ppm_etat0
687c
688      REAL solaire_etat0
689c
690      real slp(klon) ! sea level pressure
691
692      REAL,allocatable,save :: ftsol(:,:)
693c$OMP THREADPRIVATE(ftsol)
694cym      SAVE ftsol                  ! temperature du sol
695
696cIM
697      REAL,SAVE,ALLOCATABLE :: newsst(:) !temperature de l'ocean
698c$OMP THREADPRIVATE(newsst)
699cym     SAVE newsst
700c
701      REAL,allocatable,save :: ftsoil(:,:,:)
702c$OMP THREADPRIVATE(ftsoil)
703cym      SAVE ftsoil                 ! temperature dans le sol
704c
705      REAL,allocatable,save :: fevap(:,:)
706c$OMP THREADPRIVATE(fevap)
707cym      SAVE fevap                 ! evaporation
708      REAL,allocatable,save :: fluxlat(:,:)
709c$OMP THREADPRIVATE(fluxlat)
710cym      SAVE fluxlat
711c
712      REAL,allocatable,save :: deltat(:)
713c$OMP THREADPRIVATE(deltat)
714cym      SAVE deltat                 ! ecart avec la SST de reference
715c
716      REAL,allocatable,save :: fqsurf(:,:)
717c$OMP THREADPRIVATE(fqsurf)
718cym      SAVE fqsurf                 ! humidite de l'air au contact de la surface
719c
720      REAL,allocatable,save :: qsol(:)
721c$OMP THREADPRIVATE(qsol)
722cym      SAVE qsol                  ! hauteur d'eau dans le sol
723c
724      REAL,allocatable,save :: fsnow(:,:)
725c$OMP THREADPRIVATE(fsnow)
726cym      SAVE fsnow                  ! epaisseur neigeuse
727c
728      REAL,allocatable,save :: falbe(:,:)
729c$OMP THREADPRIVATE(falbe)
730cym      SAVE falbe                  ! albedo par type de surface
731      REAL,allocatable,save :: falblw(:,:)
732c$OMP THREADPRIVATE(falblw)     
733cym      SAVE falblw                 ! albedo par type de surface
734
735c
736c
737c  Parametres de l'Orographie a l'Echelle Sous-Maille (OESM):
738c
739      REAL,allocatable,save :: zmea(:)
740c$OMP THREADPRIVATE(zmea)
741cym      SAVE zmea                   ! orographie moyenne
742c
743      REAL,allocatable,save :: zstd(:)
744c$OMP THREADPRIVATE(zstd)
745cym      SAVE zstd                   ! deviation standard de l'OESM
746c
747      REAL,allocatable,save :: zsig(:)
748c$OMP THREADPRIVATE(zsig)
749cym      SAVE zsig                   ! pente de l'OESM
750c
751      REAL,allocatable,save :: zgam(:)
752c$OMP THREADPRIVATE(zgam)
753cym      save zgam                   ! anisotropie de l'OESM
754c
755      REAL,allocatable,save :: zthe(:)
756c$OMP THREADPRIVATE(zthe)     
757cym      SAVE zthe                   ! orientation de l'OESM
758c
759      REAL,allocatable,save :: zpic(:)
760c$OMP THREADPRIVATE(zpic)
761cym      SAVE zpic                   ! Maximum de l'OESM
762c
763      REAL,allocatable,save :: zval(:)
764c$OMP THREADPRIVATE(zval)
765cym      SAVE zval                   ! Minimum de l'OESM
766c
767      REAL,allocatable,save :: rugoro(:)
768c$OMP THREADPRIVATE(rugoro)
769cym      SAVE rugoro                 ! longueur de rugosite de l'OESM
770c
771cIM 141004     REAL zulow(klon),zvlow(klon),zustr(klon), zvstr(klon)
772      REAL zulow(klon),zvlow(klon)
773c
774      REAL,allocatable,save :: zuthe(:),zvthe(:)
775c$OMP THREADPRIVATE(zuthe,zvthe)
776cym      SAVE zuthe
777cym      SAVE zvthe
778      INTEGER igwd,idx(klon),itest(klon)
779c
780      REAL,allocatable,save :: agesno(:,:)
781c$OMP THREADPRIVATE(agesno)
782cym      SAVE agesno                 ! age de la neige
783c
784      REAL,allocatable,save :: alb_neig(:)
785c$OMP THREADPRIVATE(alb_neig)
786cym      SAVE alb_neig               ! albedo de la neige
787c
788      REAL,allocatable,save :: run_off_lic_0(:)
789c$OMP THREADPRIVATE(run_off_lic_0)
790cym      SAVE run_off_lic_0
791cKE43
792c Variables liees a la convection de K. Emanuel (sb):
793c
794      REAL,allocatable,save :: ema_workcbmf(:)   ! cloud base mass flux
795c$OMP THREADPRIVATE(ema_workcbmf)
796cym      SAVE ema_workcbmf
797
798      REAL,allocatable,save :: ema_cbmf(:)       ! cloud base mass flux
799c$OMP THREADPRIVATE(ema_cbmf)
800cym      SAVE ema_cbmf
801
802      REAL,allocatable,save :: ema_pcb(:)        ! cloud base pressure
803c$OMP THREADPRIVATE(ema_pcb)
804cym      SAVE ema_pcb
805
806      REAL,allocatable,save :: ema_pct(:)        ! cloud top pressure
807c$OMP THREADPRIVATE(ema_pct)
808cym      SAVE ema_pct
809
810      REAL bas, top             ! cloud base and top levels
811      SAVE bas
812      SAVE top
813c$OMP THREADPRIVATE(bas, top)
814
815      REAL,allocatable,save :: Ma(:,:)        ! undilute upward mass flux
816c$OMP THREADPRIVATE(Ma)
817cym      SAVE Ma
818      REAL,allocatable,save :: qcondc(:,:)    ! in-cld water content from convect
819c$OMP THREADPRIVATE(qcondc)
820cym      SAVE qcondc
821      REAL,allocatable,save :: ema_work1(:, :), ema_work2(:, :)
822c$OMP THREADPRIVATE(ema_work1,ema_work2)
823cym      SAVE ema_work1, ema_work2
824      REAL wdn(klon), tdn(klon), qdn(klon)
825
826      REAL,allocatable,save :: wd(:) ! sb
827c$OMP THREADPRIVATE(wd)
828cym      SAVE wd       ! sb
829
830c Variables locales pour la couche limite (al1):
831c
832cAl1      REAL pblh(klon)           ! Hauteur de couche limite
833cAl1      SAVE pblh
834c34EK
835c
836c Variables locales:
837c
838      REAL cdragh(klon) ! drag coefficient pour T and Q
839      REAL cdragm(klon) ! drag coefficient pour vent
840cAA
841cAA  Pour phytrac
842cAA
843      REAL ycoefh(klon,klev)    ! coef d'echange pour phytrac
844      REAL yu1(klon)            ! vents dans la premiere couche U
845      REAL yv1(klon)            ! vents dans la premiere couche V
846      REAL,SAVE,ALLOCATABLE :: ffonte(:,:)    !Flux thermique utilise pour fondre la neige
847c$OMP THREAPRIVATE(ffonte)
848      REAL,SAVE,ALLOCATABLE :: fqcalving(:,:) !Flux d'eau "perdu" par la surface
849c$OMP THREAPRIVATE(fqcalving)
850      REAL,SAVE,ALLOCATABLE :: fqfonte(:,:)  !Quantite d'eau de fonte des glaciers
851c$OMP THREAPRIVATE(fqcalving)
852c                               !et necessaire pour limiter la
853c                               !hauteur de neige, en kg/m2/s
854      REAL zxffonte(klon), zxfqcalving(klon),zxfqfonte(klon)
855
856c@$$      LOGICAL offline           ! Controle du stockage ds "physique"
857c@$$      PARAMETER (offline=.false.)
858c@$$      INTEGER physid
859      REAL,allocatable,save :: pfrac_impa(:,:)! Produits des coefs lessivage impaction
860c$OMP THREADPRIVATE(pfrac_impa)
861cym      save pfrac_impa
862      REAL,allocatable,save :: pfrac_nucl(:,:)! Produits des coefs lessivage nucleation
863c$OMP THREADPRIVATE(pfrac_nucl)
864cym      save pfrac_nucl
865      REAL,allocatable,save :: pfrac_1nucl(:,:)! Produits des coefs lessi nucl (alpha = 1)
866c$OMP THREADPRIVATE(pfrac_1nucl)
867cym      save pfrac_1nucl
868      REAL frac_impa(klon,klev) ! fractions d'aerosols lessivees (impaction)
869      REAL frac_nucl(klon,klev) ! idem (nucleation)
870#ifdef INCA
871      INTEGER       :: iii
872      REAL          :: calday
873#endif
874
875cAA
876      REAL,allocatable,save :: rain_fall(:) ! pluie
877c$OMP THREADPRIVATE(rain_fall)
878      REAL,allocatable,save :: snow_fall(:) ! neige
879c$OMP THREADPRIVATE(snow_fall)
880cym      save snow_fall, rain_fall
881
882cIM cf FH pour Tiedtke 080604
883      REAL rain_tiedtke(klon),snow_tiedtke(klon)
884c
885
886      REAL,allocatable,save :: total_rain(:), nday_rain(:)
887c$OMP THREADPRIVATE(total_rain,nday_rain)
888cym      save total_rain, nday_rain
889cIM 050204 END
890      REAL evap(klon), devap(klon) ! evaporation et sa derivee
891      REAL sens(klon), dsens(klon) ! chaleur sensible et sa derivee
892      REAL,allocatable,save :: dlw(:)    ! derivee infra rouge
893c$OMP THREADPRIVATE(dlw)
894cym
895cym      SAVE dlw
896cym
897      REAL bils(klon) ! bilan de chaleur au sol
898      REAL wfbilo(klon,nbsrf) ! bilan d'eau, pour chaque
899C                             ! type de sous-surface et pondere par la fraction
900      REAL wfbils(klon,nbsrf) ! bilan de chaleur au sol, pour chaque
901C                             ! type de sous-surface et pondere par la fraction
902      REAL,allocatable,save :: fder(:) ! Derive de flux (sensible et latente)
903c$OMP THREADPRIVATE(fder)
904cym      save fder
905      REAL ve(klon) ! integr. verticale du transport meri. de l'energie
906      REAL vq(klon) ! integr. verticale du transport meri. de l'eau
907      REAL ue(klon) ! integr. verticale du transport zonal de l'energie
908      REAL uq(klon) ! integr. verticale du transport zonal de l'eau
909c
910      REAL,allocatable,save :: frugs(:,:) ! longueur de rugosite
911c$OMP THREADPRIVATE(frugs)
912cym      save frugs
913      REAL zxrugs(klon) ! longueur de rugosite
914c
915c Conditions aux limites
916c
917      INTEGER julien
918c
919      INTEGER lmt_pas
920      SAVE lmt_pas                ! frequence de mise a jour
921c$OMP THREADPRIVATE(lmt_pas)
922      REAL,allocatable,save :: pctsrf(:,:)
923c$OMP THREADPRIVATE(pctsrf)
924cIM
925      REAL pctsrf_new(klon,nbsrf) !pourcentage surfaces issus d'ORCHIDEE
926
927cym      REAL paire_ter(klon)        !surfaces terre
928      REAL,allocatable,save ::  paire_ter(:)        !surfaces terre
929c$OMP THREADPRIVATE(paire_ter)
930   
931cIM
932cym      SAVE pctsrf                 ! sous-fraction du sol
933      REAL,allocatable,save :: albsol(:)
934c$OMP THREADPRIVATE(albsol)
935cym      SAVE albsol                 ! albedo du sol total
936      REAL,allocatable,save :: albsollw(:)
937c$OMP THREADPRIVATE(albsollw)     
938cym      SAVE albsollw                 ! albedo du sol total
939
940      REAL,allocatable,save :: wo(:,:)
941c$OMP THREADPRIVATE(wo)
942cym     SAVE wo                     ! ozone
943
944cIM sorties
945      REAL un_jour
946      PARAMETER(un_jour=86400.)
947c======================================================================
948c
949c Declaration des procedures appelees
950c
951      EXTERNAL angle     ! calculer angle zenithal du soleil
952      EXTERNAL alboc     ! calculer l'albedo sur ocean
953      EXTERNAL ajsec     ! ajustement sec
954      EXTERNAL clmain    ! couche limite
955      EXTERNAL conlmd    ! convection (schema LMD)
956cKE43
957      EXTERNAL conema3  ! convect4.3
958      EXTERNAL fisrtilp  ! schema de condensation a grande echelle (pluie)
959cAA
960      EXTERNAL fisrtilp_tr ! schema de condensation a grande echelle (pluie)
961c                          ! stockage des coefficients necessaires au
962c                          ! lessivage OFF-LINE et ON-LINE
963      EXTERNAL hgardfou  ! verifier les temperatures
964      EXTERNAL nuage     ! calculer les proprietes radiatives
965      EXTERNAL o3cm      ! initialiser l'ozone
966      EXTERNAL orbite    ! calculer l'orbite terrestre
967      EXTERNAL ozonecm   ! prescrire l'ozone
968      EXTERNAL phyetat0  ! lire l'etat initial de la physique
969      EXTERNAL phyredem  ! ecrire l'etat de redemarrage de la physique
970      EXTERNAL radlwsw   ! rayonnements solaire et infrarouge
971      EXTERNAL suphec    ! initialiser certaines constantes
972      EXTERNAL transp    ! transport total de l'eau et de l'energie
973      EXTERNAL ecribina  ! ecrire le fichier binaire global
974      EXTERNAL ecribins  ! ecrire le fichier binaire global
975      EXTERNAL ecrirega  ! ecrire le fichier binaire regional
976      EXTERNAL ecriregs  ! ecrire le fichier binaire regional
977cIM
978      EXTERNAL haut2bas  !variables de haut en bas
979      INTEGER lnblnk1
980      EXTERNAL lnblnk1   !enleve les blancs a la fin d'une variable de type
981                         !caracter
982      EXTERNAL ini_undefSTD  !initialise a 0 une variable a 1 niveau de pression
983      EXTERNAL undefSTD      !somme les valeurs definies d'1 var a 1 niveau de pression
984c     EXTERNAL moy_undefSTD  !moyenne d'1 var a 1 niveau de pression
985c     EXTERNAL moyglo_aire   !moyenne globale d'1 var ponderee par l'aire de la maille (moyglo_pondaire)
986c                            !par la masse/airetot (moyglo_pondaima) et la vraie masse (moyglo_pondmass)
987c
988c Variables locales
989c
990      real,allocatable,save :: clwcon(:,:),rnebcon(:,:)
991c$OMP THREADPRIVATE(clwcon,rnebcon)
992      real,allocatable,save :: clwcon0(:,:),rnebcon0(:,:)
993cym      save rnebcon, clwcon
994c$OMP THREADPRIVATE(clwcon0,rnebcon0)
995      REAL rhcl(klon,klev)    ! humiditi relative ciel clair
996      REAL dialiq(klon,klev)  ! eau liquide nuageuse
997      REAL diafra(klon,klev)  ! fraction nuageuse
998      REAL cldliq(klon,klev)  ! eau liquide nuageuse
999      REAL cldfra(klon,klev)  ! fraction nuageuse
1000      REAL cldtau(klon,klev)  ! epaisseur optique
1001      REAL cldemi(klon,klev)  ! emissivite infrarouge
1002c
1003CXXX PB
1004      REAL fluxq(klon,klev, nbsrf)   ! flux turbulent d'humidite
1005      REAL fluxt(klon,klev, nbsrf)   ! flux turbulent de chaleur
1006      REAL fluxu(klon,klev, nbsrf)   ! flux turbulent de vitesse u
1007      REAL fluxv(klon,klev, nbsrf)   ! flux turbulent de vitesse v
1008c
1009      REAL zxfluxt(klon, klev)
1010      REAL zxfluxq(klon, klev)
1011      REAL zxfluxu(klon, klev)
1012      REAL zxfluxv(klon, klev)
1013CXXX
1014      REAL,allocatable,save :: heat(:,:)    ! chauffage solaire
1015c$OMP THREADPRIVATE(heat)
1016      REAL,allocatable,save :: heat0(:,:)   ! chauffage solaire ciel clair
1017c$OMP THREADPRIVATE(heat0)
1018      REAL,allocatable,save :: cool(:,:)    ! refroidissement infrarouge
1019c$OMP THREADPRIVATE(cool)
1020      REAL,allocatable,save :: cool0(:,:)   ! refroidissement infrarouge ciel clair
1021c$OMP THREADPRIVATE(cool0)
1022      REAL,allocatable,save :: topsw(:), toplw(:), solsw(:), sollw(:)
1023c$OMP THREADPRIVATE(topsw,toplw,solsw,sollw)
1024      real,allocatable,save :: sollwdown(:)    ! downward LW flux at surface
1025c$OMP THREADPRIVATE(sollwdown)
1026cIM BEG
1027      real,allocatable,save :: sollwdownclr(:)    ! downward CS LW flux at surface
1028c$OMP THREADPRIVATE(sollwdownclr)
1029      real,allocatable,save :: toplwdown(:)       ! downward CS LW flux at TOA
1030c$OMP THREADPRIVATE(toplwdown)
1031      real,allocatable,save :: toplwdownclr(:)    ! downward CS LW flux at TOA
1032c$OMP THREADPRIVATE(toplwdownclr)
1033cIM END
1034      REAL,allocatable,save :: topsw0(:),toplw0(:),solsw0(:),sollw0(:)
1035c$OMP THREADPRIVATE( topsw0,toplw0,solsw0,sollw0)
1036      REAL,allocatable,save :: albpla(:)
1037c$OMP THREADPRIVATE(albpla)
1038      REAL fsollw(klon, nbsrf)   ! bilan flux IR pour chaque sous surface
1039      REAL fsolsw(klon, nbsrf)   ! flux solaire absorb. pour chaque sous surface
1040c Le rayonnement n'est pas calcule tous les pas, il faut donc
1041c                      sauvegarder les sorties du rayonnement
1042cym      SAVE  heat,cool,albpla,topsw,toplw,solsw,sollw,sollwdown
1043cym      SAVE  sollwdownclr, toplwdown, toplwdownclr
1044cym      SAVE  topsw0,toplw0,solsw0,sollw0, heat0, cool0
1045c
1046      INTEGER itaprad
1047      SAVE itaprad
1048c$OMP THREADPRIVATE(itaprad)
1049c
1050      REAL conv_q(klon,klev) ! convergence de l'humidite (kg/kg/s)
1051      REAL conv_t(klon,klev) ! convergence de la temperature(K/s)
1052c
1053      REAL cldl(klon),cldm(klon),cldh(klon) !nuages bas, moyen et haut
1054      REAL cldt(klon),cldq(klon) !nuage total, eau liquide integree
1055c
1056      REAL zxtsol(klon), zxqsurf(klon), zxsnow(klon), zxfluxlat(klon)
1057c
1058      REAL dist, rmu0(klon), fract(klon)
1059      REAL zdtime, zlongi
1060c
1061      CHARACTER*2 str2
1062      CHARACTER*2 iqn
1063c
1064      REAL qcheck
1065      REAL z_avant(klon), z_apres(klon), z_factor(klon)
1066      LOGICAL zx_ajustq
1067c
1068      REAL za, zb
1069      REAL zx_t, zx_qs, zdelta, zcor, zfra, zlvdcp, zlsdcp
1070      real zqsat(klon,klev)
1071      INTEGER i, k, iq, ig, j, nsrf, ll, l, iiq
1072      REAL t_coup
1073      PARAMETER (t_coup=234.0)
1074c
1075      REAL zphi(klon,klev)
1076cym A voir plus tard !!
1077cym      REAL zx_relief(iim,jjmp1)
1078cym      REAL zx_aire(iim,jjmp1)
1079c
1080cIM cf. AM Variables locales pour la CLA (hbtm2)
1081c
1082      REAL,SAVE,ALLOCATABLE :: pblh(:, :)           ! Hauteur de couche limite
1083c$OMP THREAPRIVATE(pblh)
1084      REAL,SAVE,ALLOCATABLE :: plcl(:, :)           ! Niveau de condensation de la CLA
1085c$OMP THREAPRIVATE(plcl)
1086      REAL,SAVE,ALLOCATABLE :: capCL(:, :)          ! CAPE de couche limite
1087c$OMP THREAPRIVATE(capCL)
1088      REAL,SAVE,ALLOCATABLE :: oliqCL(:, :)          ! eau_liqu integree de couche limite
1089c$OMP THREAPRIVATE(oliqCL)
1090      REAL,SAVE,ALLOCATABLE :: cteiCL(:, :)          ! cloud top instab. crit. couche limite
1091c$OMP THREAPRIVATE(cteiCL)
1092      REAL,SAVE,ALLOCATABLE :: pblt(:, :)          ! T a la Hauteur de couche limite
1093c$OMP THREAPRIVATE(pblt)
1094      REAL,SAVE,ALLOCATABLE :: therm(:, :)
1095c$OMP TREADPRIVATE(therm)
1096      REAL,SAVE,ALLOCATABLE :: trmb1(:, :)          ! deep_cape
1097c$OMP TREADPRIVATE(trmb1)
1098      REAL,SAVE,ALLOCATABLE :: trmb2(:, :)          ! inhibition
1099c$OMP TREADPRIVATE(trmb2)
1100      REAL,SAVE,ALLOCATABLE :: trmb3(:, :)          ! Point Omega
1101c$OMP TREADPRIVATE(trmb3)
1102c Grdeurs de sorties
1103      REAL s_pblh(klon), s_lcl(klon), s_capCL(klon)
1104      REAL s_oliqCL(klon), s_cteiCL(klon), s_pblt(klon)
1105      REAL s_therm(klon), s_trmb1(klon), s_trmb2(klon)
1106      REAL s_trmb3(klon)
1107cKE43
1108c Variables locales pour la convection de K. Emanuel (sb):
1109c
1110      REAL upwd(klon,klev)      ! saturated updraft mass flux
1111      REAL dnwd(klon,klev)      ! saturated downdraft mass flux
1112      REAL dnwd0(klon,klev)     ! unsaturated downdraft mass flux
1113      REAL tvp(klon,klev)       ! virtual temp of lifted parcel
1114      REAL,allocatable,save :: cape(:)           ! CAPE
1115c$OMP THREADPRIVATE(cape)
1116cym      SAVE cape
1117      CHARACTER*40 capemaxcels  !max(CAPE)
1118
1119      REAL,allocatable,save :: pbase(:)          ! cloud base pressure
1120c$OMP THREADPRIVATE(pbase)
1121cym      SAVE pbase
1122      REAL,allocatable,save :: bbase(:)          ! cloud base buoyancy
1123c$OMP THREADPRIVATE(bbase)
1124cym      SAVE bbase
1125      REAL rflag(klon)          ! flag fonctionnement de convect
1126      INTEGER iflagctrl(klon)          ! flag fonctionnement de convect
1127c -- convect43:
1128      INTEGER ntra              ! nb traceurs pour convect4.3
1129      REAL pori_con(klon)    ! pressure at the origin level of lifted parcel
1130      REAL plcl_con(klon),dtma_con(klon),dtlcl_con(klon)
1131      REAL dtvpdt1(klon,klev), dtvpdq1(klon,klev)
1132      REAL dplcldt(klon), dplcldr(klon)
1133c?     .     condm_con(klon,klev),conda_con(klon,klev),
1134c?     .     mr_con(klon,klev),ep_con(klon,klev)
1135c?     .    ,sadiab(klon,klev),wadiab(klon,klev)
1136c --
1137c34EK
1138c
1139c Variables du changement
1140c
1141c con: convection
1142c lsc: condensation a grande echelle (Large-Scale-Condensation)
1143c ajs: ajustement sec
1144c eva: evaporation de l'eau liquide nuageuse
1145c vdf: couche limite (Vertical DiFfusion)
1146      REAL d_t_con(klon,klev),d_q_con(klon,klev)
1147      REAL,SAVE,ALLOCATABLE :: d_u_con(:,:),d_v_con(:,:)
1148c$OMP THREADPRIVATE(d_u_con,d_v_con)
1149      REAL d_t_lsc(klon,klev),d_q_lsc(klon,klev),d_ql_lsc(klon,klev)
1150      REAL d_t_ajs(klon,klev), d_q_ajs(klon,klev)
1151      REAL d_u_ajs(klon,klev), d_v_ajs(klon,klev)
1152      REAL d_t_eva(klon,klev),d_q_eva(klon,klev)
1153      REAL d_t_oli(klon,klev) !tendances dues a oro et lif
1154      REAL rneb(klon,klev)
1155c
1156*********************************************************
1157*     declarations
1158      real,save,allocatable :: zqasc(:,:)
1159c$OMP THREADPRIVATE(zqasc)
1160cym      save zqasc
1161     
1162*********************************************************
1163cIM 081204 END
1164c
1165      REAL pmfu(klon,klev), pmfd(klon,klev)
1166      REAL pen_u(klon,klev), pen_d(klon,klev)
1167      REAL pde_u(klon,klev), pde_d(klon,klev)
1168      INTEGER kcbot(klon), kctop(klon), kdtop(klon)
1169      REAL pmflxr(klon,klev+1), pmflxs(klon,klev+1)
1170      REAL prfl(klon,klev+1), psfl(klon,klev+1)
1171c
1172      INTEGER,allocatable,save :: ibas_con(:), itop_con(:)
1173c$OMP THREADPRIVATE(ibas_con,itop_con)
1174cym
1175cym      SAVE ibas_con,itop_con
1176cym
1177      REAL,SAVE,ALLOCATABLE :: rain_con(:)
1178c$OMP THREADPRIVATE(rain_con)
1179      REAL rain_lsc(klon)
1180      REAL,SAVE,ALLOCATABLE :: snow_con(:)
1181c$OMP THREADPRIVATE(snow_con)
1182      REAL snow_lsc(klon)
1183      REAL d_ts(klon,nbsrf)
1184c
1185      REAL d_u_vdf(klon,klev), d_v_vdf(klon,klev)
1186      REAL d_t_vdf(klon,klev), d_q_vdf(klon,klev)
1187c
1188      REAL d_u_oro(klon,klev), d_v_oro(klon,klev)
1189      REAL d_t_oro(klon,klev)
1190      REAL d_u_lif(klon,klev), d_v_lif(klon,klev)
1191      REAL d_t_lif(klon,klev)
1192      REAL d_u_oli(klon,klev), d_v_oli(klon,klev) !tendances dues a oro et lif
1193
1194      REAL,allocatable,save :: ratqs(:,:)
1195c$OMP THREADPRIVATE(ratqs)
1196      REAL ratqss(klon,klev),ratqsc(klon,klev)
1197      real ratqsbas,ratqshaut
1198cym      save ratqsbas,ratqshaut, ratqs
1199      save ratqsbas,ratqshaut
1200c$OMP THREADPRIVATE(ratqsbas,ratqshaut)
1201      real zpt_conv(klon,klev)
1202
1203c Parametres lies au nouveau schema de nuages (SB, PDF)
1204      real fact_cldcon
1205      real facttemps
1206      logical ok_newmicro
1207      save ok_newmicro
1208c$OMP THREADPRIVATE(ok_newmicro)
1209      save fact_cldcon,facttemps
1210c$OMP THREADPRIVATE(fact_cldcon,facttemps)
1211      real facteur
1212
1213      integer iflag_cldcon
1214      save iflag_cldcon
1215c$OMP THREADPRIVATE(iflag_cldcon)
1216      logical ptconv(klon,klev)
1217cIM cf. AM 081204 BEG
1218      logical ptconvth(klon,klev)
1219cIM cf. AM 081204 END
1220c
1221c Variables liees a l'ecriture de la bande histoire physique
1222c
1223c======================================================================
1224c
1225cIM cf. AM 081204 BEG
1226c   declarations pour sortir sur une sous-region
1227      integer imin_ins,imax_ins,jmin_ins,jmax_ins
1228      save imin_ins,imax_ins,jmin_ins,jmax_ins
1229c$OMP THREADPRIVATE(imin_ins,imax_ins,jmin_ins,jmax_ins)
1230c      real lonmin_ins,lonmax_ins,latmin_ins
1231c     s  ,latmax_ins
1232c     data lonmin_ins,lonmax_ins,latmin_ins
1233c    s  ,latmax_ins/
1234c valeurs initiales     s   -5.,20.,41.,55./   
1235c    s   100.,130.,-20.,20./
1236c    s   -180.,180.,-90.,90./
1237c======================================================================
1238cIM cf. AM 081204 END
1239
1240c
1241      integer itau_w   ! pas de temps ecriture = itap + itau_phy
1242c
1243c
1244c Variables locales pour effectuer les appels en serie
1245c
1246      REAL t_seri(klon,klev), q_seri(klon,klev)
1247      REAL ql_seri(klon,klev),qs_seri(klon,klev)
1248      REAL u_seri(klon,klev), v_seri(klon,klev)
1249c
1250      REAL tr_seri(klon,klev,nbtr)
1251      REAL d_tr(klon,klev,nbtr)
1252
1253      REAL zx_rh(klon,klev)
1254cIM RH a 2m (la surface)
1255      REAL rh2m(klon), qsat2m(klon)
1256      REAL zx_rh2m(klon,nbsrf), zx_qsat2m(klon,nbsrf)
1257      REAL zx_qs1(klon,nbsrf), zx_t1(klon,nbsrf), zdelta1(klon,nbsrf)
1258      REAL zcor1(klon,nbsrf)
1259      REAL tpot(klon), tpote(klon)
1260      REAL Lheat
1261
1262      INTEGER        length
1263      PARAMETER    ( length = 100 )
1264      REAL tabcntr0( length       )
1265c
1266
1267      INTEGER ndex2d(iim*jjmp1),ndex3d(iim*jjmp1*klev)
1268cIM
1269      INTEGER ndex2d1(iwmax)
1270c
1271cIM AMIP2 BEG
1272      REAL moyglo, mountor
1273cIM 141004 BEG
1274      REAL zustrdr(klon), zvstrdr(klon)
1275      REAL zustrli(klon), zvstrli(klon)
1276      REAL zustrph(klon), zvstrph(klon)
1277      REAL aam, torsfc
1278cIM 141004 END
1279cIM 190504 BEG
1280      INTEGER ij, imp1jmp1
1281      PARAMETER(imp1jmp1=(iim+1)*jjmp1)
1282cym A voir plus tard
1283      REAL zx_tmp(imp1jmp1), airedyn(iim+1,jjmp1)
1284      REAL padyn(iim+1,jjmp1,klev+1)
1285      REAL dudyn(iim+1,jjmp1,klev)
1286      REAL rlatdyn(iim+1,jjmp1)
1287cIM 190504 END
1288      LOGICAL ok_msk
1289      REAL msk(klon)
1290cIM
1291      REAL airetot, pi
1292cym A voir plus tard
1293cym      REAL zm_wo(jjmp1, klev)
1294cIM AMIP2 END
1295c
1296      REAL zx_tmp_fi2d(klon)      ! variable temporaire grille physique
1297      REAL zx_tmp_fi3d(klon,klev) ! variable temporaire pour champs 3D
1298#ifdef histmthNMC
1299cym   A voir plus tard !!!!
1300cym      REAL zx_tmp_NC(iim,jjmp1,nlevSTD)
1301      REAL zx_tmp_fiNC(klon,nlevSTD)
1302#endif
1303      REAL*8 zx_tmp2_fi3d(klon,klev) ! variable temporaire pour champs 3D
1304      REAL zx_tmp_2d(iim,jjmp1), zx_tmp_3d(iim,jjmp1,klev)
1305      REAL zx_lon(iim,jjmp1), zx_lat(iim,jjmp1)
1306c
1307      INTEGER nid_day, nid_mth, nid_ins, nid_nmc, nid_day_seri
1308      INTEGER nid_ctesGCM
1309      SAVE nid_day, nid_mth, nid_ins, nid_nmc, nid_day_seri
1310      SAVE nid_ctesGCM
1311c$OMP THREADPRIVATE(nid_day, nid_mth, nid_ins, nid_nmc, nid_day_seri,nid_ctesGCM)
1312c
1313cIM 280405 BEG
1314      INTEGER nid_bilKPins, nid_bilKPave
1315      SAVE nid_bilKPins, nid_bilKPave
1316c$OMP THREADPRIVATE(nid_bilKPins, nid_bilKPave)
1317c
1318      REAL ve_lay(klon,klev) ! transport meri. de l'energie a chaque niveau vert.
1319      REAL vq_lay(klon,klev) ! transport meri. de l'eau a chaque niveau vert.
1320      REAL ue_lay(klon,klev) ! transport zonal de l'energie a chaque niveau vert.
1321      REAL uq_lay(klon,klev) ! transport zonal de l'eau a chaque niveau vert.
1322c
1323cIM 280405 END
1324c
1325      INTEGER nhori, nvert, nvert1, nvert3
1326      REAL zsto, zsto1, zsto2
1327      REAL zstophy, zstorad, zstohf, zstoday, zstomth, zout
1328      REAL zcals(napisccp), zcalh(napisccp), zoutj(napisccp)
1329      REAL zout_isccp(napisccp)
1330      SAVE zcals, zcalh, zoutj, zout_isccp
1331c$OMP THREADPRIVATE(zcals, zcalh, zoutj, zout_isccp)
1332
1333      real zjulian
1334      save zjulian
1335c$OMP THREADPRIVATE(zjulian)
1336
1337      character*20 modname
1338      character*80 abort_message
1339      logical ok_sync
1340      real date0
1341      integer idayref
1342
1343C essai writephys
1344      integer fid_day, fid_mth, fid_ins
1345      parameter (fid_ins = 1, fid_day = 2, fid_mth = 3)
1346      integer prof2d_on, prof3d_on, prof2d_av, prof3d_av
1347      parameter (prof2d_on = 1, prof3d_on = 2,
1348     .           prof2d_av = 3, prof3d_av = 4)
1349      character*30 nom_fichier
1350      character*10 varname
1351      character*40 vartitle
1352      character*20 varunits
1353C     Variables liees au bilan d'energie et d'enthalpi
1354      REAL ztsol(klon)
1355      REAL      h_vcol_tot, h_dair_tot, h_qw_tot, h_ql_tot
1356     $        , h_qs_tot, qw_tot, ql_tot, qs_tot , ec_tot
1357      SAVE      h_vcol_tot, h_dair_tot, h_qw_tot, h_ql_tot
1358     $        , h_qs_tot, qw_tot, ql_tot, qs_tot , ec_tot
1359c$OMP THREADPRIVATE(h_vcol_tot, h_dair_tot, h_qw_tot, h_ql_tot,
1360c$OMP+              h_qs_tot, qw_tot, ql_tot, qs_tot , ec_tot)
1361      REAL      d_h_vcol, d_h_dair, d_qt, d_qw, d_ql, d_qs, d_ec
1362      REAL      d_h_vcol_phy
1363      REAL      fs_bound, fq_bound
1364      SAVE      d_h_vcol_phy
1365c$OMP THREADPRIVATE(d_h_vcol_phy)
1366      REAL      zero_v(klon)
1367      CHARACTER*15 ztit
1368      INTEGER   ip_ebil  ! PRINT level for energy conserv. diag.
1369      SAVE      ip_ebil
1370      DATA      ip_ebil/0/
1371c$OMP THREADPRIVATE(ip_ebil)
1372      INTEGER   if_ebil ! level for energy conserv. dignostics
1373      SAVE      if_ebil
1374c$OMP THREADPRIVATE(if_ebil)
1375c+jld ec_conser
1376      REAL d_t_ec(klon,klev)    ! tendance du a la conersion Ec -> E thermique
1377      REAL ZRCPD
1378c-jld ec_conser
1379cIM: t2m, q2m, u10m, v10m et t2mincels, t2maxcels
1380      REAL,SAVE,ALLOCATABLE :: t2m(:,:), q2m(:,:)   !temperature, humidite a 2m
1381c$OMP THREADPRIVATE(t2m,q2m)
1382      REAL,SAVE,ALLOCATABLE :: u10m(:,:), v10m(:,:) !vents a 10m
1383c$OMP THREADPRIVATE(u10m,v10m)
1384      REAL zt2m(klon), zq2m(klon)             !temp., hum. 2m moyenne s/ 1 maille
1385      REAL zu10m(klon), zv10m(klon)           !vents a 10m moyennes s/1 maille
1386      CHARACTER*40 t2mincels, t2maxcels       !t2m min., t2m max
1387      CHARACTER*40 tinst, tave, typeval
1388cjq   Aerosol effects (Johannes Quaas, 27/11/2003)
1389      REAL sulfate(klon, klev) ! SO4 aerosol concentration [ug/m3]
1390      REAL,allocatable,save :: sulfate_pi(:,:) ! SO4 aerosol concentration [ug/m3] (pre-industrial value)
1391c$OMP THREADPRIVATE(sulfate_pi)
1392cym      SAVE sulfate_pi
1393
1394      REAL cldtaupi(klon,klev)  ! Cloud optical thickness for pre-industrial (pi) aerosols
1395
1396      REAL re(klon, klev)       ! Cloud droplet effective radius
1397      REAL fl(klon, klev)  ! denominator of re
1398
1399      REAL re_top(klon), fl_top(klon) ! CDR at top of liquid water clouds
1400
1401      ! Aerosol optical properties
1402      REAL,SAVE,ALLOCATABLE :: tau_ae(:,:,:), piz_ae(:,:,:)
1403c$OMP THREADPRIVATE(tau_ae,piz_ae)
1404      REAL,SAVE,ALLOCATABLE :: cg_ae(:,:,:)
1405c$OMP THREADPRIVATE(cg_ae)
1406
1407      REAL,SAVE,ALLOCATABLE :: topswad(:), solswad(:) ! Aerosol direct effect.
1408c$OMP THREADPRIVATE(topswad,solswad)
1409      ! ok_ade=T -ADE=topswad-topsw
1410
1411      REAL,SAVE,ALLOCATABLE :: topswai(:), solswai(:) ! Aerosol indirect effect.
1412c$OMP THREADPRIVATE(topswai(,solswai)
1413      ! ok_aie=T ->
1414      !        ok_ade=T -AIE=topswai-topswad
1415      !        ok_ade=F -AIE=topswai-topsw
1416
1417      REAL aerindex(klon)       ! POLDER aerosol index
1418     
1419      ! Parameters
1420      LOGICAL ok_ade, ok_aie    ! Apply aerosol (in)direct effects or not
1421      REAL bl95_b0, bl95_b1   ! Parameter in Boucher and Lohmann (1995)
1422cym
1423      SAVE ok_ade, ok_aie, bl95_b0, bl95_b1
1424c$OMP THREADPRIVATE(ok_ade, ok_aie, bl95_b0, bl95_b1)
1425
1426c
1427c Declaration des constantes et des fonctions thermodynamiques
1428c
1429      REAL Field_tmp(klon2,klevp1)
1430      LOGICAL,SAVE :: first=.true.
1431c$OMP THREADPRIVATE(first)
1432#include "YOMCST.h"
1433#include "YOETHF.h"
1434#include "FCTTRE.h"
1435cIM 100106 BEG : pouvoir sortir les ctes de la physique
1436#include "conema3.h"
1437#include "fisrtilp.h"
1438#include "nuage.h"
1439#include "compbl.h"
1440cIM 100106 END : pouvoir sortir les ctes de la physique
1441c
1442c======================================================================
1443
1444cym => necessaire pour iflag_con != 2   
1445      pmfd(:,:) = 0.
1446      pen_u(:,:) = 0.
1447      pen_d(:,:) = 0.
1448      pde_d(:,:) = 0.
1449      pde_u(:,:) = 0.
1450      aam=0.
1451      torsfc=0.
1452cym => pour le couple ocean => revoir dans clmain/intersurf
1453      fluxg(:)=0.
1454      fluxo(:)=0.     
1455
1456      if (first) then
1457     
1458      allocate( t_ancien(klon,klev), q_ancien(klon,klev))
1459      allocate( q2(klon,klev+1,nbsrf))
1460      allocate( swdn0(klon,klevp1), swdn(klon,klevp1))
1461      allocate( swup0(klon,klevp1), swup(klon,klevp1))
1462      allocate( SWdn200clr(klon), SWdn200(klon))
1463      allocate( SWup200clr(klon), SWup200(klon))
1464      allocate( lwdn0(klon,klevp1), lwdn(klon,klevp1))
1465      allocate( lwup0(klon,klevp1), lwup(klon,klevp1))
1466      allocate( LWdn200clr(klon), LWdn200(klon))
1467      allocate( LWup200clr(klon), LWup200(klon))
1468      allocate( LWdnTOA(klon), LWdnTOAclr(klon))
1469      allocate( radsol(klon))
1470      allocate( rlat(klon))
1471      allocate( rlon(klon))
1472      allocate( ftsol(klon,nbsrf))
1473      allocate( ftsoil(klon,nsoilmx,nbsrf))
1474      allocate( fevap(klon,nbsrf))
1475      allocate( fluxlat(klon,nbsrf))
1476      allocate( deltat(klon))
1477      allocate( fqsurf(klon,nbsrf))
1478      allocate( qsol(klon))
1479      allocate( fsnow(klon,nbsrf))
1480      allocate( falbe(klon,nbsrf))
1481      allocate( falblw(klon,nbsrf))
1482      allocate( zmea(klon))
1483      allocate( zstd(klon))
1484      allocate( zsig(klon))
1485      allocate( zgam(klon))
1486      allocate( zthe(klon))
1487      allocate( zpic(klon))
1488      allocate( zval(klon))
1489      allocate( rugoro(klon))
1490      allocate( zuthe(klon),zvthe(klon))
1491      allocate( agesno(klon,nbsrf))
1492      allocate( alb_neig(klon))
1493      allocate( run_off_lic_0(klon))
1494      allocate( ema_workcbmf(klon))   
1495      allocate( ema_cbmf(klon))
1496      allocate( ema_pcb(klon))
1497      allocate( ema_pct(klon)) 
1498      allocate( Ma(klon,klev) )
1499      allocate( qcondc(klon,klev)) 
1500      allocate( ema_work1(klon, klev), ema_work2(klon, klev))
1501      allocate( wd(klon) )
1502      allocate( pfrac_impa(klon,klev))
1503      allocate( pfrac_nucl(klon,klev))
1504      allocate( pfrac_1nucl(klon,klev))
1505      allocate( rain_fall(klon) )
1506      allocate( snow_fall(klon) )
1507      allocate( total_rain(klon), nday_rain(klon))
1508      allocate( dlw(klon)   )
1509      allocate( fder(klon) )
1510      allocate( frugs(klon,nbsrf) )
1511      allocate( pctsrf(klon,nbsrf))
1512      allocate( albsol(klon))
1513      allocate( albsollw(klon))
1514      allocate( wo(klon,klev))
1515      allocate( clwcon(klon,klev),rnebcon(klon,klev))
1516      allocate( heat(klon,klev)    )
1517      allocate( heat0(klon,klev)  )
1518      allocate( cool(klon,klev)    )
1519      allocate( cool0(klon,klev)   )
1520      allocate( topsw(klon), toplw(klon), solsw(klon), sollw(klon))
1521      allocate( sollwdown(klon)    )
1522      allocate( sollwdownclr(klon)  )
1523      allocate( toplwdown(klon)      )
1524      allocate( toplwdownclr(klon)   )
1525      allocate( topsw0(klon), toplw0(klon), solsw0(klon), sollw0(klon))
1526      allocate( albpla(klon))
1527      allocate( cape(klon)   )       
1528      allocate( pbase(klon)   )     
1529      allocate( bbase(klon)    )     
1530      allocate( ibas_con(klon), itop_con(klon))
1531      allocate( ratqs(klon,klev))
1532      allocate( sulfate_pi(klon, klev))
1533      allocate( paire_ter(klon))
1534      allocate(tsumSTD(klon,nlevSTD,nout))
1535      allocate(usumSTD(klon,nlevSTD,nout))
1536      allocate(vsumSTD(klon,nlevSTD,nout))
1537      allocate(wsumSTD(klon,nlevSTD,nout))
1538      allocate(phisumSTD(klon,nlevSTD,nout))
1539      allocate(qsumSTD(klon,nlevSTD,nout))
1540      allocate(rhsumSTD(klon,nlevSTD,nout))
1541      allocate(uvsumSTD(klon,nlevSTD,nout))
1542      allocate(vqsumSTD(klon,nlevSTD,nout))
1543      allocate(vTsumSTD(klon,nlevSTD,nout))
1544      allocate(wqsumSTD(klon,nlevSTD,nout))
1545      allocate( vphisumSTD(klon,nlevSTD,nout))
1546      allocate( wTsumSTD(klon,nlevSTD,nout))
1547      allocate( u2sumSTD(klon,nlevSTD,nout))
1548      allocate( v2sumSTD(klon,nlevSTD,nout))
1549      allocate( T2sumSTD(klon,nlevSTD,nout))
1550      allocate( seed_old(klon,napisccp))
1551      allocate( pct_ocean(klon,nbregdyn))
1552      allocate( rlonPOS(klon))
1553      allocate( newsst(klon))
1554      allocate( zqasc(klon,klev))
1555      allocate( therm(klon, nbsrf))
1556      allocate( rain_con(klon))
1557      allocate( pblt(klon, nbsrf))
1558      allocate( t2m(klon,nbsrf), q2m(klon,nbsrf) ) 
1559      allocate( u10m(klon,nbsrf), v10m(klon,nbsrf))
1560      allocate( topswad(klon), solswad(klon))
1561      allocate( topswai(klon), solswai(klon) )
1562      allocate( ffonte(klon,nbsrf))
1563      allocate( fqcalving(klon,nbsrf))
1564      allocate( fqfonte(klon,nbsrf))
1565      allocate( pblh(klon, nbsrf))
1566      allocate( plcl(klon, nbsrf)) 
1567      allocate( capCL(klon, nbsrf))   
1568      allocate( oliqCL(klon, nbsrf))       
1569      allocate( cteiCL(klon, nbsrf))       
1570      allocate( trmb1(klon, nbsrf))   
1571      allocate( trmb2(klon, nbsrf))     
1572      allocate( trmb3(klon, nbsrf))
1573      allocate( clwcon0(klon,klev),rnebcon0(klon,klev))
1574      allocate( tau_ae(klon,klev,2), piz_ae(klon,klev,2))
1575      allocate( cg_ae(klon,klev,2))
1576      allocate( snow_con(klon))
1577      allocate( tnondef(klon,nlevSTD,nout))
1578      allocate( d_u_con(klon,klev),d_v_con(klon,klev))           
1579     
1580     
1581        paire_ter(:)=0.   
1582        clwcon(:,:)=0.
1583        rnebcon(:,:)=0.
1584        ratqs(:,:)=0.
1585        run_off_lic_0(:)=0.
1586        sollw(:)=0.
1587        ema_work1(:,:)=0.
1588        ema_work2(:,:)=0.
1589cym Attention pbase pas initialise dans concvl !!!!
1590        pbase(:)=0
1591       
1592        first=.false.
1593      endif
1594
1595                 
1596       modname = 'physiq'
1597cIM
1598      IF (ip_ebil_phy.ge.1) THEN
1599        DO i=1,klon
1600          zero_v(i)=0.
1601        END DO
1602      END IF
1603      ok_sync=.TRUE.
1604      IF (nqmax .LT. 2) THEN
1605         abort_message = 'eaux vapeur et liquide sont indispensables'
1606         CALL abort_gcm (modname,abort_message,1)
1607      ENDIF
1608      IF (debut) THEN
1609         CALL suphec ! initialiser constantes et parametres phys.
1610      ENDIF
1611
1612
1613c======================================================================
1614      xjour = rjourvrai
1615c
1616c Si c'est le debut, il faut initialiser plusieurs choses
1617c          ********
1618c
1619       IF (debut) THEN
1620C
1621!rv
1622         u10m(:,:)=0.
1623         v10m(:,:)=0.
1624         t2m(:,:)=0.
1625         q2m(:,:)=0.
1626         ffonte(:,:)=0.
1627         fqcalving(:,:)=0.
1628         fqfonte(:,:)=0.
1629         piz_ae(:,:,:)=0.
1630         tau_ae(:,:,:)=0.
1631         cg_ae(:,:,:)=0.
1632         rain_con(:)=0.
1633         snow_con(:)=0.
1634         bl95_b0=0.
1635         bl95_b1=0.
1636         topswai(:)=0.
1637         topswad(:)=0.
1638         solswai(:)=0.
1639         solswad(:)=0.
1640!rv
1641! anne
1642         d_u_con(:,:) = 0.0
1643         d_v_con(:,:) = 0.0
1644         rnebcon0(:,:) = 0.0
1645         clwcon0(:,:) = 0.0
1646         rnebcon(:,:) = 0.0
1647         clwcon(:,:) = 0.0
1648         paire_ter(:) = 0.0
1649c        nhistoW(:,:,:,:) = 0.0
1650c        histoW(:,:,:,:) = 0.0
1651! fin anne
1652! Anne 12/09/2005
1653
1654         pblh(:,:)   =0.        ! Hauteur de couche limite
1655         plcl(:,:)   =0.        ! Niveau de condensation de la CLA
1656         capCL(:,:)  =0.        ! CAPE de couche limite
1657         oliqCL(:,:) =0.        ! eau_liqu integree de couche limite
1658         cteiCL(:,:) =0.        ! cloud top instab. crit. couche limite
1659         pblt(:,:)   =0.        ! T a la Hauteur de couche limite
1660         therm(:,:)  =0.
1661         trmb1(:,:)  =0.        ! deep_cape
1662         trmb2(:,:)  =0.        ! inhibition
1663         trmb3(:,:)  =0.        ! Point Omega
1664! fin Anne
1665
1666cym
1667         wfbils(:,:)=0
1668cym     
1669cIM     
1670         IF (ip_ebil_phy.ge.1) d_h_vcol_phy=0.
1671c
1672c appel a la lecture du run.def physique
1673c
1674         call conf_phys(ocean, ok_veget, ok_journe, ok_mensuel,
1675     .                  ok_instan, fact_cldcon, facttemps,ok_newmicro,
1676cIM  .                  iflag_cldcon,ratqsbas,ratqshaut, if_ebil,
1677     .                  iflag_cldcon,ratqsbas,ratqshaut,
1678     .                  ok_ade, ok_aie,
1679     .                  bl95_b0, bl95_b1,
1680     .                  iflag_thermals,nsplit_thermals)
1681
1682c
1683c
1684c Initialiser les compteurs:
1685c
1686
1687         frugs = 0.
1688         itap    = 0
1689         itaprad = 0
1690         CALL phyetat0 ("startphy.nc",dtime,co2_ppm_etat0,solaire_etat0,
1691     .       rlat,rlon,pctsrf, ftsol,ftsoil,
1692cIM "slab" ocean
1693     .       ocean, tslab,seaice,
1694     .       fqsurf,qsol,fsnow,
1695cIM 220306  .       falbe, falblw, fevap, rain_fall,snow_fall,solsw, sollwdown,
1696     .       falbe, falblw, fevap, rain_fall,snow_fall,solsw, sollw,
1697     .       dlw,radsol,frugs,agesno,clesphy0,
1698     .       zmea,zstd,zsig,zgam,zthe,zpic,zval,rugoro,tabcntr0,
1699     .       t_ancien, q_ancien, ancien_ok, rnebcon, ratqs,clwcon,
1700     .       run_off_lic_0)
1701
1702       DO i=1,klon
1703         IF ( abs( pctsrf(i, is_ter) + pctsrf(i, is_lic) +
1704     $       pctsrf(i, is_oce) + pctsrf(i, is_sic)  - 1.) .GT. EPSFRA)
1705     $       THEN
1706             WRITE(*,*) 'physiq : pb sous surface au point ', i,
1707     $           pctsrf(i, 1 : nbsrf)
1708         ENDIF
1709      ENDDO
1710 
1711c   ATTENTION : il faudra a terme relire q2 dans l'etat initial
1712         q2(:,:,:)=1.e-8
1713c
1714         radpas = NINT( 86400./dtime/nbapp_rad)
1715c
1716C on remet le calendrier a zero
1717c
1718         IF (raz_date .eq. 1) THEN
1719           itau_phy = 0
1720         ENDIF
1721
1722cIM cf. AM 081204 BEG
1723         PRINT*,'cycle_diurne3 =',cycle_diurne
1724cIM cf. AM 081204 END
1725c
1726         IF(ocean.NE.'force ') THEN
1727          ok_ocean=.TRUE.
1728         ENDIF
1729c
1730         CALL printflag( tabcntr0,radpas,ok_ocean,ok_oasis ,ok_journe,
1731     ,                    ok_instan, ok_region )
1732c
1733         IF (ABS(dtime-pdtphys).GT.0.001) THEN
1734            WRITE(lunout,*) 'Pas physique n est pas correct',dtime,
1735     .                        pdtphys
1736            abort_message='Pas physique n est pas correct '
1737            call abort_gcm(modname,abort_message,1)
1738         ENDIF
1739         IF (nlon .NE. klon) THEN
1740            WRITE(lunout,*)'nlon et klon ne sont pas coherents', nlon,
1741     .                      klon
1742            abort_message='nlon et klon ne sont pas coherents'
1743            call abort_gcm(modname,abort_message,1)
1744         ENDIF
1745         IF (nlev .NE. klev) THEN
1746            WRITE(lunout,*)'nlev et klev ne sont pas coherents', nlev,
1747     .                       klev
1748            abort_message='nlev et klev ne sont pas coherents'
1749            call abort_gcm(modname,abort_message,1)
1750         ENDIF
1751c
1752         IF (dtime*FLOAT(radpas).GT.21600..AND.cycle_diurne) THEN
1753           WRITE(lunout,*)'Nbre d appels au rayonnement insuffisant'
1754           WRITE(lunout,*)"Au minimum 4 appels par jour si cycle diurne"
1755           abort_message='Nbre d appels au rayonnement insuffisant'
1756           call abort_gcm(modname,abort_message,1)
1757         ENDIF
1758         WRITE(lunout,*)"Clef pour la convection, iflag_con=", iflag_con
1759         WRITE(lunout,*)"Clef pour le driver de la convection, ok_cvl=",
1760     .                   ok_cvl
1761c
1762cKE43
1763c Initialisation pour la convection de K.E. (sb):
1764         IF (iflag_con.GE.3) THEN
1765
1766         WRITE(lunout,*)"*** Convection de Kerry Emanuel 4.3  "
1767         WRITE(lunout,*)
1768     .      "On va utiliser le melange convectif des traceurs qui"
1769         WRITE(lunout,*)"est calcule dans convect4.3"
1770         WRITE(lunout,*)" !!! penser aux logical flags de phytrac"
1771
1772          DO i = 1, klon
1773           ema_cbmf(i) = 0.
1774           ema_pcb(i)  = 0.
1775           ema_pct(i)  = 0.
1776           ema_workcbmf(i) = 0.
1777          ENDDO
1778cIM15/11/02 rajout initialisation ibas_con,itop_con cf. SB =>BEG
1779          DO i = 1, klon
1780           ibas_con(i) = 1
1781           itop_con(i) = 1
1782          ENDDO
1783cIM15/11/02 rajout initialisation ibas_con,itop_con cf. SB =>END
1784
1785         ENDIF
1786
1787c34EK
1788         IF (ok_orodr) THEN
1789         DO i=1,klon
1790         rugoro(i) = MAX(1.0e-05, zstd(i)*zsig(i)/2.0)
1791         ENDDO
1792         CALL SUGWD(klon,klev,paprs,pplay)
1793         DO i=1,klon
1794         zuthe(i)=0.
1795         zvthe(i)=0.
1796         if(zstd(i).gt.10.)then
1797           zuthe(i)=(1.-zgam(i))*cos(zthe(i))
1798           zvthe(i)=(1.-zgam(i))*sin(zthe(i))
1799         endif
1800         ENDDO
1801         ENDIF
1802c
1803c
1804         lmt_pas = NINT(86400./dtime * 1.0)   ! tous les jours
1805         WRITE(lunout,*)'La frequence de lecture surface est de ',
1806     .                   lmt_pas
1807c
1808cIM200505        ecrit_mth = NINT(86400./dtime *ecritphy)  ! tous les ecritphy jours
1809c        IF (ok_mensuel) THEN
1810c        WRITE(lunout,*)'La frequence de sortie mensuelle est de ',
1811c    .                   ecrit_mth
1812c        ENDIF
1813c        ecrit_day = NINT(86400./dtime *1.0)  ! tous les jours
1814c        IF (ok_journe) THEN
1815c        WRITE(lunout,*)'La frequence de sortie journaliere est de ',
1816c    .                   ecrit_day
1817c        ENDIF
1818cIM 130904 BEG
1819cIM 080205      ecrit_hf = 86400./dtime *0.25  ! toutes les 6h
1820cIM 170305     
1821c        ecrit_hf = 86400./dtime/12.  ! toutes les 2h
1822cIM 230305     
1823cIM200505        ecrit_hf = 86400./dtime *0.25  ! toutes les 6h
1824c
1825cIM200505        ecrit_hf2mth = ecrit_day/ecrit_hf*30
1826c
1827cIM200505        IF (ok_journe) THEN
1828cIM200505        WRITE(lunout,*)'La frequence de sortie hf est de ',
1829cIM200505    .                   ecrit_hf
1830cIM200505        ENDIF
1831cIM 130904 END
1832ccc         ecrit_ins = NINT(86400./dtime *0.5)  ! 2 fois par jour
1833ccc         ecrit_ins = NINT(86400./dtime *0.25)  ! 4 fois par jour
1834c        ecrit_ins = NINT(86400./dtime/48.)  ! a chaque pas de temps ==> PB. dans time_counter pour 1mois
1835c        ecrit_ins = NINT(86400./dtime/12.)  ! toutes les deux heures
1836cIM200505        ecrit_ins = NINT(86400./dtime/8.)  ! toutes les trois heures
1837cIM200505        IF (ok_instan) THEN
1838cIM200505        WRITE(lunout,*)'La frequence de sortie instant. est de ',
1839cIM200505    .                   ecrit_ins
1840cIM200505        ENDIF
1841cIM200505        ecrit_reg = NINT(86400./dtime *0.25)  ! 4 fois par jour
1842cIM200505        IF (ok_region) THEN
1843cIM200505        WRITE(lunout,*)'La frequence de sortie region est de ',
1844cIM200505    .                   ecrit_reg
1845cIM200505        ENDIF
1846cIM 030306 BEG
1847cIM ecrit_hf2mth = nombre de pas de temps de calcul de hf par mois apres lequel on ecrit
1848cIM : ne pas modifier ecrit_hf2mth
1849c
1850         ecrit_hf2mth = 30*1/ecrit_hf
1851c ecrit_ins en secondes, chaque pas de temps de la physique
1852         ecrit_ins = dtime
1853cIM on passe les frequences de jours en secondes : ecrit_ins, ecrit_hf, ecrit_day, ecrit_mth, ecrit_tra, ecrit_reg
1854         ecrit_hf = ecrit_hf * un_jour
1855         ecrit_day = ecrit_day * un_jour
1856         ecrit_mth = ecrit_mth * un_jour
1857         ecrit_reg = ecrit_reg * un_jour
1858         ecrit_tra = ecrit_tra * un_jour
1859cIM 030306 END
1860c
1861c Initialiser le couplage si necessaire
1862c
1863      npas = 0
1864      nexca = 0
1865      if (ocean == 'couple') then
1866        npas = itaufin/ iphysiq
1867        nexca = 86400 / dtime
1868        write(lunout,*)' ##### Ocean couple #####'
1869        write(lunout,*)' Valeurs des pas de temps'
1870        write(lunout,*)' npas = ', npas
1871        write(lunout,*)' nexca = ', nexca
1872      endif       
1873c
1874      capemaxcels = 't_max(X)'
1875      t2mincels = 't_min(X)'
1876      t2maxcels = 't_max(X)'
1877      tinst = 'inst(X)'
1878      tave = 'ave(X)'
1879cIM cf. AM 081204 BEG
1880      write(lunout,*)'AVANT HIST IFLAG_CON=',iflag_con
1881cIM cf. AM 081204 END
1882c
1883c=============================================================
1884c   Initialisation des sorties
1885c=============================================================
1886
1887#ifdef CPP_IOIPSL
1888
1889#ifdef histhf
1890#include "ini_histhf.h"
1891#endif
1892
1893#ifdef histday
1894#include "ini_histday.h"
1895cIM rajout diagnostiques bilan KP pour analyse MJO par Jun-Ichi Yano
1896c#include "ini_bilKP_ins.h"
1897c#include "ini_bilKP_ave.h"
1898#endif
1899
1900#ifdef histmth
1901#include "ini_histmth.h"
1902#endif
1903
1904#ifdef histins
1905#include "ini_histins.h"
1906#endif
1907
1908#ifdef histISCCP
1909#include "ini_histISCCP.h"
1910#endif
1911
1912#ifdef histmthNMC
1913#include "ini_histmthNMC.h"
1914#endif
1915
1916c#include "ini_histday_seri.h"
1917
1918c#include "ini_paramLMDZ_phy.h"
1919
1920#endif
1921
1922cXXXPB Positionner date0 pour initialisation de ORCHIDEE
1923      date0 = zjulian
1924C      date0 = day_ini
1925      WRITE(*,*) 'physiq date0 : ',date0
1926c
1927c
1928c
1929c Prescrire l'ozone dans l'atmosphere
1930c
1931c
1932cc         DO i = 1, klon
1933cc         DO k = 1, klev
1934cc            CALL o3cm (paprs(i,k)/100.,paprs(i,k+1)/100., wo(i,k),20)
1935cc         ENDDO
1936cc         ENDDO
1937c
1938#ifdef INCA
1939           call VTe(VTphysiq)
1940           call VTb(VTinca)
1941           iii = MOD(NINT(xjour),360)
1942           calday = FLOAT(iii) + gmtime
1943           WRITE(lunout,*) 'initial time ', xjour, calday
1944#ifdef INCAINFO
1945           WRITE(lunout,*) 'Appel CHEMINI ...'
1946#endif
1947           CALL chemini( rpi,
1948     $                   rg,
1949     $                   ra,
1950     $                   airephy,
1951     $                   rlat,
1952     $                   rlon,
1953     $                   presnivs,
1954     $                   calday,
1955     $                   klon,
1956     $                   nqmax,
1957     $                   pdtphys,
1958     $                   annee_ref,
1959     $                   day_ini)
1960#ifdef INCAINFO
1961           WRITE(lunout,*) 'OK.'
1962#endif
1963      call VTe(VTinca)
1964      call VTb(VTphysiq)
1965#endif
1966c
1967      ENDIF
1968c
1969c   ****************     Fin  de   IF ( debut  )   ***************
1970c
1971c
1972c Mettre a zero des variables de sortie (pour securite)
1973c
1974      DO i = 1, klon
1975         d_ps(i) = 0.0
1976      ENDDO
1977      DO k = 1, klev
1978      DO i = 1, klon
1979         d_t(i,k) = 0.0
1980         d_u(i,k) = 0.0
1981         d_v(i,k) = 0.0
1982      ENDDO
1983      ENDDO
1984      DO iq = 1, nqmax
1985      DO k = 1, klev
1986      DO i = 1, klon
1987         d_qx(i,k,iq) = 0.0
1988      ENDDO
1989      ENDDO
1990      ENDDO
1991      da(:,:)=0.
1992      mp(:,:)=0.
1993      phi(:,:,:)=0.
1994c
1995c Ne pas affecter les valeurs entrees de u, v, h, et q
1996c
1997      DO k = 1, klev
1998      DO i = 1, klon
1999         t_seri(i,k)  = t(i,k)
2000         u_seri(i,k)  = u(i,k)
2001         v_seri(i,k)  = v(i,k)
2002         q_seri(i,k)  = qx(i,k,ivap)
2003         ql_seri(i,k) = qx(i,k,iliq)
2004         qs_seri(i,k) = 0.
2005      ENDDO
2006      ENDDO
2007      IF (nqmax.GE.3) THEN
2008      DO iq = 3, nqmax
2009      DO  k = 1, klev
2010      DO  i = 1, klon
2011         tr_seri(i,k,iq-2) = qx(i,k,iq)
2012      ENDDO
2013      ENDDO
2014      ENDDO
2015      ELSE
2016      DO k = 1, klev
2017      DO i = 1, klon
2018         tr_seri(i,k,1) = 0.0
2019      ENDDO
2020      ENDDO
2021      ENDIF
2022C
2023      DO i = 1, klon
2024        ztsol(i) = 0.
2025      ENDDO
2026      DO nsrf = 1, nbsrf
2027        DO i = 1, klon
2028          ztsol(i) = ztsol(i) + ftsol(i,nsrf)*pctsrf(i,nsrf)
2029        ENDDO
2030      ENDDO
2031cIM
2032      IF (ip_ebil_phy.ge.1) THEN
2033        ztit='after dynamic'
2034        CALL diagetpq(airephy,ztit,ip_ebil_phy,1,1,dtime
2035     e      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay
2036     s      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
2037C     Comme les tendances de la physique sont ajoute dans la dynamique,
2038C     on devrait avoir que la variation d'entalpie par la dynamique
2039C     est egale a la variation de la physique au pas de temps precedent.
2040C     Donc la somme de ces 2 variations devrait etre nulle.
2041        call diagphy(airephy,ztit,ip_ebil_phy
2042     e      , zero_v, zero_v, zero_v, zero_v, zero_v
2043     e      , zero_v, zero_v, zero_v, ztsol
2044     e      , d_h_vcol+d_h_vcol_phy, d_qt, 0.
2045     s      , fs_bound, fq_bound )
2046      END IF
2047
2048c Diagnostiquer la tendance dynamique
2049c
2050      IF (ancien_ok) THEN
2051         DO k = 1, klev
2052         DO i = 1, klon
2053            d_t_dyn(i,k) = (t_seri(i,k)-t_ancien(i,k))/dtime
2054            d_q_dyn(i,k) = (q_seri(i,k)-q_ancien(i,k))/dtime
2055         ENDDO
2056         ENDDO
2057      ELSE
2058         DO k = 1, klev
2059         DO i = 1, klon
2060            d_t_dyn(i,k) = 0.0
2061            d_q_dyn(i,k) = 0.0
2062         ENDDO
2063         ENDDO
2064         ancien_ok = .TRUE.
2065      ENDIF
2066c
2067c Ajouter le geopotentiel du sol:
2068c
2069      DO k = 1, klev
2070      DO i = 1, klon
2071         zphi(i,k) = pphi(i,k) + pphis(i)
2072      ENDDO
2073      ENDDO
2074c
2075c Verifier les temperatures
2076c
2077cIM BEG
2078      IF (check) THEN
2079       amn=MIN(ftsol(1,is_ter),1000.)
2080       amx=MAX(ftsol(1,is_ter),-1000.)
2081       DO i=2, klon
2082        amn=MIN(ftsol(i,is_ter),amn)
2083        amx=MAX(ftsol(i,is_ter),amx)
2084       ENDDO
2085c
2086       PRINT*,' debut avant hgardfou min max ftsol',itap,amn,amx
2087      ENDIF !(check) THEN
2088cIM END
2089c
2090      CALL hgardfou(t_seri,ftsol,'debutphy')
2091c
2092cIM BEG
2093      IF (check) THEN
2094       amn=MIN(ftsol(1,is_ter),1000.)
2095       amx=MAX(ftsol(1,is_ter),-1000.)
2096       DO i=2, klon
2097        amn=MIN(ftsol(i,is_ter),amn)
2098        amx=MAX(ftsol(i,is_ter),amx)
2099       ENDDO
2100c
2101       PRINT*,' debut apres hgardfou min max ftsol',itap,amn,amx
2102      ENDIF !(check) THEN
2103cIM END
2104c
2105c Incrementer le compteur de la physique
2106c
2107      itap   = itap + 1
2108      julien = MOD(NINT(xjour),360)
2109      if (julien .eq. 0) julien = 360
2110c
2111c Mettre en action les conditions aux limites (albedo, sst, etc.).
2112c Prescrire l'ozone et calculer l'albedo sur l'ocean.
2113c
2114      IF (MOD(itap-1,lmt_pas) .EQ. 0) THEN
2115         WRITE(lunout,*)' PHYS cond  julien ',julien
2116         CALL ozonecm( FLOAT(julien), rlat, paprs, wo)
2117      ENDIF
2118c
2119c Re-evaporer l'eau liquide nuageuse
2120c
2121      DO k = 1, klev  ! re-evaporation de l'eau liquide nuageuse
2122      DO i = 1, klon
2123         zlvdcp=RLVTT/RCPD/(1.0+RVTMP2*q_seri(i,k))
2124c        zlsdcp=RLSTT/RCPD/(1.0+RVTMP2*q_seri(i,k))
2125         zlsdcp=RLVTT/RCPD/(1.0+RVTMP2*q_seri(i,k))
2126         zdelta = MAX(0.,SIGN(1.,RTT-t_seri(i,k)))
2127         zb = MAX(0.0,ql_seri(i,k))
2128         za = - MAX(0.0,ql_seri(i,k))
2129     .                  * (zlvdcp*(1.-zdelta)+zlsdcp*zdelta)
2130         t_seri(i,k) = t_seri(i,k) + za
2131         q_seri(i,k) = q_seri(i,k) + zb
2132         ql_seri(i,k) = 0.0
2133         d_t_eva(i,k) = za
2134         d_q_eva(i,k) = zb
2135      ENDDO
2136      ENDDO
2137cIM
2138      IF (ip_ebil_phy.ge.2) THEN
2139        ztit='after reevap'
2140        CALL diagetpq(airephy,ztit,ip_ebil_phy,2,1,dtime
2141     e      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay
2142     s      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
2143         call diagphy(airephy,ztit,ip_ebil_phy
2144     e      , zero_v, zero_v, zero_v, zero_v, zero_v
2145     e      , zero_v, zero_v, zero_v, ztsol
2146     e      , d_h_vcol, d_qt, d_ec
2147     s      , fs_bound, fq_bound )
2148C
2149      END IF
2150C
2151c
2152c Appeler la diffusion verticale (programme de couche limite)
2153c
2154      DO i = 1, klon
2155c       if (.not. ok_veget) then
2156c          frugs(i,is_ter) = SQRT(frugs(i,is_ter)**2+rugoro(i)**2)
2157c       endif
2158c         frugs(i,is_lic) = rugoro(i)
2159c         frugs(i,is_oce) = rugmer(i)
2160c         frugs(i,is_sic) = 0.001
2161         zxrugs(i) = 0.0
2162      ENDDO
2163      DO nsrf = 1, nbsrf
2164      DO i = 1, klon
2165c         frugs(i,nsrf) = MAX(frugs(i,nsrf),0.001)
2166        frugs(i,nsrf) = MAX(frugs(i,nsrf),0.000015)
2167      ENDDO
2168      ENDDO
2169      DO nsrf = 1, nbsrf
2170      DO i = 1, klon
2171            zxrugs(i) = zxrugs(i) + frugs(i,nsrf)*pctsrf(i,nsrf)
2172      ENDDO
2173      ENDDO
2174c
2175C calculs necessaires au calcul de l'albedo dans l'interface
2176c
2177      CALL orbite(FLOAT(julien),zlongi,dist)
2178      IF (cycle_diurne) THEN
2179        zdtime=dtime*FLOAT(radpas) ! pas de temps du rayonnement (s)
2180        CALL zenang(zlongi,gmtime,zdtime,rlat,rlon,rmu0,fract)
2181      ELSE
2182        rmu0 = -999.999
2183      ENDIF
2184c
2185C     Calcul de l'abedo moyen par maille
2186      albsol(:)=0.
2187      albsollw(:)=0.
2188      DO nsrf = 1, nbsrf
2189      DO i = 1, klon
2190         albsol(i) = albsol(i) + falbe(i,nsrf) * pctsrf(i,nsrf)
2191         albsollw(i) = albsollw(i) + falblw(i,nsrf) * pctsrf(i,nsrf)
2192      ENDDO
2193      ENDDO
2194C
2195C     Repartition sous maille des flux LW et SW
2196C Modif OM+PASB+JLD
2197C Repartition du longwave par sous-surface linearisee
2198Cn
2199
2200       DO nsrf = 1, nbsrf
2201       DO i = 1, klon
2202c@$$        fsollw(i,nsrf) = sollwdown(i) - RSIGMA*ftsol(i,nsrf)**4
2203c@$$        fsollw(i,nsrf) = sollw(i)
2204         fsollw(i,nsrf) = sollw(i)
2205     $      + 4.0*RSIGMA*ztsol(i)**3 * (ztsol(i)-ftsol(i,nsrf))
2206         fsolsw(i,nsrf) = solsw(i)*(1.-falbe(i,nsrf))/(1.-albsol(i))
2207       ENDDO
2208       ENDDO
2209     
2210cYM   !!!!!!!!!!!!!!!!!!!!!!!!!!!!
2211cYM         Attention verrue
2212cYM    ---> A supprimer plus tard       
2213cYM         pour etre integre dans
2214cYM         ORCHIDEE       
2215      DO i = 1, klon
2216        sollwdown(i)=sollw(i)+RSIGMA*ztsol(i)**4
2217      ENDDO
2218cYM  !!!!!!!!!!!!!!!!!!!!!!!!!!!!!     
2219     
2220      fder = dlw
2221
2222      if (mydebug) then
2223        call writefield_phy('u_seri',u_seri,llm)
2224        call writefield_phy('v_seri',v_seri,llm)
2225        call writefield_phy('t_seri',t_seri,llm)
2226        call writefield_phy('q_seri',q_seri,llm)
2227      endif
2228 
2229      IF (check) THEN
2230       amn=MIN(tslab(1),1000.)
2231       amx=MAX(tslab(1),-1000.)
2232       DO i=2, klon
2233        amn=MIN(tslab(i),amn)
2234        amx=MAX(tslab(i),amx)
2235       ENDDO
2236c
2237       PRINT*,' debut avant clqh min max tslab',amn,amx
2238      ENDIF !(check) THEN
2239c
2240      CALL clmain(dtime,itap,date0,pctsrf,pctsrf_new,
2241     e            t_seri,q_seri,u_seri,v_seri,
2242     e            julien, rmu0, co2_ppm,
2243     e            ok_veget, ocean, npas, nexca, ftsol,
2244     $            soil_model,cdmmax, cdhmax,
2245     $            ksta, ksta_ter, ok_kzmin, ftsoil, qsol,
2246cIM BAD    $            paprs,pplay,radsol, fsnow,fqsurf,fevap,falbe,falblw,
2247     $            paprs,pplay, fsnow,fqsurf,fevap,falbe,falblw,
2248     $            fluxlat,
2249     e            rain_fall, snow_fall,
2250     e            fsolsw, fsollw, sollwdown, fder,
2251     e            rlon, rlat, cuphy, cvphy, frugs,
2252     e            debut, lafin, agesno,rugoro ,
2253     s            d_t_vdf,d_q_vdf,d_u_vdf,d_v_vdf,d_ts,
2254     s            fluxt,fluxq,fluxu,fluxv,cdragh,cdragm,
2255     s            q2,
2256     s            dsens, devap,
2257     s            ycoefh,yu1,yv1, t2m, q2m, u10m, v10m,
2258     s            pblh,capCL,oliqCL,cteiCL,pblT,
2259     s            therm,trmb1,trmb2,trmb3,plcl,
2260     s            fqcalving, fqfonte,ffonte, run_off_lic_0,
2261cIM "slab" ocean
2262     s            fluxo, fluxg, tslab, seaice)
2263c
2264CXXX PB
2265CXXX Incrementation des flux
2266CXXX
2267
2268      zxfluxt=0.
2269      zxfluxq=0.
2270      zxfluxu=0.
2271      zxfluxv=0.
2272      DO nsrf = 1, nbsrf
2273        DO k = 1, klev
2274          DO i = 1, klon
2275            zxfluxt(i,k) = zxfluxt(i,k) +
2276     $          fluxt(i,k,nsrf) * pctsrf( i, nsrf)
2277            zxfluxq(i,k) = zxfluxq(i,k) +
2278     $          fluxq(i,k,nsrf) * pctsrf( i, nsrf)
2279            zxfluxu(i,k) = zxfluxu(i,k) +
2280     $          fluxu(i,k,nsrf) * pctsrf( i, nsrf)
2281            zxfluxv(i,k) = zxfluxv(i,k) +
2282     $          fluxv(i,k,nsrf) * pctsrf( i, nsrf)
2283          END DO
2284        END DO
2285      END DO
2286      DO i = 1, klon
2287         sens(i) = - zxfluxt(i,1) ! flux de chaleur sensible au sol
2288c         evap(i) = - fluxq(i,1) ! flux d'evaporation au sol
2289         evap(i) = - zxfluxq(i,1) ! flux d'evaporation au sol
2290         fder(i) = dlw(i) + dsens(i) + devap(i)
2291      ENDDO
2292
2293
2294      DO k = 1, klev
2295      DO i = 1, klon
2296         t_seri(i,k) = t_seri(i,k) + d_t_vdf(i,k)
2297         q_seri(i,k) = q_seri(i,k) + d_q_vdf(i,k)
2298         u_seri(i,k) = u_seri(i,k) + d_u_vdf(i,k)
2299         v_seri(i,k) = v_seri(i,k) + d_v_vdf(i,k)
2300      ENDDO
2301      ENDDO
2302
2303      if (mydebug) then
2304        call writefield_phy('u_seri',u_seri,llm)
2305        call writefield_phy('v_seri',v_seri,llm)
2306        call writefield_phy('t_seri',t_seri,llm)
2307        call writefield_phy('q_seri',q_seri,llm)
2308      endif
2309
2310
2311cIM
2312      IF (ip_ebil_phy.ge.2) THEN
2313        ztit='after clmain'
2314        CALL diagetpq(airephy,ztit,ip_ebil_phy,2,2,dtime
2315     e      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay
2316     s      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
2317         call diagphy(airephy,ztit,ip_ebil_phy
2318     e      , zero_v, zero_v, zero_v, zero_v, sens
2319     e      , evap  , zero_v, zero_v, ztsol
2320     e      , d_h_vcol, d_qt, d_ec
2321     s      , fs_bound, fq_bound )
2322      END IF
2323C
2324c
2325c Incrementer la temperature du sol
2326c
2327      DO i = 1, klon
2328         zxtsol(i) = 0.0
2329         zxfluxlat(i) = 0.0
2330c
2331         zt2m(i) = 0.0
2332         zq2m(i) = 0.0
2333         zu10m(i) = 0.0
2334         zv10m(i) = 0.0
2335cIM cf JLD ??
2336         zxffonte(i) = 0.0
2337         zxfqcalving(i) = 0.0
2338         zxfqfonte(i) = 0.0
2339cIM cf. AM 081204 BEG
2340c
2341         s_pblh(i) = 0.0
2342         s_lcl(i) = 0.0
2343         s_capCL(i) = 0.0
2344         s_oliqCL(i) = 0.0
2345         s_cteiCL(i) = 0.0
2346         s_pblT(i) = 0.0
2347         s_therm(i) = 0.0
2348         s_trmb1(i) = 0.0
2349         s_trmb2(i) = 0.0
2350         s_trmb3(i) = 0.0
2351c
2352         IF ( abs( pctsrf(i, is_ter) + pctsrf(i, is_lic) +
2353     $       pctsrf(i, is_oce) + pctsrf(i, is_sic)  - 1.) .GT. EPSFRA)
2354     $       THEN
2355             WRITE(*,*) 'physiq : pb sous surface au point ', i,
2356     $           pctsrf(i, 1 : nbsrf)
2357         ENDIF
2358      ENDDO
2359      DO nsrf = 1, nbsrf
2360        DO i = 1, klon
2361c        IF (pctsrf(i,nsrf) .GE. EPSFRA) THEN
2362            ftsol(i,nsrf) = ftsol(i,nsrf) + d_ts(i,nsrf)
2363cIM cf. JLD
2364            wfbils(i,nsrf) = ( fsolsw(i,nsrf) + fsollw(i,nsrf)
2365     $         + fluxt(i,1,nsrf) + fluxlat(i,nsrf) ) * pctsrf(i,nsrf)
2366cIM
2367            wfbilo(i,nsrf) = ( fevap(i,nsrf) -
2368     $      (rain_fall(i) + snow_fall(i)) ) * pctsrf(i,nsrf)
2369            zxtsol(i) = zxtsol(i) + ftsol(i,nsrf)*pctsrf(i,nsrf)
2370            zxfluxlat(i) = zxfluxlat(i) + fluxlat(i,nsrf)*pctsrf(i,nsrf)
2371cccIM
2372            zt2m(i) = zt2m(i) + t2m(i,nsrf)*pctsrf(i,nsrf)
2373            zq2m(i) = zq2m(i) + q2m(i,nsrf)*pctsrf(i,nsrf)
2374            zu10m(i) = zu10m(i) + u10m(i,nsrf)*pctsrf(i,nsrf)
2375            zv10m(i) = zv10m(i) + v10m(i,nsrf)*pctsrf(i,nsrf)
2376cIM cf JLD ??
2377            zxffonte(i) = zxffonte(i) + ffonte(i,nsrf)*pctsrf(i,nsrf)
2378            zxfqcalving(i) = zxfqcalving(i) +
2379     .                      fqcalving(i,nsrf)*pctsrf(i,nsrf)
2380            zxfqfonte(i) = zxfqfonte(i) +
2381     .                      fqfonte(i,nsrf)*pctsrf(i,nsrf)
2382cIM cf. AM 081204 BEG
2383            s_pblh(i) = s_pblh(i) + pblh(i,nsrf)*pctsrf(i,nsrf)
2384            s_lcl(i) = s_lcl(i) + plcl(i,nsrf)*pctsrf(i,nsrf)
2385            s_capCL(i) = s_capCL(i) + capCL(i,nsrf) *pctsrf(i,nsrf)
2386            s_oliqCL(i) = s_oliqCL(i) + oliqCL(i,nsrf) *pctsrf(i,nsrf)
2387            s_cteiCL(i) = s_cteiCL(i) + cteiCL(i,nsrf) *pctsrf(i,nsrf)
2388            s_pblT(i) = s_pblT(i) + pblT(i,nsrf) *pctsrf(i,nsrf)
2389            s_therm(i) = s_therm(i) + therm(i,nsrf) *pctsrf(i,nsrf)
2390            s_trmb1(i) = s_trmb1(i) + trmb1(i,nsrf) *pctsrf(i,nsrf)
2391            s_trmb2(i) = s_trmb2(i) + trmb2(i,nsrf) *pctsrf(i,nsrf)
2392            s_trmb3(i) = s_trmb3(i) + trmb3(i,nsrf) *pctsrf(i,nsrf)
2393c        ENDIF
2394        ENDDO
2395      ENDDO
2396
2397      IF (check) THEN
2398       amn=MIN(ftsol(1,is_ter),1000.)
2399       amx=MAX(ftsol(1,is_ter),-1000.)
2400       DO i=2, klon
2401        amn=MIN(ftsol(i,is_ter),amn)
2402        amx=MAX(ftsol(i,is_ter),amx)
2403       ENDDO
2404c
2405       PRINT*,' debut apres d_ts min max ftsol',itap,amn,amx
2406      ENDIF !(check) THEN
2407c
2408c Si une sous-fraction n'existe pas, elle prend la temp. moyenne
2409c
2410      DO nsrf = 1, nbsrf
2411        DO i = 1, klon
2412          IF (pctsrf(i,nsrf) .LT. epsfra.OR.t2m(i,nsrf).EQ.0.) THEN
2413           ftsol(i,nsrf) = zxtsol(i)
2414           t2m(i,nsrf) = zt2m(i)
2415           q2m(i,nsrf) = zq2m(i)
2416           u10m(i,nsrf) = zu10m(i)
2417           v10m(i,nsrf) = zv10m(i)
2418           ffonte(i,nsrf) = zxffonte(i)
2419           fqcalving(i,nsrf) = zxfqcalving(i)
2420           fqfonte(i,nsrf) = zxfqfonte(i)
2421           pblh(i,nsrf)=s_pblh(i)
2422           plcl(i,nsrf)=s_lcl(i)
2423           capCL(i,nsrf)=s_capCL(i)
2424           oliqCL(i,nsrf)=s_oliqCL(i)
2425           cteiCL(i,nsrf)=s_cteiCL(i)
2426           pblT(i,nsrf)=s_pblT(i)
2427           therm(i,nsrf)=s_therm(i)
2428           trmb1(i,nsrf)=s_trmb1(i)
2429           trmb2(i,nsrf)=s_trmb2(i)
2430           trmb3(i,nsrf)=s_trmb3(i)
2431          ENDIF
2432        ENDDO
2433      ENDDO
2434c
2435c Calculer la derive du flux infrarouge
2436c
2437cXXX      DO nsrf = 1, nbsrf
2438      DO i = 1, klon
2439cXXX        IF (pctsrf(i,nsrf) .GE. EPSFRA) THEN
2440            dlw(i) = - 4.0*RSIGMA*zxtsol(i)**3
2441cXXX     .          *(ftsol(i,nsrf)-zxtsol(i))
2442cXXX     .          *pctsrf(i,nsrf)
2443cXXX        ENDIF
2444cXXX      ENDDO
2445      ENDDO
2446c
2447c Appeler la convection (au choix)
2448c
2449      DO k = 1, klev
2450      DO i = 1, klon
2451         conv_q(i,k) = d_q_dyn(i,k)
2452     .               + d_q_vdf(i,k)/dtime
2453         conv_t(i,k) = d_t_dyn(i,k)
2454     .               + d_t_vdf(i,k)/dtime
2455      ENDDO
2456      ENDDO
2457      IF (check) THEN
2458         za = qcheck(klon,klev,paprs,q_seri,ql_seri,airephy)
2459         WRITE(lunout,*) "avantcon=", za
2460      ENDIF
2461      zx_ajustq = .FALSE.
2462      IF (iflag_con.EQ.2) zx_ajustq=.TRUE.
2463      IF (zx_ajustq) THEN
2464         DO i = 1, klon
2465            z_avant(i) = 0.0
2466         ENDDO
2467         DO k = 1, klev
2468         DO i = 1, klon
2469            z_avant(i) = z_avant(i) + (q_seri(i,k)+ql_seri(i,k))
2470     .                        *(paprs(i,k)-paprs(i,k+1))/RG
2471         ENDDO
2472         ENDDO
2473      ENDIF
2474      IF (iflag_con.EQ.1) THEN
2475          stop'reactiver le call conlmd dans physiq.F'
2476c     CALL conlmd (dtime, paprs, pplay, t_seri, q_seri, conv_q,
2477c    .             d_t_con, d_q_con,
2478c    .             rain_con, snow_con, ibas_con, itop_con)
2479      ELSE IF (iflag_con.EQ.2) THEN
2480      CALL conflx(dtime, paprs, pplay, t_seri, q_seri,
2481     e            conv_t, conv_q, zxfluxq(1,1), omega,
2482     s            d_t_con, d_q_con, rain_con, snow_con,
2483     s            pmfu, pmfd, pen_u, pde_u, pen_d, pde_d,
2484     s            kcbot, kctop, kdtop, pmflxr, pmflxs)
2485      WHERE (rain_con < 0.) rain_con = 0.
2486      WHERE (snow_con < 0.) snow_con = 0.
2487      DO i = 1, klon
2488         ibas_con(i) = klev+1 - kcbot(i)
2489         itop_con(i) = klev+1 - kctop(i)
2490      ENDDO
2491      ELSE IF (iflag_con.GE.3) THEN
2492c nb of tracers for the KE convection:
2493c MAF la partie traceurs est faite dans phytrac
2494c on met ntra=1 pour limiter les appels mais on peut
2495c supprimer les calculs / ftra.
2496              ntra = 1
2497c sb, oct02:
2498c Schema de convection modularise et vectorise:
2499c (driver commun aux versions 3 et 4)
2500c
2501          IF (ok_cvl) THEN ! new driver for convectL
2502
2503          CALL concvl (iflag_con,
2504     .        dtime,paprs,pplay,t_seri,q_seri,
2505     .        u_seri,v_seri,tr_seri,ntra,
2506     .        ema_work1,ema_work2,
2507     .        d_t_con,d_q_con,d_u_con,d_v_con,d_tr,
2508     .        rain_con, snow_con, ibas_con, itop_con,
2509     .        upwd,dnwd,dnwd0,
2510     .        Ma,cape,tvp,iflagctrl,
2511     .        pbase,bbase,dtvpdt1,dtvpdq1,dplcldt,dplcldr,qcondc,wd,
2512     .        pmflxr,pmflxs,
2513     .        da,phi,mp)
2514
2515cIM cf. FH
2516              clwcon0=qcondc
2517              pmfu(:,:)=upwd(:,:)+dnwd(:,:)
2518
2519          ELSE ! ok_cvl
2520c MAF conema3 ne contient pas les traceurs
2521          CALL conema3 (dtime,
2522     .        paprs,pplay,t_seri,q_seri,
2523     .        u_seri,v_seri,tr_seri,ntra,
2524     .        ema_work1,ema_work2,
2525     .        d_t_con,d_q_con,d_u_con,d_v_con,d_tr,
2526     .        rain_con, snow_con, ibas_con, itop_con,
2527     .        upwd,dnwd,dnwd0,bas,top,
2528     .        Ma,cape,tvp,rflag,
2529     .        pbase
2530     .        ,bbase,dtvpdt1,dtvpdq1,dplcldt,dplcldr
2531     .        ,clwcon0)
2532
2533          ENDIF ! ok_cvl
2534
2535c
2536c Correction precip
2537          rain_con = rain_con * cvl_corr
2538          snow_con = snow_con * cvl_corr
2539c
2540
2541           IF (.NOT. ok_gust) THEN
2542           do i = 1, klon
2543            wd(i)=0.0
2544           enddo
2545           ENDIF
2546
2547c =================================================================== c
2548c Calcul des proprietes des nuages convectifs
2549c
2550      DO k = 1, klev
2551      DO i = 1, klon
2552         zx_t = t_seri(i,k)
2553         IF (thermcep) THEN
2554            zdelta = MAX(0.,SIGN(1.,rtt-zx_t))
2555            zx_qs  = r2es * FOEEW(zx_t,zdelta)/pplay(i,k)
2556            zx_qs  = MIN(0.5,zx_qs)
2557            zcor   = 1./(1.-retv*zx_qs)
2558            zx_qs  = zx_qs*zcor
2559         ELSE
2560           IF (zx_t.LT.t_coup) THEN
2561              zx_qs = qsats(zx_t)/pplay(i,k)
2562           ELSE
2563              zx_qs = qsatl(zx_t)/pplay(i,k)
2564           ENDIF
2565         ENDIF
2566         zqsat(i,k)=zx_qs
2567      ENDDO
2568      ENDDO
2569
2570c   calcul des proprietes des nuages convectifs
2571             clwcon0(:,:)=fact_cldcon*clwcon0(:,:)
2572             call clouds_gno
2573     s       (klon,klev,q_seri,zqsat,clwcon0,ptconv,ratqsc,rnebcon0)
2574
2575c =================================================================== c
2576
2577          DO i = 1, klon
2578            ema_pcb(i)  = pbase(i)
2579          ENDDO
2580          DO i = 1, klon
2581            ema_pct(i)  = paprs(i,itop_con(i))
2582          ENDDO
2583          DO i = 1, klon
2584            ema_cbmf(i) = ema_workcbmf(i)
2585          ENDDO     
2586      ELSE
2587          WRITE(lunout,*) "iflag_con non-prevu", iflag_con
2588          CALL abort
2589      ENDIF
2590
2591c     CALL homogene(paprs, q_seri, d_q_con, u_seri,v_seri,
2592c    .              d_u_con, d_v_con)
2593
2594      DO k = 1, klev
2595        DO i = 1, klon
2596         t_seri(i,k) = t_seri(i,k) + d_t_con(i,k)
2597         q_seri(i,k) = q_seri(i,k) + d_q_con(i,k)
2598         u_seri(i,k) = u_seri(i,k) + d_u_con(i,k)
2599         v_seri(i,k) = v_seri(i,k) + d_v_con(i,k)
2600        ENDDO
2601      ENDDO
2602
2603      if (mydebug) then
2604        call writefield_phy('u_seri',u_seri,llm)
2605        call writefield_phy('v_seri',v_seri,llm)
2606        call writefield_phy('t_seri',t_seri,llm)
2607        call writefield_phy('q_seri',q_seri,llm)
2608      endif
2609
2610cIM
2611      IF (ip_ebil_phy.ge.2) THEN
2612        ztit='after convect'
2613        CALL diagetpq(airephy,ztit,ip_ebil_phy,2,2,dtime
2614     e      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay
2615     s      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
2616         call diagphy(airephy,ztit,ip_ebil_phy
2617     e      , zero_v, zero_v, zero_v, zero_v, zero_v
2618     e      , zero_v, rain_con, snow_con, ztsol
2619     e      , d_h_vcol, d_qt, d_ec
2620     s      , fs_bound, fq_bound )
2621      END IF
2622C
2623      IF (check) THEN
2624          za = qcheck(klon,klev,paprs,q_seri,ql_seri,airephy)
2625          WRITE(lunout,*)"aprescon=", za
2626          zx_t = 0.0
2627          za = 0.0
2628          DO i = 1, klon
2629            za = za + airephy(i)/FLOAT(klon)
2630            zx_t = zx_t + (rain_con(i)+
2631     .                   snow_con(i))*airephy(i)/FLOAT(klon)
2632          ENDDO
2633          zx_t = zx_t/za*dtime
2634          WRITE(lunout,*)"Precip=", zx_t
2635      ENDIF
2636      IF (zx_ajustq) THEN
2637          DO i = 1, klon
2638            z_apres(i) = 0.0
2639          ENDDO
2640          DO k = 1, klev
2641            DO i = 1, klon
2642              z_apres(i) = z_apres(i) + (q_seri(i,k)+ql_seri(i,k))
2643     .            *(paprs(i,k)-paprs(i,k+1))/RG
2644            ENDDO
2645          ENDDO
2646          DO i = 1, klon
2647            z_factor(i) = (z_avant(i)-(rain_con(i)+snow_con(i))*dtime)
2648     .          /z_apres(i)
2649          ENDDO
2650          DO k = 1, klev
2651            DO i = 1, klon
2652              IF (z_factor(i).GT.(1.0+1.0E-08) .OR.
2653     .            z_factor(i).LT.(1.0-1.0E-08)) THEN
2654                  q_seri(i,k) = q_seri(i,k) * z_factor(i)
2655              ENDIF
2656            ENDDO
2657          ENDDO
2658      ENDIF
2659      zx_ajustq=.FALSE.
2660c
2661c===================================================================
2662c Convection seche (thermiques ou ajustement)
2663c===================================================================
2664c
2665      d_t_ajs(:,:)=0.
2666      d_u_ajs(:,:)=0.
2667      d_v_ajs(:,:)=0.
2668      d_q_ajs(:,:)=0.
2669      fm_therm(:,:)=0.
2670      entr_therm(:,:)=0.
2671c
2672      IF(prt_level>9)WRITE(lunout,*)
2673     .    'AVANT LA CONVECTION SECHE , iflag_thermals='
2674     s   ,iflag_thermals,'   nsplit_thermals=',nsplit_thermals
2675      if(iflag_thermals.lt.0) then
2676c  Rien
2677c  ====
2678         IF(prt_level>9)WRITE(lunout,*)'pas de convection'
2679      else if(iflag_thermals.eq.0) then
2680
2681c  Ajustement sec
2682c  ==============
2683         IF(prt_level>9)WRITE(lunout,*)'ajsec'
2684         CALL ajsec(paprs, pplay, t_seri,q_seri, d_t_ajs, d_q_ajs)
2685         t_seri(:,:) = t_seri(:,:) + d_t_ajs(:,:)
2686         q_seri(:,:) = q_seri(:,:) + d_q_ajs(:,:)
2687      else
2688c  Thermiques
2689c  ==========
2690         IF(prt_level>9)WRITE(lunout,*)'JUSTE AVANT , iflag_thermals='
2691     s   ,iflag_thermals,'   nsplit_thermals=',nsplit_thermals
2692         call calltherm(pdtphys
2693     s      ,pplay,paprs,pphi
2694     s      ,u_seri,v_seri,t_seri,q_seri
2695     s      ,d_u_ajs,d_v_ajs,d_t_ajs,d_q_ajs
2696     s      ,fm_therm,entr_therm)
2697      endif
2698c
2699c===================================================================
2700cIM
2701      IF (ip_ebil_phy.ge.2) THEN
2702        ztit='after dry_adjust'
2703        CALL diagetpq(airephy,ztit,ip_ebil_phy,2,2,dtime
2704     e      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay
2705     s      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
2706      END IF
2707
2708
2709c-------------------------------------------------------------------------
2710c  Caclul des ratqs
2711c-------------------------------------------------------------------------
2712
2713c      print*,'calcul des ratqs'
2714c   ratqs convectifs a l'ancienne en fonction de q(z=0)-q / q
2715c   ----------------
2716c   on ecrase le tableau ratqsc calcule par clouds_gno
2717      if (iflag_cldcon.eq.1) then
2718         do k=1,klev
2719         do i=1,klon
2720            if(ptconv(i,k)) then
2721              ratqsc(i,k)=ratqsbas
2722     s        +fact_cldcon*(q_seri(i,1)-q_seri(i,k))/q_seri(i,k)
2723            else
2724               ratqsc(i,k)=0.
2725            endif
2726         enddo
2727         enddo
2728      endif
2729
2730c   ratqs stables
2731c   -------------
2732      do k=1,klev
2733cIM RAJOUT boucle do=i
2734       do i=1, klon
2735cIM         ratqss(:,k)=ratqsbas+(ratqshaut-ratqsbas)*
2736cIM     s   min((paprs(:,1)-pplay(:,k))/(paprs(:,1)-30000.),1.)
2737         ratqss(i,k)=ratqsbas+(ratqshaut-ratqsbas)*
2738     s   min((paprs(i,1)-pplay(i,k))/(paprs(i,1)-30000.),1.)
2739cIM      print*,' IMratqs STABLE i, k',i,k,ratqss(i,k)
2740       enddo
2741      enddo
2742
2743
2744c  ratqs final
2745c  -----------
2746      if (iflag_cldcon.eq.1 .or.iflag_cldcon.eq.2) then
2747c   les ratqs sont une conbinaison de ratqss et ratqsc
2748c   ratqs final
2749c   1e4 (en gros 3 heures), en dur pour le moment, est le temps de
2750c   relaxation des ratqs
2751c         facttemps=exp(-pdtphys/1.e4)
2752         facteur=exp(-pdtphys*facttemps)
2753         ratqs(:,:)=max(ratqs(:,:)*facteur,ratqss(:,:))
2754         ratqs(:,:)=max(ratqs(:,:),ratqsc(:,:))
2755c         print*,'calcul des ratqs fini'
2756      else
2757c   on ne prend que le ratqs stable pour fisrtilp
2758         ratqs(:,:)=ratqss(:,:)
2759      endif
2760
2761
2762c
2763c Appeler le processus de condensation a grande echelle
2764c et le processus de precipitation
2765c-------------------------------------------------------------------------
2766      CALL fisrtilp(dtime,paprs,pplay,
2767     .           t_seri, q_seri,ptconv,ratqs,
2768     .           d_t_lsc, d_q_lsc, d_ql_lsc, rneb, cldliq,
2769     .           rain_lsc, snow_lsc,
2770     .           pfrac_impa, pfrac_nucl, pfrac_1nucl,
2771     .           frac_impa, frac_nucl,
2772     .           prfl, psfl, rhcl)
2773
2774      WHERE (rain_lsc < 0) rain_lsc = 0.
2775      WHERE (snow_lsc < 0) snow_lsc = 0.
2776      DO k = 1, klev
2777      DO i = 1, klon
2778         t_seri(i,k) = t_seri(i,k) + d_t_lsc(i,k)
2779         q_seri(i,k) = q_seri(i,k) + d_q_lsc(i,k)
2780         ql_seri(i,k) = ql_seri(i,k) + d_ql_lsc(i,k)
2781         cldfra(i,k) = rneb(i,k)
2782         IF (.NOT.new_oliq) cldliq(i,k) = ql_seri(i,k)
2783      ENDDO
2784      ENDDO
2785      IF (check) THEN
2786         za = qcheck(klon,klev,paprs,q_seri,ql_seri,airephy)
2787         WRITE(lunout,*)"apresilp=", za
2788         zx_t = 0.0
2789         za = 0.0
2790         DO i = 1, klon
2791            za = za + airephy(i)/FLOAT(klon)
2792            zx_t = zx_t + (rain_lsc(i)
2793     .                  + snow_lsc(i))*airephy(i)/FLOAT(klon)
2794        ENDDO
2795         zx_t = zx_t/za*dtime
2796         WRITE(lunout,*)"Precip=", zx_t
2797      ENDIF
2798cIM
2799      IF (ip_ebil_phy.ge.2) THEN
2800        ztit='after fisrt'
2801        CALL diagetpq(airephy,ztit,ip_ebil_phy,2,2,dtime
2802     e      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay
2803     s      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
2804        call diagphy(airephy,ztit,ip_ebil_phy
2805     e      , zero_v, zero_v, zero_v, zero_v, zero_v
2806     e      , zero_v, rain_lsc, snow_lsc, ztsol
2807     e      , d_h_vcol, d_qt, d_ec
2808     s      , fs_bound, fq_bound )
2809      END IF
2810
2811      if (mydebug) then
2812        call writefield_phy('u_seri',u_seri,llm)
2813        call writefield_phy('v_seri',v_seri,llm)
2814        call writefield_phy('t_seri',t_seri,llm)
2815        call writefield_phy('q_seri',q_seri,llm)
2816      endif
2817
2818c
2819c-------------------------------------------------------------------
2820c  PRESCRIPTION DES NUAGES POUR LE RAYONNEMENT
2821c-------------------------------------------------------------------
2822
2823c 1. NUAGES CONVECTIFS
2824c
2825cIM cf FH
2826c     IF (iflag_cldcon.eq.-1) THEN ! seulement pour Tiedtke
2827       IF (iflag_cldcon.le.-1) THEN ! seulement pour Tiedtke
2828       snow_tiedtke=0.
2829c     print*,'avant calcul de la pseudo precip '
2830c     print*,'iflag_cldcon',iflag_cldcon
2831       if (iflag_cldcon.eq.-1) then
2832          rain_tiedtke=rain_con
2833       else
2834c       print*,'calcul de la pseudo precip '
2835          rain_tiedtke=0.
2836c         print*,'calcul de la pseudo precip 0'
2837          do k=1,klev
2838          do i=1,klon
2839             if (d_q_con(i,k).lt.0.) then
2840                rain_tiedtke(i)=rain_tiedtke(i)-d_q_con(i,k)/pdtphys
2841     s         *(paprs(i,k)-paprs(i,k+1))/rg
2842             endif
2843          enddo
2844          enddo
2845       endif
2846c
2847c     call dump2d(iim,jjm,rain_tiedtke(2:klon-1),'PSEUDO PRECIP ')
2848c
2849
2850c Nuages diagnostiques pour Tiedtke
2851      CALL diagcld1(paprs,pplay,
2852cIM cf FH  .             rain_con,snow_con,ibas_con,itop_con,
2853     .             rain_tiedtke,snow_tiedtke,ibas_con,itop_con,
2854     .             diafra,dialiq)
2855      DO k = 1, klev
2856      DO i = 1, klon
2857      IF (diafra(i,k).GT.cldfra(i,k)) THEN
2858         cldliq(i,k) = dialiq(i,k)
2859         cldfra(i,k) = diafra(i,k)
2860      ENDIF
2861      ENDDO
2862      ENDDO
2863
2864      ELSE IF (iflag_cldcon.eq.3) THEN
2865c  On prend pour les nuages convectifs le max du calcul de la
2866c  convection et du calcul du pas de temps pr��ent diminu�d'un facteur
2867c  facttemps
2868c      facttemps=pdtphys/1.e4
2869      facteur = pdtphys *facttemps
2870      do k=1,klev
2871         do i=1,klon
2872            rnebcon(i,k)=rnebcon(i,k)*facteur
2873            if (rnebcon0(i,k)*clwcon0(i,k).gt.rnebcon(i,k)*clwcon(i,k))
2874     s      then
2875                rnebcon(i,k)=rnebcon0(i,k)
2876                clwcon(i,k)=clwcon0(i,k)
2877            endif
2878         enddo
2879      enddo
2880
2881c
2882cjq - introduce the aerosol direct and first indirect radiative forcings
2883cjq - Johannes Quaas, 27/11/2003 (quaas@lmd.jussieu.fr)
2884      IF (ok_ade.OR.ok_aie) THEN
2885         ! Get sulfate aerosol distribution
2886         CALL readsulfate(rjourvrai, debut, sulfate)
2887         CALL readsulfate_preind(rjourvrai, debut, sulfate_pi)
2888
2889         ! Calculate aerosol optical properties (Olivier Boucher)
2890         CALL aeropt(pplay, paprs, t_seri, sulfate, rhcl,
2891     .        tau_ae, piz_ae, cg_ae, aerindex)
2892cym
2893      ELSE
2894        tau_ae(:,:,:)=0.0
2895        piz_ae(:,:,:)=0.0
2896        cg_ae(:,:,:)=0.0
2897cym     
2898      ENDIF
2899
2900c
2901cIM calcul nuages par le simulateur ISCCP
2902c
2903      IF (ok_isccp) THEN
2904c#include "calcul_simulISCCP.h"
2905      ENDIF !ok_isccp
2906
2907c   On prend la somme des fractions nuageuses et des contenus en eau
2908      cldfra(:,:)=min(max(cldfra(:,:),rnebcon(:,:)),1.)
2909      cldliq(:,:)=cldliq(:,:)+rnebcon(:,:)*clwcon(:,:)
2910
2911      ENDIF
2912
2913c
2914c 2. NUAGES STARTIFORMES
2915c
2916      IF (ok_stratus) THEN
2917      CALL diagcld2(paprs,pplay,t_seri,q_seri, diafra,dialiq)
2918      DO k = 1, klev
2919      DO i = 1, klon
2920      IF (diafra(i,k).GT.cldfra(i,k)) THEN
2921         cldliq(i,k) = dialiq(i,k)
2922         cldfra(i,k) = diafra(i,k)
2923      ENDIF
2924      ENDDO
2925      ENDDO
2926      ENDIF
2927c
2928c Precipitation totale
2929c
2930      DO i = 1, klon
2931         rain_fall(i) = rain_con(i) + rain_lsc(i)
2932         snow_fall(i) = snow_con(i) + snow_lsc(i)
2933      ENDDO
2934cIM
2935      IF (ip_ebil_phy.ge.2) THEN
2936        ztit="after diagcld"
2937        CALL diagetpq(airephy,ztit,ip_ebil_phy,2,2,dtime
2938     e      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay
2939     s      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
2940      END IF
2941c
2942c Calculer l'humidite relative pour diagnostique
2943c
2944      DO k = 1, klev
2945      DO i = 1, klon
2946         zx_t = t_seri(i,k)
2947         IF (thermcep) THEN
2948            zdelta = MAX(0.,SIGN(1.,rtt-zx_t))
2949            zx_qs  = r2es * FOEEW(zx_t,zdelta)/pplay(i,k)
2950            zx_qs  = MIN(0.5,zx_qs)
2951            zcor   = 1./(1.-retv*zx_qs)
2952            zx_qs  = zx_qs*zcor
2953         ELSE
2954           IF (zx_t.LT.t_coup) THEN
2955              zx_qs = qsats(zx_t)/pplay(i,k)
2956           ELSE
2957              zx_qs = qsatl(zx_t)/pplay(i,k)
2958           ENDIF
2959         ENDIF
2960         zx_rh(i,k) = q_seri(i,k)/zx_qs
2961         zqsat(i,k)=zx_qs
2962      ENDDO
2963      ENDDO
2964c
2965cIM Calculer l'humidite relative a 2m (rh2m) pour diagnostique
2966cIM ajout dependance type surface
2967      DO i = 1, klon
2968       rh2m(i)=0.
2969       qsat2m(i)=0.
2970      DO nsrf=1, nbsrf
2971         zx_t1(i,nsrf) = t2m(i,nsrf)
2972         IF (thermcep) THEN
2973            zdelta1(i,nsrf) = MAX(0.,SIGN(1.,rtt-zx_t1(i,nsrf)))
2974            zx_qs1(i,nsrf)  = r2es *
2975     $      FOEEW(zx_t1(i,nsrf),zdelta1(i,nsrf))/paprs(i,1)
2976            zx_qs1(i,nsrf)  = MIN(0.5,zx_qs1(i,nsrf))
2977            zcor1(i,nsrf)   = 1./(1.-retv*zx_qs1(i,nsrf))
2978            zx_qs1(i,nsrf)  = zx_qs1(i,nsrf)*zcor1(i,nsrf)
2979         ELSE
2980c
2981           IF (zx_t.LT.RTT) THEN
2982              zx_qs = qsats(zx_t)/paprs(i,1)
2983           ELSE
2984              zx_qs = qsatl(zx_t)/paprs(i,1)
2985           ENDIF
2986         ENDIF
2987       zx_rh2m(i,nsrf) = q2m(i,nsrf)/zx_qs1(i,nsrf)
2988       zx_qsat2m(i,nsrf)=zx_qs1(i,nsrf)
2989       rh2m(i) = rh2m(i)+zx_rh2m(i,nsrf)*pctsrf(i,nsrf)
2990       qsat2m(i)=qsat2m(i)+zx_qsat2m(i,nsrf)*pctsrf(i,nsrf)
2991      ENDDO !nsrf
2992      ENDDO
2993c
2994cIM Calcul temp.potentielle a 2m (tpot) et temp. potentielle
2995c   equivalente a 2m (tpote) pour diagnostique
2996c
2997      DO i = 1, klon
2998       tpot(i)=zt2m(i)*(100000./paprs(i,1))**RKAPPA
2999       IF (thermcep) THEN
3000        IF(zt2m(i).LT.RTT) then
3001         Lheat=RLSTT
3002        ELSE
3003         Lheat=RLVTT
3004        ENDIF
3005       ELSE
3006        IF (zt2m(i).LT.RTT) THEN
3007         Lheat=RLSTT
3008        ELSE
3009         Lheat=RLVTT
3010        ENDIF
3011       ENDIF
3012       tpote(i) = tpot(i)*     
3013     . EXP((Lheat *qsat2m(i))/(RCPD*zt2m(i)))
3014      ENDDO
3015
3016
3017#ifdef INCA
3018      call VTe(VTphysiq)
3019      call VTb(VTinca)
3020           calday = FLOAT(julien) + gmtime
3021
3022#ifdef INCA_AER
3023      call AEROSOL_METEO_CALC(calday,pdtphys,pplay,paprs,t,pmflxr,pmflxs,
3024     &   prfl,psfl,pctsrf(1,3),airephy,xjour,rlat,rlon)
3025#endif
3026
3027#ifdef INCAINFO
3028           WRITE(lunout,*)'Appel CHEMHOOK_BEGIN ...'
3029#endif
3030
3031           CALL chemhook_begin (calday,
3032#if defined(INCA) && !defined(INCA_CH4) && !defined(INCA_NMHC) && !defined(INCA_AER)
3033     $                          julien,
3034     $                          gmtime,
3035#endif
3036     $                          pctsrf(1,1),
3037     $                          rlat,
3038     $                          rlon,
3039     $                          airephy,
3040     $                          paprs,
3041     $                          pplay,
3042     $                          ycoefh,
3043     $                          pphi,
3044     $                          t_seri,
3045     $                          u,
3046     $                          v,
3047     $                          wo,
3048     $                          q_seri,
3049     $                          zxtsol,
3050     $                          zxsnow,
3051     $                          solsw,
3052     $                          albsol,
3053     $                          rain_fall,
3054     $                          snow_fall,
3055     $                          itop_con,
3056     $                          ibas_con,
3057     $                          cldfra,
3058     $                          iim,
3059     $                          jjm,
3060#ifdef INCA_AER
3061     $                          tr_seri,
3062     $                          ftsol,
3063     $                          paprs,
3064     $                          cdragh,
3065     $                          cdragm,
3066     $                          pctsrf,
3067     $                          pdtphys,
3068     $                          itap)
3069#else
3070     $                          tr_seri)     
3071#endif       
3072
3073
3074#ifdef INCAINFO
3075           WRITE(lunout,*)'OK.'
3076#endif
3077      call VTe(VTinca)
3078      call VTb(VTphysiq)
3079#endif
3080c     
3081c Calculer les parametres optiques des nuages et quelques
3082c parametres pour diagnostiques:
3083c
3084      if (ok_newmicro) then
3085      CALL newmicro (paprs, pplay,ok_newmicro,
3086     .            t_seri, cldliq, cldfra, cldtau, cldemi,
3087     .            cldh, cldl, cldm, cldt, cldq,
3088     .            flwp, fiwp, flwc, fiwc,
3089     e            ok_aie,
3090     e            sulfate, sulfate_pi,
3091     e            bl95_b0, bl95_b1,
3092     s            cldtaupi, re, fl)
3093      else
3094      CALL nuage (paprs, pplay,
3095     .            t_seri, cldliq, cldfra, cldtau, cldemi,
3096     .            cldh, cldl, cldm, cldt, cldq,
3097     e            ok_aie,
3098     e            sulfate, sulfate_pi,
3099     e            bl95_b0, bl95_b1,
3100     s            cldtaupi, re, fl)
3101     
3102      endif
3103c
3104c Appeler le rayonnement mais calculer tout d'abord l'albedo du sol.
3105c
3106      IF (MOD(itaprad,radpas).EQ.0) THEN
3107      DO i = 1, klon
3108         albsol(i) = falbe(i,is_oce) * pctsrf(i,is_oce)
3109     .             + falbe(i,is_lic) * pctsrf(i,is_lic)
3110     .             + falbe(i,is_ter) * pctsrf(i,is_ter)
3111     .             + falbe(i,is_sic) * pctsrf(i,is_sic)
3112         albsollw(i) = falblw(i,is_oce) * pctsrf(i,is_oce)
3113     .               + falblw(i,is_lic) * pctsrf(i,is_lic)
3114     .               + falblw(i,is_ter) * pctsrf(i,is_ter)
3115     .               + falblw(i,is_sic) * pctsrf(i,is_sic)
3116      ENDDO
3117
3118      if (mydebug) then
3119        call writefield_phy('u_seri',u_seri,llm)
3120        call writefield_phy('v_seri',v_seri,llm)
3121        call writefield_phy('t_seri',t_seri,llm)
3122        call writefield_phy('q_seri',q_seri,llm)
3123      endif
3124     
3125      CALL radlwsw ! nouveau rayonnement (compatible Arpege-IFS)
3126     e            (dist, rmu0, fract,
3127     e             paprs, pplay,zxtsol,albsol, albsollw, t_seri,q_seri,
3128     e             wo,
3129     e             cldfra, cldemi, cldtau,
3130     s             heat,heat0,cool,cool0,radsol,albpla,
3131     s             topsw,toplw,solsw,sollw,
3132     s             sollwdown,
3133     s             topsw0,toplw0,solsw0,sollw0,
3134     s             lwdn0, lwdn, lwup0, lwup,
3135     s             swdn0, swdn, swup0, swup,
3136     e             ok_ade, ok_aie, ! new for aerosol radiative effects
3137     e             tau_ae, piz_ae, cg_ae, ! ="=
3138     s             topswad, solswad, ! ="=
3139     e             cldtaupi, ! ="=
3140     s             topswai, solswai) ! ="=
3141      itaprad = 0
3142      ENDIF
3143      itaprad = itaprad + 1
3144c
3145c Ajouter la tendance des rayonnements (tous les pas)
3146c
3147      DO k = 1, klev
3148      DO i = 1, klon
3149         t_seri(i,k) = t_seri(i,k)
3150     .               + (heat(i,k)-cool(i,k)) * dtime/86400.
3151      ENDDO
3152      ENDDO
3153c
3154      if (mydebug) then
3155        call writefield_phy('u_seri',u_seri,llm)
3156        call writefield_phy('v_seri',v_seri,llm)
3157        call writefield_phy('t_seri',t_seri,llm)
3158        call writefield_phy('q_seri',q_seri,llm)
3159      endif
3160 
3161cIM
3162      IF (ip_ebil_phy.ge.2) THEN
3163        ztit='after rad'
3164        CALL diagetpq(airephy,ztit,ip_ebil_phy,2,2,dtime
3165     e      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay
3166     s      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
3167        call diagphy(airephy,ztit,ip_ebil_phy
3168     e      , topsw, toplw, solsw, sollw, zero_v
3169     e      , zero_v, zero_v, zero_v, ztsol
3170     e      , d_h_vcol, d_qt, d_ec
3171     s      , fs_bound, fq_bound )
3172      END IF
3173c
3174c
3175c Calculer l'hydrologie de la surface
3176c
3177c      CALL hydrol(dtime,pctsrf,rain_fall, snow_fall, zxevap,
3178c     .            agesno, ftsol,fqsurf,fsnow, ruis)
3179c
3180      DO i = 1, klon
3181         zxqsurf(i) = 0.0
3182         zxsnow(i) = 0.0
3183      ENDDO
3184      DO nsrf = 1, nbsrf
3185      DO i = 1, klon
3186         zxqsurf(i) = zxqsurf(i) + fqsurf(i,nsrf)*pctsrf(i,nsrf)
3187         zxsnow(i) = zxsnow(i) + fsnow(i,nsrf)*pctsrf(i,nsrf)
3188      ENDDO
3189      ENDDO
3190c
3191c Si une sous-fraction n'existe pas, elle prend la valeur moyenne
3192c
3193cXXX      DO nsrf = 1, nbsrf
3194cXXX      DO i = 1, klon
3195cXXX         IF (pctsrf(i,nsrf).LT.epsfra) THEN
3196cXXX            fqsurf(i,nsrf) = zxqsurf(i)
3197cXXX            fsnow(i,nsrf) = zxsnow(i)
3198cXXX         ENDIF
3199cXXX      ENDDO
3200cXXX      ENDDO
3201c
3202c Calculer le bilan du sol et la derive de temperature (couplage)
3203c
3204      DO i = 1, klon
3205c         bils(i) = radsol(i) - sens(i) - evap(i)*RLVTT
3206c a la demande de JLD
3207         bils(i) = radsol(i) - sens(i) + zxfluxlat(i)
3208      ENDDO
3209c
3210cmoddeblott(jan95)
3211c Appeler le programme de parametrisation de l'orographie
3212c a l'echelle sous-maille:
3213c
3214      IF (ok_orodr) THEN
3215c
3216c  selection des points pour lesquels le shema est actif:
3217        igwd=0
3218        DO i=1,klon
3219        itest(i)=0
3220c        IF ((zstd(i).gt.10.0)) THEN
3221        IF (((zpic(i)-zmea(i)).GT.100.).AND.(zstd(i).GT.10.0)) THEN
3222          itest(i)=1
3223          igwd=igwd+1
3224          idx(igwd)=i
3225        ENDIF
3226        ENDDO
3227c        igwdim=MAX(1,igwd)
3228c
3229        CALL drag_noro(klon,klev,dtime,paprs,pplay,
3230     e                   zmea,zstd, zsig, zgam, zthe,zpic,zval,
3231     e                   igwd,idx,itest,
3232     e                   t_seri, u_seri, v_seri,
3233cIM 141004    s                   zulow, zvlow, zustr, zvstr,
3234     s                   zulow, zvlow, zustrdr, zvstrdr,
3235     s                   d_t_oro, d_u_oro, d_v_oro)
3236c
3237c  ajout des tendances
3238        DO k = 1, klev
3239        DO i = 1, klon
3240           t_seri(i,k) = t_seri(i,k) + d_t_oro(i,k)
3241           u_seri(i,k) = u_seri(i,k) + d_u_oro(i,k)
3242           v_seri(i,k) = v_seri(i,k) + d_v_oro(i,k)
3243        ENDDO
3244        ENDDO
3245c
3246      ENDIF ! fin de test sur ok_orodr
3247c
3248      if (mydebug) then
3249        call writefield_phy('u_seri',u_seri,llm)
3250        call writefield_phy('v_seri',v_seri,llm)
3251        call writefield_phy('t_seri',t_seri,llm)
3252        call writefield_phy('q_seri',q_seri,llm)
3253      endif
3254     
3255      IF (ok_orolf) THEN
3256c
3257c  selection des points pour lesquels le shema est actif:
3258        igwd=0
3259        DO i=1,klon
3260        itest(i)=0
3261        IF ((zpic(i)-zmea(i)).GT.100.) THEN
3262          itest(i)=1
3263          igwd=igwd+1
3264          idx(igwd)=i
3265        ENDIF
3266        ENDDO
3267c        igwdim=MAX(1,igwd)
3268c
3269        CALL lift_noro(klon,klev,dtime,paprs,pplay,
3270     e                   rlat,zmea,zstd,zpic,
3271     e                   itest,
3272     e                   t_seri, u_seri, v_seri,
3273     s                   zulow, zvlow, zustrli, zvstrli,
3274     s                   d_t_lif, d_u_lif, d_v_lif)
3275c
3276c  ajout des tendances
3277        DO k = 1, klev
3278        DO i = 1, klon
3279           t_seri(i,k) = t_seri(i,k) + d_t_lif(i,k)
3280           u_seri(i,k) = u_seri(i,k) + d_u_lif(i,k)
3281           v_seri(i,k) = v_seri(i,k) + d_v_lif(i,k)
3282        ENDDO
3283        ENDDO
3284c
3285      ENDIF ! fin de test sur ok_orolf
3286c
3287cIM cf. FLott BEG
3288C STRESS NECESSAIRES: TOUTE LA PHYSIQUE
3289
3290      if (mydebug) then
3291        call writefield_phy('u_seri',u_seri,llm)
3292        call writefield_phy('v_seri',v_seri,llm)
3293        call writefield_phy('t_seri',t_seri,llm)
3294        call writefield_phy('q_seri',q_seri,llm)
3295      endif
3296
3297      DO i = 1, klon
3298        zustrph(i)=0.
3299        zvstrph(i)=0.
3300      ENDDO
3301      DO k = 1, klev
3302      DO i = 1, klon
3303       zustrph(i)=zustrph(i)+(u_seri(i,k)-u(i,k))/dtime*
3304     c            (paprs(i,k)-paprs(i,k+1))/rg
3305       zvstrph(i)=zvstrph(i)+(v_seri(i,k)-v(i,k))/dtime*
3306     c            (paprs(i,k)-paprs(i,k+1))/rg
3307      ENDDO
3308      ENDDO
3309c
3310cIM calcul composantes axiales du moment angulaire et couple des montagnes
3311c
3312      IF (monocpu) THEN
3313     
3314        CALL aaam_bud (27,klon,klev,rjourvrai,gmtime,
3315     C                 ra,rg,romega,
3316     C                 rlat,rlon,pphis,
3317     C                 zustrdr,zustrli,zustrph,
3318     C                 zvstrdr,zvstrli,zvstrph,
3319     C                 paprs,u,v,
3320     C                 aam, torsfc)
3321       ENDIF
3322cIM cf. FLott END
3323cIM
3324      IF (ip_ebil_phy.ge.2) THEN
3325        ztit='after orography'
3326        CALL diagetpq(airephy,ztit,ip_ebil_phy,2,2,dtime
3327     e      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay
3328     s      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
3329      END IF
3330c
3331c
3332cAA
3333cAA Installation de l'interface online-offline pour traceurs
3334cAA
3335c====================================================================
3336c   Calcul  des tendances traceurs
3337c====================================================================
3338C
3339      call phytrac (     rnpb,
3340     I                   itap,
3341     I                   julien,
3342     I                   gmtime,
3343     I                   debut,
3344     I                   lafin,
3345     I                   nqmax-2,
3346     I                   nlon,
3347     I                   nlev,
3348     I                   dtime,
3349     I                   u,
3350     I                   v,
3351     I                   t,
3352     I                   paprs,
3353     I                   pplay,
3354     I                   pmfu,
3355     I                   pmfd,
3356     I                   pen_u,
3357     I                   pde_u,
3358     I                   pen_d,
3359     I                   pde_d,
3360     I                   ycoefh,
3361     I                   fm_therm,
3362     I                   entr_therm,
3363     I                   yu1,
3364     I                   yv1,
3365     I                   ftsol,
3366     I                   pctsrf,
3367     I                   rlat,
3368     I                   frac_impa,
3369     I                   frac_nucl,
3370     I                   rlon,
3371     I                   presnivs,
3372     I                   pphis,
3373     I                   pphi,
3374     I                   albsol,
3375     I                   qx(1,1,1),
3376     I                   rhcl,
3377     I                   cldfra,
3378     I                   rneb,
3379     I                   diafra,
3380     I                   cldliq,
3381     I                   itop_con,
3382     I                   ibas_con,
3383     I                   pmflxr,
3384     I                   pmflxs,
3385     I                   prfl,
3386     I                   psfl,
3387     I                   da,
3388     I                   phi,
3389     I                   mp,
3390     I                   upwd,
3391     I                   dnwd,
3392#ifdef INCA
3393     I                   flxmass_w,
3394#endif
3395     O                   tr_seri)
3396
3397      IF (offline) THEN
3398
3399         print*,'Attention on met a 0 les thermiques pour phystoke'
3400         call phystokenc (
3401     I                   nlon,nlev,pdtphys,rlon,rlat,
3402     I                   t,pmfu, pmfd, pen_u, pde_u, pen_d, pde_d,
3403     I                   fm_therm,entr_therm,
3404     I                   ycoefh,yu1,yv1,ftsol,pctsrf,
3405     I                   frac_impa, frac_nucl,
3406     I                   pphis,airephy,dtime,itap)
3407
3408
3409      ENDIF
3410
3411c
3412c Calculer le transport de l'eau et de l'energie (diagnostique)
3413c
3414      CALL transp (paprs,zxtsol,
3415     e                   t_seri, q_seri, u_seri, v_seri, zphi,
3416     s                   ve, vq, ue, uq)
3417c
3418cIM global posePB BEG
3419      IF(1.EQ.0) THEN
3420c
3421      CALL transp_lay (paprs,zxtsol,
3422     e                   t_seri, q_seri, u_seri, v_seri, zphi,
3423     s                   ve_lay, vq_lay, ue_lay, uq_lay)
3424c
3425      ENDIF !(1.EQ.0) THEN
3426cIM global posePB END
3427c Accumuler les variables a stocker dans les fichiers histoire:
3428c
3429c+jld ec_conser
3430      DO k = 1, klev
3431      DO i = 1, klon
3432        ZRCPD = RCPD*(1.0+RVTMP2*q_seri(i,k))
3433        d_t_ec(i,k)=0.5/ZRCPD
3434     $      *(u(i,k)**2+v(i,k)**2-u_seri(i,k)**2-v_seri(i,k)**2)
3435        t_seri(i,k)=t_seri(i,k)+d_t_ec(i,k)
3436        d_t_ec(i,k) = d_t_ec(i,k)/dtime
3437       END DO
3438      END DO
3439c-jld ec_conser
3440cIM
3441      IF (ip_ebil_phy.ge.1) THEN
3442        ztit='after physic'
3443        CALL diagetpq(airephy,ztit,ip_ebil_phy,1,1,dtime
3444     e      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay
3445     s      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
3446C     Comme les tendances de la physique sont ajoute dans la dynamique,
3447C     on devrait avoir que la variation d'entalpie par la dynamique
3448C     est egale a la variation de la physique au pas de temps precedent.
3449C     Donc la somme de ces 2 variations devrait etre nulle.
3450        call diagphy(airephy,ztit,ip_ebil_phy
3451     e      , topsw, toplw, solsw, sollw, sens
3452     e      , evap, rain_fall, snow_fall, ztsol
3453     e      , d_h_vcol, d_qt, d_ec
3454     s      , fs_bound, fq_bound )
3455C
3456      d_h_vcol_phy=d_h_vcol
3457C
3458      END IF
3459C
3460c=======================================================================
3461c   SORTIES
3462c=======================================================================
3463
3464cIM Interpolation sur les niveaux de pression du NMC
3465c   -------------------------------------------------
3466c
3467#include "calcul_STDlev.h"
3468c
3469c slp sea level pressure
3470      slp(:) = paprs(:,1)*exp(pphis(:)/(RD*t_seri(:,1)))
3471c
3472ccc prw = eau precipitable
3473      DO i = 1, klon
3474       prw(i) = 0.
3475       DO k = 1, klev
3476        prw(i) = prw(i) +
3477     .           q_seri(i,k)*(paprs(i,k)-paprs(i,k+1))/RG
3478       ENDDO
3479      ENDDO
3480c
3481cIM initialisation + calculs divers diag AMIP2
3482c
3483#include "calcul_divers.h"
3484c
3485#ifdef INCA
3486      call VTe(VTphysiq)
3487      call VTb(VTinca)
3488#ifdef INCAINFO
3489           WRITE(lunout,*)'Appel CHEMHOOK_END ...'
3490#endif
3491           CALL chemhook_end (calday,
3492     $                        dtime,
3493     $                        pplay,
3494     $                        t_seri,
3495     $                        tr_seri,
3496     $                        nbtr,
3497     $                        paprs,
3498     $                        q_seri,
3499     $                        annee_ref,
3500     $                        day_ini,
3501#ifdef INCA_AER
3502     $                        xjour,
3503     $                        pphi,
3504     $                        pphis,
3505     $                        zx_rh)
3506#else
3507     $                        xjour)
3508#endif
3509#ifdef INCAINFO
3510           WRITE(lunout,*)'OK.'
3511#endif
3512      call VTe(VTinca)
3513      call VTb(VTphysiq)
3514#endif
3515
3516c=============================================================
3517c
3518c Convertir les incrementations en tendances
3519c
3520      if (mydebug) then
3521        call writefield_phy('u_seri',u_seri,llm)
3522        call writefield_phy('v_seri',v_seri,llm)
3523        call writefield_phy('t_seri',t_seri,llm)
3524        call writefield_phy('q_seri',q_seri,llm)
3525      endif
3526
3527      DO k = 1, klev
3528      DO i = 1, klon
3529         d_u(i,k) = ( u_seri(i,k) - u(i,k) ) / dtime
3530         d_v(i,k) = ( v_seri(i,k) - v(i,k) ) / dtime
3531         d_t(i,k) = ( t_seri(i,k)-t(i,k) ) / dtime
3532         d_qx(i,k,ivap) = ( q_seri(i,k) - qx(i,k,ivap) ) / dtime
3533         d_qx(i,k,iliq) = ( ql_seri(i,k) - qx(i,k,iliq) ) / dtime
3534      ENDDO
3535      ENDDO
3536c
3537      IF (nqmax.GE.3) THEN
3538      DO iq = 3, nqmax
3539      DO  k = 1, klev
3540      DO  i = 1, klon
3541         d_qx(i,k,iq) = ( tr_seri(i,k,iq-2) - qx(i,k,iq) ) / dtime
3542      ENDDO
3543      ENDDO
3544      ENDDO
3545      ENDIF
3546c
3547cIM rajout diagnostiques bilan KP pour analyse MJO par Jun-Ichi Yano
3548cIM global posePB#include "write_bilKP_ins.h"
3549cIM global posePB#include "write_bilKP_ave.h"
3550c
3551c Sauvegarder les valeurs de t et q a la fin de la physique:
3552c
3553      DO k = 1, klev
3554      DO i = 1, klon
3555         t_ancien(i,k) = t_seri(i,k)
3556         q_ancien(i,k) = q_seri(i,k)
3557      ENDDO
3558      ENDDO
3559c
3560c 22.03.04 BEG
3561c=============================================================
3562c   Ecriture des sorties
3563c=============================================================
3564#ifdef CPP_IOIPSL
3565
3566#ifdef histhf
3567#include "write_histhf.h"
3568#endif
3569
3570#ifdef histday
3571#include "write_histday.h"
3572#endif
3573
3574#ifdef histmth
3575#include "write_histmth.h"
3576#endif
3577
3578#ifdef histins
3579#include "write_histins.h"
3580#endif
3581
3582#ifdef histISCCP
3583#include "write_histISCCP.h"
3584#endif
3585
3586#ifdef histmthNMC
3587#include "write_histmthNMC.h"
3588#endif
3589
3590c#include "write_histday_seri.h"
3591
3592c#include "write_paramLMDZ_phy.h"
3593
3594#endif
3595
3596c 22.03.04 END
3597c
3598c====================================================================
3599c Si c'est la fin, il faut conserver l'etat de redemarrage
3600c====================================================================
3601c
3602      IF (lafin) THEN
3603         itau_phy = itau_phy + itap
3604ccc         IF (ok_oasis) CALL quitcpl
3605         CALL phyredem ("restartphy.nc",dtime,radpas,
3606     .      rlat, rlon, pctsrf, ftsol, ftsoil,
3607cIM "slab" ocean
3608     .      tslab, seaice,
3609     .      fqsurf, qsol,
3610     .      fsnow, falbe,falblw, fevap, rain_fall, snow_fall,
3611cIM  .      solsw, sollwdown,dlw,
3612     .      solsw, sollw,dlw,
3613     .      radsol,frugs,agesno,
3614     .      zmea,zstd,zsig,zgam,zthe,zpic,zval,rugoro,
3615     .      t_ancien, q_ancien, rnebcon, ratqs, clwcon,run_off_lic_0)
3616      ENDIF
3617     
3618
3619      RETURN
3620      END
3621      FUNCTION qcheck(klon,klev,paprs,q,ql,aire)
3622      IMPLICIT none
3623c
3624c Calculer et imprimer l'eau totale. A utiliser pour verifier
3625c la conservation de l'eau
3626c
3627#include "YOMCST.h"
3628      INTEGER klon,klev
3629      REAL paprs(klon,klev+1), q(klon,klev), ql(klon,klev)
3630      REAL aire(klon)
3631      REAL qtotal, zx, qcheck
3632      INTEGER i, k
3633c
3634      zx = 0.0
3635      DO i = 1, klon
3636         zx = zx + aire(i)
3637      ENDDO
3638      qtotal = 0.0
3639      DO k = 1, klev
3640      DO i = 1, klon
3641         qtotal = qtotal + (q(i,k)+ql(i,k)) * aire(i)
3642     .                     *(paprs(i,k)-paprs(i,k+1))/RG
3643      ENDDO
3644      ENDDO
3645c
3646      qcheck = qtotal/zx
3647c
3648      RETURN
3649      END
3650      SUBROUTINE gr_fi_ecrit(nfield,nlon,iim,jjmp1,fi,ecrit)
3651      IMPLICIT none
3652c
3653c Tranformer une variable de la grille physique a
3654c la grille d'ecriture
3655c
3656      INTEGER nfield,nlon,iim,jjmp1, jjm
3657      REAL fi(nlon,nfield), ecrit(iim*jjmp1,nfield)
3658c
3659      INTEGER i, n, ig
3660c
3661      jjm = jjmp1 - 1
3662      DO n = 1, nfield
3663         DO i=1,iim
3664            ecrit(i,n) = fi(1,n)
3665            ecrit(i+jjm*iim,n) = fi(nlon,n)
3666         ENDDO
3667         DO ig = 1, nlon - 2
3668           ecrit(iim+ig,n) = fi(1+ig,n)
3669         ENDDO
3670      ENDDO
3671      RETURN
3672      END
Note: See TracBrowser for help on using the repository browser.