source: lmdz_wrf/branches/LMDZ_WRFmeas/WRFV3/lmdz/physiq.F90 @ 146

Last change on this file since 146 was 141, checked in by lfita, 10 years ago

recovering 'llp' point for checkings definition and value

File size: 166.3 KB
Line 
1! $Id: physiq.F 1795 2013-07-18 08:20:28Z emillour $
2!c#define IO_DEBUG
3
4      SUBROUTINE physiq (nlon,nlev,                                                  &
5       &            debut,lafin,jD_cur, jH_cur,pdtphys,                              &
6       &            paprs,pplay,pphi,pphis,presnivs,clesphy0,                        &
7       &            u,v,t,qx,                                                        &
8       &            flxmass_w,                                                       &
9       &            d_u, d_v, d_t, d_qx, d_ps                                        &
10       &            , dudyn                                                          &
11       &            , PVteta)
12
13      USE ioipsl, only: histbeg, histvert, histdef, histend, histsync,               &
14       &     histwrite, ju2ymds, ymds2ju, ioget_year_len
15      USE comgeomphy
16      USE phys_cal_mod
17      USE write_field_phy
18      USE dimphy
19      USE infotrac
20      USE mod_grid_phy_lmdz
21      USE mod_phys_lmdz_para
22      USE iophy
23      USE misc_mod, mydebug=>debug
24      USE vampir
25!L. Fita, LMD. November 2013
26!      USE pbl_surface_mod, ONLY : pbl_surface
27!      USE pbl_surface_mod, ONLY : pbl_surface, pbl_surface_init
28      USE pbl_surface_mod
29      USE change_srf_frac_mod
30      USE surface_data,     ONLY : type_ocean, ok_veget
31      USE phys_local_var_mod ! Variables internes non sauvegardees de la physique
32      USE phys_state_var_mod ! Variables sauvegardees de la physique
33      USE phys_output_var_mod ! Variables pour les ecritures des sorties
34      USE fonte_neige_mod, ONLY  : fonte_neige_get_vars, fonte_neige_init
35      USE phys_output_mod
36      USE phys_output_ctrlout_mod
37      USE iophy
38      use open_climoz_m, only: open_climoz ! ozone climatology from a file
39      use regr_pr_av_m, only: regr_pr_av
40      use netcdf95, only: nf95_close
41!IM for NMC files
42!c     use netcdf, only: nf90_fill_real
43      use netcdf
44      use mod_phys_lmdz_mpi_data, only: is_mpi_root
45      USE aero_mod
46      use ozonecm_m, only: ozonecm ! ozone of J.-F. Royer
47      use conf_phys_m, only: conf_phys
48      use radlwsw_m, only: radlwsw
49      USE control_mod
50#ifdef REPROBUS
51      USE CHEM_REP, ONLY : Init_chem_rep_xjour
52#endif
53      USE indice_sol_mod
54
55!IM stations CFMIP
56      USE CFMIP_point_locations
57
58!L. Fita. July 2013
59      USE orografi
60      USE orografi_strato_mod
61      USE diagphy_mod
62!      USE orbite_mod, ONLY : angle
63      USE phyaqua_mod, ONLY: zenang_an
64      USE nuage_mod, ONLY : diagcld1
65
66! L. Fita, LMD. November 2013.
67!!      USE wrf_lmdz_mod
68!!      USE module_lmdz_variables, ONLY: neige_initialize, limit_initialize
69!!      USE physiq_limit_variables_mod
70!!      USE physiq_limit_variables_mod
71      USE lmdz_wrf_variables_mod
72! L. Fita, LMD. January 2014
73!   Defining with SAVE statement all that variables that should appear in the output
74      USE output_lmdz_NOmodule
75
76      IMPLICIT none
77!>======================================================================
78!!
79!! Auteur(s) Z.X. Li (LMD/CNRS) date: 19930818
80!!
81!! Objet: Moniteur general de la physique du modele
82!!AA      Modifications quant aux traceurs :
83!!AA                  -  uniformisation des parametrisations ds phytrac
84!!AA                  -  stockage des moyennes des champs necessaires
85!!AA                     en mode traceur off-line
86!!======================================================================
87!!   CLEFS CPP POUR LES IO
88!!   =====================
89#define histNMC
90!c#define histISCCP
91!!======================================================================
92!!    modif   ( P. Le Van ,  12/10/98 )
93!!
94!!  Arguments:
95!!
96!! nlon----input-I-nombre de points horizontaux
97!! nlev----input-I-nombre de couches verticales, doit etre egale a klev
98!! debut---input-L-variable logique indiquant le premier passage
99!! lafin---input-L-variable logique indiquant le dernier passage
100!! jD_cur       -R-jour courant a l'appel de la physique (jour julien)
101!! jH_cur       -R-heure courante a l'appel de la physique (jour julien)
102!! pdtphys-input-R-pas d'integration pour la physique (seconde)
103!! paprs---input-R-pression pour chaque inter-couche (en Pa)
104!! pplay---input-R-pression pour le mileu de chaque couche (en Pa)
105!! pphi----input-R-geopotentiel de chaque couche (g z) (reference sol)
106!! pphis---input-R-geopotentiel du sol
107!! presnivs-input_R_pressions approximat. des milieux couches ( en PA)
108!! u-------input-R-vitesse dans la direction X (de O a E) en m/s
109!! v-------input-R-vitesse Y (de S a N) en m/s
110!! t-------input-R-temperature (K)
111!! qx------input-R-humidite specifique (kg/kg) et d'autres traceurs
112!! d_t_dyn-input-R-tendance dynamique pour "t" (K/s)
113!! d_q_dyn-input-R-tendance dynamique pour "q" (kg/kg/s)
114!! flxmass_w -input-R- flux de masse verticale
115!! d_u-----output-R-tendance physique de "u" (m/s/s)
116!! d_v-----output-R-tendance physique de "v" (m/s/s)
117!! d_t-----output-R-tendance physique de "t" (K/s)
118!! d_qx----output-R-tendance physique de "qx" (kg/kg/s)
119!! d_ps----output-R-tendance physique de la pression au sol
120!!IM
121!! PVteta--output-R-vorticite potentielle a des thetas constantes
122!!======================================================================
123#include "dimensions.h"
124      integer jjmp1
125      parameter (jjmp1=jjm+1-1/jjm)
126      integer iip1
127      parameter (iip1=iim+1)
128
129#include "regdim.h"
130#include "dimsoil.h"
131#include "clesphys.h"
132#include "temps.h"
133#include "iniprint.h"
134#include "thermcell.h"
135!c======================================================================
136      LOGICAL ok_cvl  ! pour activer le nouveau driver pour convection KE
137      PARAMETER (ok_cvl=.TRUE.)
138      LOGICAL ok_gust ! pour activer l'effet des gust sur flux surface
139      PARAMETER (ok_gust=.FALSE.)
140      integer iflag_radia     ! active ou non le rayonnement (MPL)
141      save iflag_radia
142!$OMP THREADPRIVATE(iflag_radia)
143!c======================================================================
144      LOGICAL check ! Verifier la conservation du modele en eau
145      PARAMETER (check=.FALSE.)
146      LOGICAL ok_stratus ! Ajouter artificiellement les stratus
147      PARAMETER (ok_stratus=.FALSE.)
148!c======================================================================
149      REAL amn, amx
150      INTEGER igout
151!c======================================================================
152!c Clef controlant l'activation du cycle diurne:
153!ccc      LOGICAL cycle_diurne
154!ccc      PARAMETER (cycle_diurne=.FALSE.)
155!c======================================================================
156!c Modele thermique du sol, a activer pour le cycle diurne:
157!ccc      LOGICAL soil_model
158!ccc      PARAMETER (soil_model=.FALSE.)
159!c======================================================================
160!c Dans les versions precedentes, l'eau liquide nuageuse utilisee dans
161!c le calcul du rayonnement est celle apres la precipitation des nuages.
162!c Si cette cle new_oliq est activee, ce sera une valeur moyenne entre
163!c la condensation et la precipitation. Cette cle augmente les impacts
164!c radiatifs des nuages.
165!ccc      LOGICAL new_oliq
166!ccc      PARAMETER (new_oliq=.FALSE.)
167!c======================================================================
168!c Clefs controlant deux parametrisations de l'orographie:
169!cc      LOGICAL ok_orodr
170!ccc      PARAMETER (ok_orodr=.FALSE.)
171!ccc      LOGICAL ok_orolf
172!ccc      PARAMETER (ok_orolf=.FALSE.)
173!c======================================================================
174      LOGICAL ok_journe ! sortir le fichier journalier
175      save ok_journe
176!$OMP THREADPRIVATE(ok_journe)
177!c
178      LOGICAL ok_mensuel ! sortir le fichier mensuel
179      save ok_mensuel
180!$OMP THREADPRIVATE(ok_mensuel)
181!c
182      LOGICAL ok_instan ! sortir le fichier instantane
183      save ok_instan
184!$OMP THREADPRIVATE(ok_instan)
185!c
186      LOGICAL ok_LES ! sortir le fichier LES
187      save ok_LES                           
188!$OMP THREADPRIVATE(ok_LES)                 
189!c
190      LOGICAL callstats ! sortir le fichier stats
191      save callstats                           
192!$OMP THREADPRIVATE(callstats)                 
193!c
194      LOGICAL ok_region ! sortir le fichier regional
195      PARAMETER (ok_region=.FALSE.)
196!c======================================================================
197! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
198!      real weak_inversion(klon),dthmin(klon)
199      real seuil_inversion
200      save seuil_inversion
201!$OMP THREADPRIVATE(seuil_inversion)
202      integer iflag_ratqs
203      save iflag_ratqs
204!$OMP THREADPRIVATE(iflag_ratqs)
205      real facteur
206
207      REAL zz,znum,zden
208      REAL wmax_th(klon)
209! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
210!      REAL zmax_th(klon)
211      REAL tau_overturning_th(klon)
212
213! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
214!      integer lmax_th(klon)
215      integer limbas(klon)
216      real ratqscth(klon,klev)
217      real ratqsdiff(klon,klev)
218      real zqsatth(klon,klev)
219
220!c======================================================================
221!c
222      INTEGER ivap          ! indice de traceurs pour vapeur d'eau
223      PARAMETER (ivap=1)
224      INTEGER iliq          ! indice de traceurs pour eau liquide
225      PARAMETER (iliq=2)
226
227!c
228!c
229!c Variables argument:
230!c
231      INTEGER nlon
232      INTEGER nlev
233      REAL, intent(in):: jD_cur, jH_cur
234
235      REAL pdtphys
236      LOGICAL debut, lafin
237      REAL paprs(klon,klev+1)
238      REAL pplay(klon,klev)
239      REAL pphi(klon,klev)
240      REAL pphis(klon)
241      REAL presnivs(klev)
242      REAL znivsig(klev)
243      real pir
244
245      REAL u(klon,klev)
246      REAL v(klon,klev)
247! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
248!      REAL t(klon,klev),theta(klon,klev),thetal(klon,klev)
249      REAL t(klon,klev),thetal(klon,klev)
250
251!c thetal: ligne suivante a decommenter si vous avez les fichiers     MPL 20130625
252!c fth_fonctions.F90 et parkind1.F90
253!c sinon thetal=theta
254!c     REAL fth_thetae,fth_thetav,fth_thetal
255      REAL qx(klon,klev,nqtot)
256      REAL flxmass_w(klon,klev)
257! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
258!      REAL omega(klon,klev) ! vitesse verticale en Pa/s
259      REAL d_u(klon,klev)
260      REAL d_v(klon,klev)
261      REAL d_t(klon,klev)
262      REAL d_qx(klon,klev,nqtot)
263      REAL d_ps(klon)
264! Variables pour le transport convectif
265      real da(klon,klev),phi(klon,klev,klev),mp(klon,klev)
266! Variables pour le lessivage convectif
267! RomP >>>
268      real phi2(klon,klev,klev)
269      real d1a(klon,klev),dam(klon,klev)
270      real ev(klon,klev),ep(klon,klev)
271      real clw(klon,klev),elij(klon,klev,klev)
272      real epmlmMm(klon,klev,klev),eplaMm(klon,klev)
273! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
274!      real wdtrainA(klon,klev),wdtrainM(klon,klev)
275
276! RomP <<<
277!IM definition dynamique o_trac dans phys_output_open
278!      type(ctrl_out) :: o_trac(nqtot)
279!c
280!IM Amip2 PV a theta constante
281!c
282      INTEGER nbteta
283      PARAMETER(nbteta=3)
284      CHARACTER*3 ctetaSTD(nbteta)
285      DATA ctetaSTD/'350','380','405'/
286      SAVE ctetaSTD
287!$OMP THREADPRIVATE(ctetaSTD)
288      REAL rtetaSTD(nbteta)
289      DATA rtetaSTD/350., 380., 405./
290      SAVE rtetaSTD
291!$OMP THREADPRIVATE(rtetaSTD)     
292!c
293      REAL PVteta(klon,nbteta)
294      REAL zx_tmp_3dte(iim,jjmp1,nbteta)
295!c
296!MI Amip2 PV a theta constante
297
298!cym      INTEGER klevp1, klevm1
299!cym      PARAMETER(klevp1=klev+1,klevm1=klev-1)
300!cym#include "raddim.h"
301!c
302!c
303!IM Amip2
304!c variables a une pression donnee
305!c
306#include "declare_STDlev.h"
307!c
308      CHARACTER*4 bb2
309      CHARACTER*2 bb3
310!c
311#include "radopt.h"
312!c
313!c
314!c prw: precipitable water
315! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
316!      real prw(klon)
317
318      REAL convliq(klon,klev)  ! eau liquide nuageuse convective
319      REAL convfra(klon,klev)  ! fraction nuageuse convective
320
321      REAL cldl_c(klon),cldm_c(klon),cldh_c(klon) !nuages bas, moyen et haut
322      REAL cldt_c(klon),cldq_c(klon) !nuage total, eau liquide integree
323      REAL cldl_s(klon),cldm_s(klon),cldh_s(klon) !nuages bas, moyen et haut
324      REAL cldt_s(klon),cldq_s(klon) !nuage total, eau liquide integree
325
326      INTEGER linv, kp1
327!c flwp, fiwp = Liquid Water Path & Ice Water Path (kg/m2)
328!c flwc, fiwc = Liquid Water Content & Ice Water Content (kg/kg)
329! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
330!      REAL flwp(klon), fiwp(klon)
331!      REAL flwc(klon,klev), fiwc(klon,klev)
332      REAL flwp_c(klon), fiwp_c(klon)
333      REAL flwc_c(klon,klev), fiwc_c(klon,klev)
334      REAL flwp_s(klon), fiwp_s(klon)
335      REAL flwc_s(klon,klev), fiwc_s(klon,klev)
336
337! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
338!      REAL evap_pot(klon,nbsrf)
339
340!IM ISCCP simulator v3.4
341!c dans clesphys.h top_height, overlap
342!cv3.4
343      INTEGER debug, debugcol
344!cym      INTEGER npoints
345!cym      PARAMETER(npoints=klon)
346!c
347      INTEGER sunlit(klon) !sunlit=1 if day; sunlit=0 if night
348      INTEGER nregISCtot
349      PARAMETER(nregISCtot=1)
350!c
351!c imin_debut, nbpti, jmin_debut, nbptj : parametres pour sorties sur 1 region rectangulaire
352!c y compris pour 1 point
353!c imin_debut : indice minimum de i; nbpti : nombre de points en direction i (longitude)
354!c jmin_debut : indice minimum de j; nbptj : nombre de points en direction j (latitude)
355      INTEGER imin_debut, nbpti
356      INTEGER jmin_debut, nbptj
357!IM parametres ISCCP BEG
358      INTEGER nbapp_isccp
359!     INTEGER nbapp_isccp,isccppas
360!     PARAMETER(isccppas=6) !appel du simulateurs tous les 6pas de temps de la physique
361!                           !i.e. toutes les 3 heures
362      INTEGER n
363      INTEGER ifreq_isccp(napisccp), freqin_pdt(napisccp)
364      DATA ifreq_isccp/3/
365      SAVE ifreq_isccp
366!$OMP THREADPRIVATE(ifreq_isccp)
367      CHARACTER*5 typinout(napisccp)
368      DATA typinout/'i3od'/
369      SAVE typinout
370!$OMP THREADPRIVATE(typinout)
371!IM verif boxptop BEG
372      CHARACTER*1 verticaxe(napisccp)
373      DATA verticaxe/'1'/
374      SAVE verticaxe
375!$OMP THREADPRIVATE(verticaxe)
376!IM verif boxptop END
377      INTEGER nvlev(napisccp)
378!c     INTEGER nvlev
379      REAL t1, aa
380      REAL seed_re(klon,napisccp)
381!cym !!!! A voir plus tard
382!cym      INTEGER iphy(iim,jjmp1)
383!IM parametres ISCCP END
384!c
385!c ncol = nb. de sous-colonnes pour chaque maille du GCM
386!c ncolmx = No. max. de sous-colonnes pour chaque maille du GCM
387!c      INTEGER ncol(napisccp), ncolmx, seed(klon,napisccp)
388      INTEGER,SAVE :: ncol(napisccp)
389!$OMP THREADPRIVATE(ncol)
390      INTEGER ncolmx, seed(klon,napisccp)
391      REAL nbsunlit(nregISCtot,klon,napisccp)  !nbsunlit : moyenne de sunlit
392!c     PARAMETER(ncolmx=1500)
393      PARAMETER(ncolmx=300)
394!c
395!IM verif boxptop BEG
396      REAL vertlev(ncolmx,napisccp)
397!IM verif boxptop END
398!c
399      REAL,SAVE :: tautab_omp(0:255),tautab(0:255)
400      INTEGER,SAVE :: invtau_omp(-20:45000),invtau(-20:45000)
401!$OMP THREADPRIVATE(tautab,invtau)
402      REAL emsfc_lw
403      PARAMETER(emsfc_lw=0.99)
404!c     REAL    ran0                      ! type for random number fuction
405!c
406      REAL cldtot(klon,klev)
407!c variables de haut en bas pour le simulateur ISCCP
408      REAL dtau_s(klon,klev) !tau nuages startiformes
409      REAL dtau_c(klon,klev) !tau nuages convectifs
410      REAL dem_s(klon,klev)  !emissivite nuages startiformes
411      REAL dem_c(klon,klev)  !emissivite nuages convectifs
412!c
413!c variables de haut en bas pour le simulateur ISCCP
414      REAL pfull(klon,klev)
415      REAL phalf(klon,klev+1)
416      REAL qv(klon,klev)
417      REAL cc(klon,klev)
418      REAL conv(klon,klev)
419      REAL dtau_sH2B(klon,klev)
420      REAL dtau_cH2B(klon,klev)
421      REAL at(klon,klev)
422      REAL dem_sH2B(klon,klev)
423      REAL dem_cH2B(klon,klev)
424!c
425      INTEGER kmax, lmax, lmax3
426      PARAMETER(kmax=8, lmax=8, lmax3=3)
427      INTEGER kmaxm1, lmaxm1
428      PARAMETER(kmaxm1=kmax-1, lmaxm1=lmax-1)
429      INTEGER iimx7, jjmx7, jjmp1x7
430      PARAMETER(iimx7=iim*kmaxm1, jjmx7=jjm*lmaxm1,                                  &
431       &jjmp1x7=jjmp1*lmaxm1)
432!c
433!c output from ISCCP simulator
434      REAL fq_isccp(klon,kmaxm1,lmaxm1,napisccp)
435      REAL fq_is_true(klon,kmaxm1,lmaxm1,napisccp)
436      REAL totalcldarea(klon,napisccp)
437      REAL meanptop(klon,napisccp)
438      REAL meantaucld(klon,napisccp)
439      REAL boxtau(klon,ncolmx,napisccp)
440      REAL boxptop(klon,ncolmx,napisccp)
441      REAL zx_tmp_fi3d_bx(klon,ncolmx)
442      REAL zx_tmp_3d_bx(iim,jjmp1,ncolmx)
443!c
444      REAL cld_fi3d(klon,lmax3)
445      REAL cld_3d(iim,jjmp1,lmax3)
446!c
447      INTEGER iw, iwmax
448      REAL wmin, pas_w
449!c     PARAMETER(wmin=-100.,pas_w=10.,iwmax=30)
450!IM 051005     PARAMETER(wmin=-200.,pas_w=10.,iwmax=40)
451      PARAMETER(wmin=-100.,pas_w=10.,iwmax=20)
452      REAL o500(klon)
453!c
454
455!c sorties ISCCP
456
457      integer nid_isccp
458      save nid_isccp       
459!$OMP THREADPRIVATE(nid_isccp)
460
461      REAL zx_tau(kmaxm1), zx_pc(lmaxm1), zx_o500(iwmax)
462      DATA zx_tau/0.0, 0.3, 1.3, 3.6, 9.4, 23., 60./
463      SAVE zx_tau
464      DATA zx_pc/180., 310., 440., 560., 680., 800., 1000./
465      SAVE zx_pc
466!$OMP THREADPRIVATE(zx_tau,zx_pc)
467!c cldtopres pression au sommet des nuages
468      REAL cldtopres(lmaxm1), cldtopres3(lmax3)
469      DATA cldtopres/180., 310., 440., 560., 680., 800., 1000./
470      DATA cldtopres3/440., 680., 1000./
471      SAVE cldtopres,cldtopres3
472!$OMP THREADPRIVATE(cldtopres,cldtopres3)
473!IM 051005 BEG
474      INTEGER komega, nhoriRD
475
476!c taulev: numero du niveau de tau dans les sorties ISCCP
477      CHARACTER *4 taulev(kmaxm1)
478!c     DATA taulev/'tau1','tau2','tau3','tau4','tau5','tau6','tau7'/
479      DATA taulev/'tau0','tau1','tau2','tau3','tau4','tau5','tau6'/
480      CHARACTER *3 pclev(lmaxm1)
481      DATA pclev/'pc1','pc2','pc3','pc4','pc5','pc6','pc7'/
482      SAVE taulev,pclev
483!$OMP THREADPRIVATE(taulev,pclev)
484!c
485!c cnameisccp
486      CHARACTER *29 cnameisccp(lmaxm1,kmaxm1)
487!IM bad 151205     DATA cnameisccp/'pc< 50hPa, tau< 0.3',
488      DATA cnameisccp/'pc= 50-180hPa, tau< 0.3',                                     &
489       &                'pc= 180-310hPa, tau< 0.3',                                  &
490       &                'pc= 310-440hPa, tau< 0.3',                                  &
491       &                'pc= 440-560hPa, tau< 0.3',                                  &
492       &                'pc= 560-680hPa, tau< 0.3',                                  &
493       &                'pc= 680-800hPa, tau< 0.3',                                  &
494       &                'pc= 800-1000hPa, tau< 0.3',                                 &
495       &                'pc= 50-180hPa, tau= 0.3-1.3',                               &
496       &                'pc= 180-310hPa, tau= 0.3-1.3',                              &
497       &                'pc= 310-440hPa, tau= 0.3-1.3',                              &
498       &                'pc= 440-560hPa, tau= 0.3-1.3',                              &
499       &                'pc= 560-680hPa, tau= 0.3-1.3',                              &
500       &                'pc= 680-800hPa, tau= 0.3-1.3',                              &
501       &                'pc= 800-1000hPa, tau= 0.3-1.3',                             &
502       &                'pc= 50-180hPa, tau= 1.3-3.6',                               &
503       &                'pc= 180-310hPa, tau= 1.3-3.6',                              &
504       &                'pc= 310-440hPa, tau= 1.3-3.6',                              &
505       &                'pc= 440-560hPa, tau= 1.3-3.6',                              &
506       &                'pc= 560-680hPa, tau= 1.3-3.6',                              &
507       &                'pc= 680-800hPa, tau= 1.3-3.6',                              &
508       &                'pc= 800-1000hPa, tau= 1.3-3.6',                             &
509       &                'pc= 50-180hPa, tau= 3.6-9.4',                               &
510       &                'pc= 180-310hPa, tau= 3.6-9.4',                              &
511       &                'pc= 310-440hPa, tau= 3.6-9.4',                              &
512       &                'pc= 440-560hPa, tau= 3.6-9.4',                              &
513       &                'pc= 560-680hPa, tau= 3.6-9.4',                              &
514       &                'pc= 680-800hPa, tau= 3.6-9.4',                              &
515       &                'pc= 800-1000hPa, tau= 3.6-9.4',                             &
516       &                'pc= 50-180hPa, tau= 9.4-23',                                &
517       &                'pc= 180-310hPa, tau= 9.4-23',                               &
518       &                'pc= 310-440hPa, tau= 9.4-23',                               &
519       &                'pc= 440-560hPa, tau= 9.4-23',                               &
520       &                'pc= 560-680hPa, tau= 9.4-23',                               &
521       &                'pc= 680-800hPa, tau= 9.4-23',                               &
522       &                'pc= 800-1000hPa, tau= 9.4-23',                              &
523       &                'pc= 50-180hPa, tau= 23-60',                                 &
524       &                'pc= 180-310hPa, tau= 23-60',                                &
525       &                'pc= 310-440hPa, tau= 23-60',                                &
526       &                'pc= 440-560hPa, tau= 23-60',                                &
527       &                'pc= 560-680hPa, tau= 23-60',                                &
528       &                'pc= 680-800hPa, tau= 23-60',                                &
529       &                'pc= 800-1000hPa, tau= 23-60',                               &
530       &                'pc= 50-180hPa, tau> 60.',                                   &
531       &                'pc= 180-310hPa, tau> 60.',                                  &
532       &                'pc= 310-440hPa, tau> 60.',                                  &
533       &                'pc= 440-560hPa, tau> 60.',                                  &
534       &                'pc= 560-680hPa, tau> 60.',                                  &
535       &                'pc= 680-800hPa, tau> 60.',                                  &
536       &                'pc= 800-1000hPa, tau> 60.'/
537       SAVE cnameisccp
538!$OMP THREADPRIVATE(cnameisccp)
539!c
540!c     REAL zx_lonx7(iimx7), zx_latx7(jjmp1x7)
541!c     INTEGER nhorix7
542!IM: region='3d' <==> sorties en global
543      CHARACTER*3 region
544      PARAMETER(region='3d')
545!c
546!IM ISCCP simulator v3.4
547!c
548      logical ok_hf
549!c
550      integer nid_hf, nid_hf3d
551      save ok_hf, nid_hf, nid_hf3d
552!$OMP THREADPRIVATE(ok_hf, nid_hf, nid_hf3d)
553!c  QUESTION : noms de variables ?
554
555      INTEGER        longcles
556      PARAMETER    ( longcles = 20 )
557      REAL clesphy0( longcles      )
558!c
559!c Variables propres a la physique
560      INTEGER itap
561      SAVE itap                   ! compteur pour la physique
562!$OMP THREADPRIVATE(itap)
563!c
564! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
565!      real slp(klon) ! sea level pressure
566!c
567! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
568!      REAL fevap(klon,nbsrf)
569!      REAL fluxlat(klon,nbsrf)
570!c
571! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
572!      REAL qsol(klon)
573      REAL,save ::  solarlong0
574!$OMP THREADPRIVATE(solarlong0)
575
576!c
577!c  Parametres de l'Orographie a l'Echelle Sous-Maille (OESM):
578!c
579!IM 141004     REAL zulow(klon),zvlow(klon),zustr(klon), zvstr(klon)
580      REAL zulow(klon),zvlow(klon)
581!c
582      INTEGER igwd,idx(klon),itest(klon)
583!c
584! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
585!      REAL agesno(klon,nbsrf)
586
587!c
588!c      REAL,allocatable,save :: run_off_lic_0(:)
589!cc$OMP THREADPRIVATE(run_off_lic_0)
590!cym      SAVE run_off_lic_0
591!cKE43
592!c Variables liees a la convection de K. Emanuel (sb):
593!c
594      REAL bas, top             ! cloud base and top levels
595      SAVE bas
596      SAVE top
597!$OMP THREADPRIVATE(bas, top)
598
599      REAL wdn(klon), tdn(klon), qdn(klon)
600!c
601!c=================================================================================================
602!cCR04.12.07: on ajoute les nouvelles variables du nouveau schema de convection avec poches froides
603!c Variables li\'ees \`a la poche froide (jyg)
604
605      REAL mip(klon,klev)  ! mass flux shed by the adiab ascent at each level
606! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
607!      REAL Vprecip(klon,klev+1)   ! precipitation vertical profile
608!c
609      REAL wape_prescr, fip_prescr
610      INTEGER it_wape_prescr
611      SAVE wape_prescr, fip_prescr, it_wape_prescr
612!$OMP THREADPRIVATE(wape_prescr, fip_prescr, it_wape_prescr)
613!c
614!c variables supplementaires de concvl
615      REAL Tconv(klon,klev)
616      REAL ment(klon,klev,klev),sij(klon,klev,klev)
617      REAL dd_t(klon,klev),dd_q(klon,klev)
618
619      real, save :: alp_bl_prescr=0.
620      real, save :: ale_bl_prescr=0.
621
622      real, save :: ale_max=1000.
623      real, save :: alp_max=2.
624
625      real, save :: wake_s_min_lsp=0.1
626
627!$OMP THREADPRIVATE(alp_bl_prescr,ale_bl_prescr)
628!$OMP THREADPRIVATE(ale_max,alp_max)
629!$OMP THREADPRIVATE(wake_s_min_lsp)
630
631! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
632!      real ale_wake(klon)
633!      real alp_wake(klon)
634
635      real ok_wk_lsp(klon)
636
637!cRC
638!c Variables li\'ees \`a la poche froide (jyg et rr)
639!c Version diagnostique pour l'instant : pas de r\'etroaction sur la convection
640
641      REAL t_wake(klon,klev),q_wake(klon,klev) ! wake pour la convection
642
643      REAL wake_dth(klon,klev)        ! wake : temp pot difference
644
645      REAL wake_d_deltat_gw(klon,klev)! wake : delta T tendency due to Gravity Wave (/s)
646      REAL wake_omgbdth(klon,klev)    ! Wake : flux of Delta_Theta transported by LS omega
647      REAL wake_dp_omgb(klon,klev)    ! Wake : vertical gradient of large scale omega
648      REAL wake_dtKE(klon,klev)       ! Wake : differential heating (wake - unpertubed) CONV
649      REAL wake_dqKE(klon,klev)       ! Wake : differential moistening (wake - unpertubed) CONV
650      REAL wake_dtPBL(klon,klev)      ! Wake : differential heating (wake - unpertubed) PBL
651      REAL wake_dqPBL(klon,klev)      ! Wake : differential moistening (wake - unpertubed) PBL
652! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
653!      REAL wake_omg(klon,klev)        ! Wake : velocity difference (wake - unpertubed)
654      REAL wake_ddeltat(klon,klev),wake_ddeltaq(klon,klev)
655      REAL wake_dp_deltomg(klon,klev) ! Wake : gradient vertical de wake_omg
656      REAL wake_spread(klon,klev)     ! spreading term in wake_delt
657!c
658!cpourquoi y'a pas de save??
659! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
660!      REAL wake_h(klon)               ! Wake : hauteur de la poche froide
661!c
662      INTEGER wake_k(klon)            ! Wake sommet
663!c
664      REAL t_undi(klon,klev)               ! temperature moyenne dans la zone non perturbee
665      REAL q_undi(klon,klev)               ! humidite moyenne dans la zone non perturbee
666!c
667!cjyg
668!ccc      REAL wake_pe(klon)              ! Wake potential energy - WAPE
669
670      REAL wake_gfl(klon)             ! Gust Front Length
671      REAL wake_dens(klon)
672!c
673!c
674      REAL dt_dwn(klon,klev)
675      REAL dq_dwn(klon,klev)
676      REAL wdt_PBL(klon,klev)
677      REAL udt_PBL(klon,klev)
678      REAL wdq_PBL(klon,klev)
679      REAL udq_PBL(klon,klev)
680      REAL M_dwn(klon,klev)
681      REAL M_up(klon,klev)
682      REAL dt_a(klon,klev)
683      REAL dq_a(klon,klev)
684      REAL, SAVE :: alp_offset
685!$OMP THREADPRIVATE(alp_offset)
686
687!c
688!cRR:fin declarations poches froides
689!c=======================================================================================================
690
691      REAL zw2(klon,klev+1)
692
693! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
694!      REAL fraca(klon,klev+1)       
695      REAL ztv(klon,klev),ztva(klon,klev)
696      REAL zpspsk(klon,klev)
697      REAL ztla(klon,klev),zqla(klon,klev)
698      REAL zthl(klon,klev)
699
700!ccc nrlmd le 10/04/2012
701
702!c--------Stochastic Boundary Layer Triggering: ALE_BL--------
703!c---Propri\'et\'es du thermiques au LCL
704      real zlcl_th(klon)                                     ! Altitude du LCL calcul\'e continument (pcon dans thermcell_main.F90)
705      real fraca0(klon)                                      ! Fraction des thermiques au LCL
706      real w0(klon)                                          ! Vitesse des thermiques au LCL
707      real w_conv(klon)                                      ! Vitesse verticale de grande \'echelle au LCL
708      real tke0(klon,klev+1)                                 ! TKE au début du pas de temps
709      real therm_tke_max0(klon)                              ! TKE dans les thermiques au LCL
710      real env_tke_max0(klon)                                ! TKE dans l'environnement au LCL
711
712!c---Spectre de thermiques de type 2 au LCL
713      real n2(klon),s2(klon)
714      real ale_bl_stat(klon)
715
716!c---D\'eclenchement stochastique
717      integer :: tau_trig(klon)
718      real proba_notrig(klon)
719      real random_notrig(klon)
720
721!c--------Statistical Boundary Layer Closure: ALP_BL--------
722!c---Profils de TKE dans et hors du thermique
723      real pbl_tke_input(klon,klev+1,nbsrf)
724      real therm_tke_max(klon,klev)                          ! Profil de TKE dans les thermiques
725      real env_tke_max(klon,klev)                            ! Profil de TKE dans l'environnement
726
727!c---Fermeture statistique
728      real alp_bl_det(klon)                                     ! ALP d\'terministe du thermique unique
729      real alp_bl_fluct_m(klon)                                 ! ALP li\'ee aux fluctuations de flux de masse sous-nuageux
730      real alp_bl_fluct_tke(klon)                               ! ALP li\'ee aux fluctuations d'\'energie cin\'etique sous-nuageuse
731      real alp_bl_conv(klon)                                    ! ALP li\'ee \`a grande \'echelle
732      real alp_bl_stat(klon)                                    ! ALP totale
733
734!ccc fin nrlmd le 10/04/2012
735
736!c Variables locales pour la couche limite (al1):
737!c
738!cAl1      REAL pblh(klon)           ! Hauteur de couche limite
739!cAl1      SAVE pblh
740!c34EK
741!c
742!c Variables locales:
743!c
744! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
745!      REAL cdragh(klon) ! drag coefficient pour T and Q
746!      REAL cdragm(klon) ! drag coefficient pour vent
747!cAA
748!cAA  Pour phytrac
749      REAL u1(klon)             ! vents dans la premiere couche U
750      REAL v1(klon)             ! vents dans la premiere couche V
751
752! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule\n
753!      REAL zxffonte(klon), zxfqcalving(klon),zxfqfonte(klon)
754
755!@$$      LOGICAL offline           ! Controle du stockage ds "physique"
756!@$$      PARAMETER (offline=.false.)
757!@$$      INTEGER physid
758      REAL frac_impa(klon,klev) ! fractions d'aerosols lessivees (impaction)
759      REAL frac_nucl(klon,klev) ! idem (nucleation)
760! RomP >>>
761      REAL beta_prec_fisrt(klon,klev) ! taux de conv de l'eau cond (fisrt)
762! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
763!      REAL beta_prec(klon,klev)       ! taux de conv de l'eau cond (utilise)
764! RomP <<<
765      INTEGER       :: iii
766      REAL          :: calday
767
768!IM cf FH pour Tiedtke 080604
769      REAL rain_tiedtke(klon),snow_tiedtke(klon)
770!c
771!IM 050204 END
772! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
773!      REAL evap(klon), devap(klon) ! evaporation et sa derivee
774      REAL devap(klon) ! evaporation et sa derivee
775
776! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
777!      REAL sens(klon), dsens(klon) ! chaleur sensible et sa derivee
778      REAL dsens(klon) ! chaleur sensible et sa derivee
779
780! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
781!      REAL bils(klon) ! bilan de chaleur au sol
782!      REAL wfbilo(klon,nbsrf) ! bilan d'eau, pour chaque
783!C                             ! type de sous-surface et pondere par la fraction
784!      REAL wfbils(klon,nbsrf) ! bilan de chaleur au sol, pour chaque
785!C                             ! type de sous-surface et pondere par la fraction
786      REAL slab_wfbils(klon)  ! bilan de chaleur au sol pour le cas de slab, sur les points d'ocean
787
788! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
789!      REAL fder(klon)         
790!      REAL ve(klon) ! integr. verticale du transport meri. de l'energie
791!      REAL vq(klon) ! integr. verticale du transport meri. de l'eau
792!      REAL ue(klon) ! integr. verticale du transport zonal de l'energie
793!      REAL uq(klon) ! integr. verticale du transport zonal de l'eau
794!c
795
796! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
797!      REAL frugs(klon,nbsrf)
798!      REAL zxrugs(klon) ! longueur de rugosite
799!c
800!c Conditions aux limites
801!c
802!
803      REAL :: day_since_equinox
804! Date de l'equinoxe de printemps
805      INTEGER, parameter :: mth_eq=3, day_eq=21
806      REAL :: jD_eq
807
808      LOGICAL, parameter :: new_orbit = .true.
809
810!c
811      INTEGER lmt_pas
812      SAVE lmt_pas                ! frequence de mise a jour
813!$OMP THREADPRIVATE(lmt_pas)
814! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
815!      real zmasse(klon, llm),exner(klon, llm)
816      real exner(klon, llm)
817!C     (column-density of mass of air in a cell, in kg m-2)
818      real, parameter:: dobson_u = 2.1415e-05 ! Dobson unit, in kg m-2
819
820!IM sorties
821      REAL un_jour
822      PARAMETER(un_jour=86400.)
823!c======================================================================
824!c
825!c Declaration des procedures appelees
826!c
827      EXTERNAL angle     ! calculer angle zenithal du soleil
828      EXTERNAL alboc     ! calculer l'albedo sur ocean
829      EXTERNAL ajsec     ! ajustement sec
830      EXTERNAL conlmd    ! convection (schema LMD)
831!cKE43
832      EXTERNAL conema3  ! convect4.3
833      EXTERNAL fisrtilp  ! schema de condensation a grande echelle (pluie)
834!cAA
835      EXTERNAL fisrtilp_tr ! schema de condensation a grande echelle (pluie)
836!c                          ! stockage des coefficients necessaires au
837!c                          ! lessivage OFF-LINE et ON-LINE
838      EXTERNAL hgardfou  ! verifier les temperatures
839      EXTERNAL nuage     ! calculer les proprietes radiatives
840!CC      EXTERNAL o3cm      ! initialiser l'ozone
841      EXTERNAL orbite    ! calculer l'orbite terrestre
842      EXTERNAL phyetat0  ! lire l'etat initial de la physique
843      EXTERNAL phyredem  ! ecrire l'etat de redemarrage de la physique
844      EXTERNAL suphel    ! initialiser certaines constantes
845      EXTERNAL transp    ! transport total de l'eau et de l'energie
846      EXTERNAL ecribina  ! ecrire le fichier binaire global
847      EXTERNAL ecribins  ! ecrire le fichier binaire global
848      EXTERNAL ecrirega  ! ecrire le fichier binaire regional
849      EXTERNAL ecriregs  ! ecrire le fichier binaire regional
850!IM
851      EXTERNAL haut2bas  !variables de haut en bas
852      EXTERNAL ini_undefSTD  !initialise a 0 une variable a 1 niveau de pression
853      EXTERNAL undefSTD      !somme les valeurs definies d'1 var a 1 niveau de pression
854!c     EXTERNAL moy_undefSTD  !moyenne d'1 var a 1 niveau de pression
855!c     EXTERNAL moyglo_aire   !moyenne globale d'1 var ponderee par l'aire de la maille (moyglo_pondaire)
856!c                            !par la masse/airetot (moyglo_pondaima) et la vraie masse (moyglo_pondmass)
857!c
858!c Variables locales
859!c
860      REAL rhcl(klon,klev)    ! humiditi relative ciel clair
861      REAL dialiq(klon,klev)  ! eau liquide nuageuse
862      REAL diafra(klon,klev)  ! fraction nuageuse
863      REAL cldliq(klon,klev)  ! eau liquide nuageuse
864! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
865!      REAL cldfra(klon,klev)  ! fraction nuageuse
866!      REAL cldtau(klon,klev)  ! epaisseur optique
867!      REAL cldemi(klon,klev)  ! emissivite infrarouge
868!c
869!CXXX PB
870! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
871      REAL fluxq(klon,klev, nbsrf)   ! flux turbulent d'humidite
872!      REAL fluxt(klon,klev, nbsrf)   ! flux turbulent de chaleur
873!      REAL fluxu(klon,klev, nbsrf)   ! flux turbulent de vitesse u
874!      REAL fluxv(klon,klev, nbsrf)   ! flux turbulent de vitesse v
875!c
876      REAL zxfluxt(klon, klev)
877      REAL zxfluxq(klon, klev)
878      REAL zxfluxu(klon, klev)
879      REAL zxfluxv(klon, klev)
880!CXXX
881!c
882! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
883!      REAL fsollw(klon, nbsrf)   ! bilan flux IR pour chaque sous surface
884!      REAL fsolsw(klon, nbsrf)   ! flux solaire absorb. pour chaque sous surface
885!c Le rayonnement n'est pas calcule tous les pas, il faut donc
886!c                      sauvegarder les sorties du rayonnement
887!cym      SAVE  heat,cool,albpla,topsw,toplw,solsw,sollw,sollwdown
888!cym      SAVE  sollwdownclr, toplwdown, toplwdownclr
889!cym      SAVE  topsw0,toplw0,solsw0,sollw0, heat0, cool0
890!c
891      INTEGER itaprad
892      SAVE itaprad
893!$OMP THREADPRIVATE(itaprad)
894!c
895      REAL conv_q(klon,klev) ! convergence de l'humidite (kg/kg/s)
896      REAL conv_t(klon,klev) ! convergence de la temperature(K/s)
897!c
898! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
899!      REAL cldl(klon),cldm(klon),cldh(klon) !nuages bas, moyen et haut
900!      REAL cldt(klon),cldq(klon) !nuage total, eau liquide integree
901!c
902!      REAL zxtsol(klon), zxqsurf(klon), zxsnow(klon), zxfluxlat(klon)
903      REAL zxsnow_dummy(klon)
904!c
905      REAL dist, rmu0(klon), fract(klon)
906      REAL zdtime, zlongi
907!c
908      CHARACTER*2 str2
909      CHARACTER*2 iqn
910!c
911      REAL qcheck
912      REAL z_avant(klon), z_apres(klon), z_factor(klon)
913      LOGICAL zx_ajustq
914!c
915      REAL za, zb
916      REAL zx_t, zx_qs, zdelta, zcor, zfra, zlvdcp, zlsdcp
917      real zqsat(klon,klev)
918      INTEGER i, k, iq, ig, j, nsrf, ll, l, iiq, iff
919      REAL t_coup
920      PARAMETER (t_coup=234.0)
921!c
922! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
923!      REAL zphi(klon,klev)
924!cym A voir plus tard !!
925!cym      REAL zx_relief(iim,jjmp1)
926!cym      REAL zx_aire(iim,jjmp1)
927!c
928!c Grandeurs de sorties
929! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
930!      REAL s_pblh(klon), s_lcl(klon), s_capCL(klon)
931!      REAL s_oliqCL(klon), s_cteiCL(klon), s_pblt(klon)
932!      REAL s_therm(klon), s_trmb1(klon), s_trmb2(klon)
933      REAL s_capCL(klon)
934      REAL s_oliqCL(klon), s_cteiCL(klon)
935      REAL s_trmb1(klon), s_trmb2(klon)
936      REAL s_trmb3(klon)
937!cKE43
938!c Variables locales pour la convection de K. Emanuel (sb):
939!c
940! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
941!      REAL upwd(klon,klev)      ! saturated updraft mass flux
942!      REAL dnwd(klon,klev)      ! saturated downdraft mass flux
943!      REAL dnwd0(klon,klev)     ! unsaturated downdraft mass flux
944      REAL tvp(klon,klev)       ! virtual temp of lifted parcel
945!      REAL plcl(klon)           ! Lifting Condensation Level
946!      REAL plfc(klon)           ! Level of Free Convection
947!      REAL wbeff(klon)          ! saturated updraft velocity at LFC
948      CHARACTER*40 capemaxcels  !max(CAPE)
949
950      REAL rflag(klon)          ! flag fonctionnement de convect
951      INTEGER iflagctrl(klon)          ! flag fonctionnement de convect
952
953!c -- convect43:
954      INTEGER ntra              ! nb traceurs pour convect4.3
955      REAL pori_con(klon)    ! pressure at the origin level of lifted parcel
956      REAL dtma_con(klon),dtlcl_con(klon)
957      REAL dtvpdt1(klon,klev), dtvpdq1(klon,klev)
958      REAL dplcldt(klon), dplcldr(klon)
959!c?     .     condm_con(klon,klev),conda_con(klon,klev),
960!c?     .     mr_con(klon,klev),ep_con(klon,klev)
961!c?     .    ,sadiab(klon,klev),wadiab(klon,klev)
962!c --
963!c34EK
964!c
965!c Variables du changement
966!c
967!c con: convection
968!c lsc: condensation a grande echelle (Large-Scale-Condensation)
969!c ajs: ajustement sec
970!c eva: evaporation de l'eau liquide nuageuse
971!c vdf: couche limite (Vertical DiFfusion)
972! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
973!      REAL rneb(klon,klev)
974
975! tendance nulles
976      REAL du0(klon,klev),dv0(klon,klev),dq0(klon,klev),dql0(klon,klev)
977
978!c
979!*********************************************************
980!*     declarations
981     
982!*********************************************************
983!IM 081204 END
984!c
985! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
986!      REAL pmfu(klon,klev), pmfd(klon,klev)
987      REAL pen_u(klon,klev), pen_d(klon,klev)
988      REAL pde_u(klon,klev), pde_d(klon,klev)
989      INTEGER kcbot(klon), kctop(klon), kdtop(klon)
990! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
991!      REAL pmflxr(klon,klev+1), pmflxs(klon,klev+1)
992!      REAL prfl(klon,klev+1), psfl(klon,klev+1)
993!c
994! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
995!      REAL rain_lsc(klon)
996!      REAL snow_lsc(klon)
997!c
998      REAL ratqsc(klon,klev)
999      real ratqsbas,ratqshaut,tau_ratqs
1000      save ratqsbas,ratqshaut,tau_ratqs
1001!$OMP THREADPRIVATE(ratqsbas,ratqshaut,tau_ratqs)
1002      real zpt_conv(klon,klev)
1003
1004!c Parametres lies au nouveau schema de nuages (SB, PDF)
1005      real fact_cldcon
1006      real facttemps
1007      logical ok_newmicro
1008      save ok_newmicro
1009! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
1010!      real ref_liq(klon,klev), ref_ice(klon,klev)
1011
1012!$OMP THREADPRIVATE(ok_newmicro)
1013      save fact_cldcon,facttemps
1014!$OMP THREADPRIVATE(fact_cldcon,facttemps)
1015
1016      integer iflag_cldcon
1017      save iflag_cldcon
1018!$OMP THREADPRIVATE(iflag_cldcon)
1019! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
1020!      logical ptconv(klon,klev)
1021!IM cf. AM 081204 BEG
1022      logical ptconvth(klon,klev)
1023!IM cf. AM 081204 END
1024!c
1025!c Variables liees a l'ecriture de la bande histoire physique
1026!c
1027!c======================================================================
1028!c
1029!IM cf. AM 081204 BEG
1030!c   declarations pour sortir sur une sous-region
1031      integer imin_ins,imax_ins,jmin_ins,jmax_ins
1032      save imin_ins,imax_ins,jmin_ins,jmax_ins
1033!$OMP THREADPRIVATE(imin_ins,imax_ins,jmin_ins,jmax_ins)
1034!c      real lonmin_ins,lonmax_ins,latmin_ins
1035!c     s  ,latmax_ins
1036!c     data lonmin_ins,lonmax_ins,latmin_ins
1037!c    s  ,latmax_ins/
1038!c valeurs initiales     s   -5.,20.,41.,55./   
1039!c    s   100.,130.,-20.,20./
1040!c    s   -180.,180.,-90.,90./
1041!c======================================================================
1042!IM cf. AM 081204 END
1043
1044!c
1045      integer itau_w   ! pas de temps ecriture = itap + itau_phy
1046!c
1047!c
1048!c Variables locales pour effectuer les appels en serie
1049!c
1050! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule\n
1051!      REAL zx_rh(klon,klev)
1052!IM RH a 2m (la surface)
1053! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
1054!      REAL rh2m(klon), qsat2m(klon)
1055!      REAL tpot(klon), tpote(klon)
1056      REAL Lheat
1057
1058      INTEGER        length
1059      PARAMETER    ( length = 100 )
1060      REAL tabcntr0( length       )
1061!c
1062      INTEGER ndex2d(iim*jjmp1),ndex3d(iim*jjmp1*klev)
1063!IM
1064      INTEGER ndex2d1(iwmax)
1065!c
1066!IM AMIP2 BEG
1067      REAL moyglo, mountor
1068!IM 141004 BEG
1069      REAL zustrdr(klon), zvstrdr(klon)
1070      REAL zustrli(klon), zvstrli(klon)
1071      REAL zustrph(klon), zvstrph(klon)
1072      REAL zustrhi(klon), zvstrhi(klon)
1073      REAL aam, torsfc
1074!IM 141004 END
1075!IM 190504 BEG
1076      INTEGER ij, imp1jmp1
1077      PARAMETER(imp1jmp1=(iim+1)*jjmp1)
1078!cym A voir plus tard
1079      REAL zx_tmp(imp1jmp1), airedyn(iim+1,jjmp1)
1080      REAL padyn(iim+1,jjmp1,klev+1)
1081      REAL dudyn(iim+1,jjmp1,klev)
1082      REAL rlatdyn(iim+1,jjmp1)
1083!IM 190504 END
1084      LOGICAL ok_msk
1085      REAL msk(klon)
1086!IM
1087      REAL airetot, pi
1088!cym A voir plus tard
1089!cym      REAL zm_wo(jjmp1, klev)
1090!IM AMIP2 END
1091!c
1092      REAL zx_tmp_fi2d(klon)      ! variable temporaire grille physique
1093      REAL zx_tmp_fi3d(klon,klev) ! variable temporaire pour champs 3D
1094      REAL zx_tmp_fi3d1(klon,klev+1) !variable temporaire pour champs 3D (kelvp1)
1095      REAL(KIND=8) zx_tmp2_fi3d(klon,klev) ! variable temporaire pour champs 3D
1096      REAL zx_tmp_2d(iim,jjmp1), zx_tmp_3d(iim,jjmp1,klev)
1097      REAL zx_lon(iim,jjmp1), zx_lat(iim,jjmp1)
1098!c
1099      INTEGER nid_day, nid_mth, nid_ins, nid_mthnmc, nid_daynmc
1100      INTEGER nid_hfnmc, nid_day_seri, nid_ctesGCM
1101      SAVE nid_day, nid_mth, nid_ins, nid_mthnmc, nid_daynmc
1102      SAVE nid_hfnmc, nid_day_seri, nid_ctesGCM
1103!$OMP THREADPRIVATE(nid_day, nid_mth, nid_ins)
1104!$OMP THREADPRIVATE(nid_mthnmc, nid_daynmc, nid_hfnmc)
1105!$OMP THREADPRIVATE(nid_day_seri,nid_ctesGCM)
1106!c
1107!IM 280405 BEG
1108      INTEGER nid_bilKPins, nid_bilKPave
1109      SAVE nid_bilKPins, nid_bilKPave
1110!$OMP THREADPRIVATE(nid_bilKPins, nid_bilKPave)
1111!c
1112      REAL ve_lay(klon,klev) ! transport meri. de l'energie a chaque niveau vert.
1113      REAL vq_lay(klon,klev) ! transport meri. de l'eau a chaque niveau vert.
1114      REAL ue_lay(klon,klev) ! transport zonal de l'energie a chaque niveau vert.
1115      REAL uq_lay(klon,klev) ! transport zonal de l'eau a chaque niveau vert.
1116!c
1117      INTEGER nhori, nvert, nvert1, nvert3
1118      REAL zsto, zsto1, zsto2
1119      REAL zstophy, zstorad, zstohf, zstoday, zstomth, zout
1120      REAL zcals(napisccp), zcalh(napisccp), zoutj(napisccp)
1121      REAL zout_isccp(napisccp)
1122      SAVE zcals, zcalh, zoutj, zout_isccp
1123!$OMP THREADPRIVATE(zcals, zcalh, zoutj, zout_isccp)
1124
1125      real zjulian
1126      save zjulian
1127!$OMP THREADPRIVATE(zjulian)
1128
1129      character*20 modname
1130      character*80 abort_message
1131      logical ok_sync
1132      real date0
1133      integer idayref
1134
1135!C essai writephys
1136      integer fid_day, fid_mth, fid_ins
1137      parameter (fid_ins = 1, fid_day = 2, fid_mth = 3)
1138      integer prof2d_on, prof3d_on, prof2d_av, prof3d_av
1139      parameter (prof2d_on = 1, prof3d_on = 2,                                       &
1140       &           prof2d_av = 3, prof3d_av = 4)
1141      character*30 nom_fichier
1142      character*40 varname
1143      character*40 vartitle
1144      character*20 varunits
1145!C     Variables liees au bilan d'energie et d'enthalpi
1146      REAL ztsol(klon)
1147      REAL      h_vcol_tot, h_dair_tot, h_qw_tot, h_ql_tot                           &
1148       &        , h_qs_tot, qw_tot, ql_tot, qs_tot , ec_tot
1149      SAVE      h_vcol_tot, h_dair_tot, h_qw_tot, h_ql_tot                           &
1150       &        , h_qs_tot, qw_tot, ql_tot, qs_tot , ec_tot
1151!$OMP THREADPRIVATE(h_vcol_tot, h_dair_tot, h_qw_tot, h_ql_tot,
1152!$OMP+              h_qs_tot, qw_tot, ql_tot, qs_tot , ec_tot)
1153      REAL      d_h_vcol, d_h_dair, d_qt, d_qw, d_ql, d_qs, d_ec
1154      REAL      d_h_vcol_phy
1155      REAL      fs_bound, fq_bound
1156      SAVE      d_h_vcol_phy
1157!$OMP THREADPRIVATE(d_h_vcol_phy)
1158      REAL      zero_v(klon)
1159      CHARACTER*15 ztit
1160      INTEGER   ip_ebil  ! PRINT level for energy conserv. diag.
1161      SAVE      ip_ebil
1162      DATA      ip_ebil/0/
1163!$OMP THREADPRIVATE(ip_ebil)
1164      INTEGER   if_ebil ! level for energy conserv. dignostics
1165      SAVE      if_ebil
1166!$OMP THREADPRIVATE(if_ebil)
1167!c+jld ec_conser
1168      REAL ZRCPD
1169!c-jld ec_conser
1170! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
1171!      REAL t2m(klon,nbsrf)  ! temperature a 2m
1172      REAL q2m(klon,nbsrf)  ! humidite a 2m
1173
1174!IM: t2m, q2m, ustar, u10m, v10m et t2mincels, t2maxcels
1175! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
1176!      REAL zt2m(klon), zq2m(klon)             !temp., hum. 2m moyenne s/ 1 maille
1177!      REAL zustar(klon),zu10m(klon), zv10m(klon)  ! u* et vents a 10m moyennes s/1 maille
1178      CHARACTER*40 t2mincels, t2maxcels       !t2m min., t2m max
1179      CHARACTER*40 tinst, tave, typeval
1180      REAL cldtaupi(klon,klev)  ! Cloud optical thickness for pre-industrial (pi) aerosols
1181
1182! L. Fita, LMD. January 2014. Defined in output_lmdz_NOmodule
1183!      REAL re(klon, klev)       ! Cloud droplet effective radius
1184!      REAL fl(klon, klev)  ! denominator of re
1185
1186      REAL re_top(klon), fl_top(klon) ! CDR at top of liquid water clouds
1187
1188      ! Aerosol optical properties
1189      CHARACTER*4, DIMENSION(naero_grp) :: rfname
1190      REAL, DIMENSION(klon)          :: aerindex     ! POLDER aerosol index
1191      REAL, DIMENSION(klon,klev)     :: mass_solu_aero    ! total mass concentration for all soluble aerosols[ug/m3]
1192      REAL, DIMENSION(klon,klev)     :: mass_solu_aero_pi ! - " - (pre-industrial value)
1193      INTEGER :: naero ! aerosol species
1194
1195      ! Parameters
1196      LOGICAL ok_ade, ok_aie    ! Apply aerosol (in)direct effects or not
1197      LOGICAL ok_cdnc          ! ok cloud droplet number concentration (O. Boucher 01-2013)
1198      REAL bl95_b0, bl95_b1   ! Parameter in Boucher and Lohmann (1995)
1199      SAVE ok_ade, ok_aie, ok_cdnc, bl95_b0, bl95_b1
1200!$OMP THREADPRIVATE(ok_ade, ok_aie, ok_cdnc, bl95_b0, bl95_b1)
1201      LOGICAL, SAVE :: aerosol_couple ! true  : calcul des aerosols dans INCA
1202                                      ! false : lecture des aerosol dans un fichier
1203!$OMP THREADPRIVATE(aerosol_couple)   
1204      INTEGER, SAVE :: flag_aerosol
1205!$OMP THREADPRIVATE(flag_aerosol)
1206      LOGICAL, SAVE :: new_aod
1207!$OMP THREADPRIVATE(new_aod)
1208!c
1209!c--STRAT AEROSOL
1210      LOGICAL, SAVE :: flag_aerosol_strat
1211!$OMP THREADPRIVATE(flag_aerosol_strat)
1212!cc-fin STRAT AEROSOL
1213!c
1214!c Declaration des constantes et des fonctions thermodynamiques
1215!c
1216      LOGICAL,SAVE :: first=.true.
1217!$OMP THREADPRIVATE(first)
1218
1219      integer iunit
1220
1221      integer, save::  read_climoz ! read ozone climatology
1222!C     (let it keep the default OpenMP shared attribute)
1223!C     Allowed values are 0, 1 and 2
1224!C     0: do not read an ozone climatology
1225!C     1: read a single ozone climatology that will be used day and night
1226!C     2: read two ozone climatologies, the average day and night
1227!C     climatology and the daylight climatology
1228
1229      integer, save:: ncid_climoz ! NetCDF file containing ozone climatologies
1230!C     (let it keep the default OpenMP shared attribute)
1231
1232      real, pointer, save:: press_climoz(:)
1233!C     (let it keep the default OpenMP shared attribute)
1234!     edges of pressure intervals for ozone climatologies, in Pa, in strictly
1235!     ascending order
1236
1237      integer, save:: co3i = 0
1238!     time index in NetCDF file of current ozone fields
1239!$OMP THREADPRIVATE(co3i)
1240
1241      integer ro3i
1242!     required time index in NetCDF file for the ozone fields, between 1
1243!     and 360
1244
1245      INTEGER ierr
1246#include "YOMCST.h"
1247#include "YOETHF.h"
1248#include "FCTTRE.h"
1249!IM 100106 BEG : pouvoir sortir les ctes de la physique
1250#include "conema3.h"
1251#include "fisrtilp.h"
1252#include "nuage.h"
1253#include "compbl.h"
1254!IM 100106 END : pouvoir sortir les ctes de la physique
1255!c
1256!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
1257!c Declarations pour Simulateur COSP
1258!c============================================================
1259      real :: mr_ozone(klon,klev)
1260
1261!IM sorties fichier 1D paramLMDZ_phy.nc
1262      REAL :: zx_tmp_0d(1,1)
1263      INTEGER, PARAMETER :: np=1
1264      REAL,dimension(klon_glo)        :: rlat_glo
1265      REAL,dimension(klon_glo)        :: rlon_glo
1266      REAL gbils(1), gevap(1), gevapt(1), glat(1), gnet0(1), gnet(1)
1267      REAL grain(1), gtsol(1), gt2m(1), gprw(1)
1268
1269!IM stations CFMIP
1270      INTEGER, SAVE :: nCFMIP
1271!$OMP THREADPRIVATE(nCFMIP)
1272      INTEGER, PARAMETER :: npCFMIP=120
1273      INTEGER, ALLOCATABLE, SAVE :: tabCFMIP(:)
1274      REAL, ALLOCATABLE, SAVE :: lonCFMIP(:), latCFMIP(:)
1275!$OMP THREADPRIVATE(tabCFMIP, lonCFMIP, latCFMIP)
1276      INTEGER, ALLOCATABLE, SAVE :: tabijGCM(:)
1277      REAL, ALLOCATABLE, SAVE :: lonGCM(:), latGCM(:)
1278!$OMP THREADPRIVATE(tabijGCM, lonGCM, latGCM)
1279      INTEGER, ALLOCATABLE, SAVE :: iGCM(:), jGCM(:)
1280!$OMP THREADPRIVATE(iGCM, jGCM)
1281      logical, dimension(nfiles)            :: phys_out_filestations
1282      logical, parameter :: lNMC=.FALSE.
1283
1284!IM betaCRF
1285      REAL, SAVE :: pfree, beta_pbl, beta_free
1286!$OMP THREADPRIVATE(pfree, beta_pbl, beta_free)
1287      REAL, SAVE :: lon1_beta,  lon2_beta, lat1_beta, lat2_beta
1288!$OMP THREADPRIVATE(lon1_beta,  lon2_beta, lat1_beta, lat2_beta)
1289      LOGICAL, SAVE :: mskocean_beta
1290!$OMP THREADPRIVATE(mskocean_beta)
1291      REAL, dimension(klon, klev) :: beta         ! facteur sur cldtaurad et cldemirad pour evaluer les retros liees aux CRF
1292      REAL, dimension(klon, klev) :: cldtaurad    ! epaisseur optique pour radlwsw pour tester "CRF off"
1293      REAL, dimension(klon, klev) :: cldtaupirad  ! epaisseur optique pour radlwsw pour tester "CRF off"
1294      REAL, dimension(klon, klev) :: cldemirad    ! emissivite pour radlwsw pour tester "CRF off"
1295      REAL, dimension(klon, klev) :: cldfrarad    ! fraction nuageuse
1296
1297      INTEGER :: nbtr_tmp ! Number of tracer inside concvl
1298      REAL, dimension(klon,klev) :: sh_in ! Specific humidity entering in phytrac
1299      integer iostat
1300
1301! L. Fita, LMD. Point for checkings...
1302      INTEGER                                            :: llp
1303      llp = 644
1304
1305!c======================================================================
1306! Gestion calendrier : mise a jour du module phys_cal_mod
1307!
1308      CALL phys_cal_update(jD_cur,jH_cur)
1309
1310!c======================================================================
1311! Ecriture eventuelle d'un profil verticale en entree de la physique.
1312! Utilise notamment en 1D mais peut etre active egalement en 3D
1313! en imposant la valeur de igout.
1314!c======================================================================
1315
1316      if (prt_level.ge.1) then
1317! Lluis
1318!          igout=klon/2+1/klon
1319          igout=llp
1320         write(lunout,*) 'DEBUT DE PHYSIQ !!!!!!!!!!!!!!!!!!!!'
1321         write(lunout,*)                                                             &
1322       & 'nlon,klev,nqtot,debut,lafin, jD_cur, jH_cur,pdtphys'
1323         write(lunout,*)                                                             &
1324       &  nlon,klev,nqtot,debut,lafin, jD_cur, jH_cur,pdtphys
1325
1326         write(lunout,*) 'paprs, play, phi, u, v, t'
1327         do k=1,klev
1328            write(lunout,*) paprs(igout,k),pplay(igout,k),pphi(igout,k),             &
1329       &   u(igout,k),v(igout,k),t(igout,k)
1330         enddo
1331         write(lunout,*) 'ovap (g/kg),  oliq (g/kg)'
1332         do k=1,klev
1333            write(lunout,*) qx(igout,k,1)*1000,qx(igout,k,2)*1000.
1334         enddo
1335      endif
1336
1337!c======================================================================
1338
1339!cym => necessaire pour iflag_con != 2   
1340      pmfd(:,:) = 0.
1341      pen_u(:,:) = 0.
1342      pen_d(:,:) = 0.
1343      pde_d(:,:) = 0.
1344      pde_u(:,:) = 0.
1345      aam=0.
1346
1347      torsfc=0.
1348
1349      forall (k=1: llm) zmasse(:, k) = (paprs(:, k)-paprs(:, k+1)) / rg
1350
1351      if (first) then
1352     
1353!cCR:nvelles variables convection/poches froides
1354     
1355      print*, '================================================='
1356      print*, 'Allocation des variables locales et sauvegardees'
1357
1358      call phys_local_var_init
1359
1360!c
1361      pasphys=pdtphys
1362!c     appel a la lecture du run.def physique
1363      call conf_phys(ok_journe, ok_mensuel,                                          &
1364       &     ok_instan, ok_hf,                                                       &
1365       &     ok_LES,                                                                 &
1366       &     callstats,                                                              &
1367       &     solarlong0,seuil_inversion,                                             &
1368       &     fact_cldcon, facttemps,ok_newmicro,iflag_radia,                         &
1369       &     iflag_cldcon,iflag_ratqs,ratqsbas,ratqshaut,tau_ratqs,                  &
1370       &     ok_ade, ok_aie, ok_cdnc, aerosol_couple,                                &
1371       &     flag_aerosol, flag_aerosol_strat, new_aod,                              &
1372       &     bl95_b0, bl95_b1,                                                       &
1373!c     nv flags pour la convection et les poches froides                             &
1374       &     read_climoz,                                                            &
1375       &     alp_offset)
1376
1377
1378!!      call phys_state_var_init(read_climoz)
1379      call phys_output_var_init
1380
1381
1382!L. Fita, LMD. November 2013
1383! Initializing
1384! Variables have been already initialilzed from the WRF variables.
1385!   Using on purpose subroutines from physiq_limit_variables_mod
1386!!      CALL neige_initialize()
1387!!      CALL limit_initialize()
1388!!      CALL vars_limit_init(klon)
1389
1390! L. Fita, LMD January 2014. Initializing output variables
1391      CALL init_ovars_lmdz_NOmodule(klon,klev,nbsrf)
1392
1393! Allocating restart variables
1394!      ALLOCATE(qsol(klon))
1395!      ALLOCATE(fder(klon))
1396!      ALLOCATE(snow(klon, nbsrf))
1397!      ALLOCATE(qsurf(klon, nbsrf))
1398!      ALLOCATE(evap(klon, nbsrf))
1399!      ALLOCATE(rugos(klon, nbsrf))
1400!      ALLOCATE(agesno(klon, nbsrf))
1401!      ALLOCATE(ftsoil(klon, nsoilmx, nbsrf))
1402!!      ALLOCATE(restart_runoff(klon))
1403
1404!      CALL pbl_surface_init(qsol_rst, fder_rst, snow_rst, qsurf_rst, evap_rst,       &
1405!        rugos_rst, agesno_rst, ftsoil_rst)
1406!      CALL fonte_neige_init(restart_runoff)
1407!      qsol=qsol_rst
1408
1409      print*, '================================================='
1410!c
1411          dnwd0=0.0
1412          ftd=0.0
1413          fqd=0.0
1414          cin=0.
1415!cym Attention pbase pas initialise dans concvl !!!!
1416          pbase=0
1417!IM 180608
1418
1419        itau_con=0
1420        first=.false.
1421
1422      endif  ! first
1423
1424       modname = 'physiq'
1425!IM
1426      IF (ip_ebil_phy.ge.1) THEN
1427        DO i=1,klon
1428          zero_v(i)=0.
1429        END DO
1430      END IF
1431      ok_sync=.TRUE.
1432
1433      IF (debut) THEN
1434         CALL suphel ! initialiser constantes et parametres phys.
1435      ENDIF
1436
1437      if(prt_level.ge.1) print*,'CONVERGENCE PHYSIQUE THERM 1 '
1438
1439
1440!c======================================================================
1441! Gestion calendrier : mise a jour du module phys_cal_mod
1442!
1443!c     CALL phys_cal_update(jD_cur,jH_cur)
1444
1445!c
1446!c Si c'est le debut, il faut initialiser plusieurs choses
1447!c          ********
1448!c
1449
1450       IF (debut) THEN
1451!rv
1452!cCRinitialisation de wght_th et lalim_conv pour la definition de la couche alimentation
1453!cde la convection a partir des caracteristiques du thermique
1454         wght_th(:,:)=1.
1455         lalim_conv(:)=1
1456!cRC
1457         ustar(:,:)=0.
1458         u10m(:,:)=0.
1459         v10m(:,:)=0.
1460         rain_con(:)=0.
1461         snow_con(:)=0.
1462         topswai(:)=0.
1463         topswad(:)=0.
1464         solswai(:)=0.
1465         solswad(:)=0.
1466
1467         wmax_th(:)=0.
1468         tau_overturning_th(:)=0.
1469
1470         IF (type_trac == 'inca') THEN
1471            ! jg : initialisation jusqu'au ces variables sont dans restart
1472            ccm(:,:,:) = 0.
1473            tau_aero(:,:,:,:) = 0.
1474            piz_aero(:,:,:,:) = 0.
1475            cg_aero(:,:,:,:) = 0.
1476         END IF
1477
1478         rnebcon0(:,:) = 0.0
1479         clwcon0(:,:) = 0.0
1480         rnebcon(:,:) = 0.0
1481         clwcon(:,:) = 0.0
1482
1483!IM     
1484         IF (ip_ebil_phy.ge.1) d_h_vcol_phy=0.
1485!c
1486      print*,'iflag_coupl,iflag_clos,iflag_wake',                                    &
1487       &   iflag_coupl,iflag_clos,iflag_wake
1488      print*,'CYCLE_DIURNE', cycle_diurne
1489!c
1490      IF (iflag_con.EQ.2.AND.iflag_cldcon.GT.-1) THEN
1491         abort_message = 'Tiedtke needs iflag_cldcon=-2 or -1'
1492         CALL abort_gcm (modname,abort_message,1)
1493      ENDIF
1494!c
1495      IF(ok_isccp.AND.iflag_con.LE.2) THEN
1496         abort_message = 'ISCCP-like outputs may be available for KE                 &
1497       &(iflag_con >= 3); for Tiedtke (iflag_con=-2) put ok_isccp=n'
1498         CALL abort_gcm (modname,abort_message,1)
1499      ENDIF
1500!c
1501!c Initialiser les compteurs:
1502!c
1503         itap    = 0
1504         itaprad = 0
1505
1506!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
1507!! Un petit travail \`a faire ici.
1508!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
1509
1510         if (iflag_pbl>1) then
1511             PRINT*, "Using method MELLOR&YAMADA"
1512         endif
1513
1514!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
1515! FH 2008/05/02 changement lie a la lecture de nbapp_rad dans phylmd plutot que
1516! dyn3d
1517! Attention : la version precedente n'etait pas tres propre.
1518! Il se peut qu'il faille prendre une valeur differente de nbapp_rad
1519! pour obtenir le meme resultat.
1520         dtime=pdtphys
1521         radpas = NINT( 86400./dtime/nbapp_rad)
1522!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
1523
1524         CALL phyetat0 ("startphy.nc",clesphy0,tabcntr0)
1525
1526         IF (klon_glo==1) THEN
1527         coefh=0. ; coefm=0. ; pbl_tke=0.
1528         coefh(:,2,:)=1.e-2 ; coefm(:,2,:)=1.e-2 ; pbl_tke(:,2,:)=1.e-2
1529         PRINT*,'FH WARNING : lignes a supprimer'
1530         ENDIF
1531!IM begin
1532          print*,'physiq: clwcon rnebcon ratqs',clwcon(1,1),rnebcon(1,1)             &
1533       &,ratqs(1,1)
1534!IM end
1535
1536
1537
1538!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
1539!c
1540!C on remet le calendrier a zero
1541!c
1542         IF (raz_date .eq. 1) THEN
1543           itau_phy = 0
1544         ENDIF
1545
1546!IM cf. AM 081204 BEG
1547         PRINT*,'cycle_diurne3 =',cycle_diurne
1548!IM cf. AM 081204 END
1549!c
1550         CALL printflag( tabcntr0,radpas,ok_journe,                                  &
1551       &                    ok_instan, ok_region )
1552!c
1553         IF (ABS(dtime-pdtphys).GT.0.001) THEN
1554            WRITE(lunout,*) 'Pas physique n est pas correct',dtime,                  &
1555       &                        pdtphys
1556            abort_message='Pas physique n est pas correct '
1557!           call abort_gcm(modname,abort_message,1)
1558            dtime=pdtphys
1559         ENDIF
1560         IF (nlon .NE. klon) THEN
1561            WRITE(lunout,*)'nlon et klon ne sont pas coherents', nlon,               &
1562       &                      klon
1563            abort_message='nlon et klon ne sont pas coherents'
1564            call abort_gcm(modname,abort_message,1)
1565         ENDIF
1566         IF (nlev .NE. klev) THEN
1567            WRITE(lunout,*)'nlev et klev ne sont pas coherents', nlev,               &
1568       &                       klev
1569            abort_message='nlev et klev ne sont pas coherents'
1570            call abort_gcm(modname,abort_message,1)
1571         ENDIF
1572!c
1573         IF (dtime*REAL(radpas).GT.21600..AND.cycle_diurne) THEN
1574           WRITE(lunout,*)'Nbre d appels au rayonnement insuffisant'
1575           WRITE(lunout,*)"Au minimum 4 appels par jour si cycle diurne"
1576           abort_message='Nbre d appels au rayonnement insuffisant'
1577           call abort_gcm(modname,abort_message,1)
1578         ENDIF
1579         WRITE(lunout,*)"Clef pour la convection, iflag_con=", iflag_con
1580         WRITE(lunout,*)"Clef pour le driver de la convection, ok_cvl=",             &
1581       &                   ok_cvl
1582!c
1583!cKE43
1584!c Initialisation pour la convection de K.E. (sb):
1585         IF (iflag_con.GE.3) THEN
1586
1587         WRITE(lunout,*)"*** Convection de Kerry Emanuel 4.3  "
1588         WRITE(lunout,*)                                                             &
1589       &      "On va utiliser le melange convectif des traceurs qui"
1590         WRITE(lunout,*)"est calcule dans convect4.3"
1591         WRITE(lunout,*)" !!! penser aux logical flags de phytrac"
1592
1593          DO i = 1, klon
1594           ema_cbmf(i) = 0.
1595           ema_pcb(i)  = 0.
1596           ema_pct(i)  = 0.
1597!c          ema_workcbmf(i) = 0.
1598          ENDDO
1599!IM15/11/02 rajout initialisation ibas_con,itop_con cf. SB =>BEG
1600          DO i = 1, klon
1601           ibas_con(i) = 1
1602           itop_con(i) = 1
1603          ENDDO
1604!IM15/11/02 rajout initialisation ibas_con,itop_con cf. SB =>END
1605!c===============================================================================
1606!cCR:04.12.07: initialisations poches froides
1607!c Controle de ALE et ALP pour la fermeture convective (jyg)
1608          if (iflag_wake>=1) then
1609            CALL ini_wake(0.,0.,it_wape_prescr,wape_prescr,fip_prescr                &
1610       &                  ,alp_bl_prescr, ale_bl_prescr)
1611!c 11/09/06 rajout initialisation ALE et ALP du wake et PBL(YU)
1612!c        print*,'apres ini_wake iflag_cldcon=', iflag_cldcon
1613          endif
1614
1615        do i = 1,klon
1616         Ale_bl(i)=0.
1617         Alp_bl(i)=0.
1618        enddo
1619
1620!c================================================================================
1621!IM stations CFMIP
1622      nCFMIP=npCFMIP
1623      OPEN(98,file='npCFMIP_param.data',status='old',                                &
1624       &          form='formatted',iostat=iostat)
1625            if (iostat == 0) then
1626      READ(98,*,end=998) nCFMIP
1627998   CONTINUE
1628      CLOSE(98)
1629      CONTINUE
1630      IF(nCFMIP.GT.npCFMIP) THEN
1631       print*,'nCFMIP > npCFMIP : augmenter npCFMIP et recompiler'
1632       CALL abort
1633      else
1634       print*,'physiq npCFMIP=',npCFMIP,'nCFMIP=',nCFMIP
1635      ENDIF
1636
1637!c
1638      ALLOCATE(tabCFMIP(nCFMIP))
1639      ALLOCATE(lonCFMIP(nCFMIP), latCFMIP(nCFMIP))
1640      ALLOCATE(tabijGCM(nCFMIP))
1641      ALLOCATE(lonGCM(nCFMIP), latGCM(nCFMIP))
1642      ALLOCATE(iGCM(nCFMIP), jGCM(nCFMIP))
1643!c
1644!c lecture des nCFMIP stations CFMIP, de leur numero
1645!c et des coordonnees geographiques lonCFMIP, latCFMIP
1646!c
1647         CALL read_CFMIP_point_locations(nCFMIP, tabCFMIP,                           &
1648       &lonCFMIP, latCFMIP)
1649!c
1650!c identification des
1651!c 1) coordonnees lonGCM, latGCM des points CFMIP dans la grille de LMDZ
1652!c 2) indices points tabijGCM de la grille physique 1d sur klon points
1653!c 3) indices iGCM, jGCM de la grille physique 2d
1654!c
1655         CALL LMDZ_CFMIP_point_locations(nCFMIP, lonCFMIP, latCFMIP,                 &
1656       &tabijGCM, lonGCM, latGCM, iGCM, jGCM)
1657!c
1658            else
1659               ALLOCATE(tabijGCM(0))
1660               ALLOCATE(lonGCM(0), latGCM(0))
1661               ALLOCATE(iGCM(0), jGCM(0))
1662            end if
1663         else
1664            ALLOCATE(tabijGCM(0))
1665            ALLOCATE(lonGCM(0), latGCM(0))
1666            ALLOCATE(iGCM(0), jGCM(0))
1667         ENDIF
1668 
1669           DO i=1,klon
1670             rugoro(i) = f_rugoro * MAX(1.0e-05, zstd(i)*zsig(i)/2.0)
1671           ENDDO
1672
1673!c34EK
1674         IF (ok_orodr) THEN
1675
1676!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
1677! FH sans doute a enlever de finitivement ou, si on le garde, l'activer
1678! justement quand ok_orodr = false.
1679! ce rugoro est utilise par la couche limite et fait double emploi
1680! avec les param\'etrisations sp\'ecifiques de Francois Lott.
1681!           DO i=1,klon
1682!             rugoro(i) = MAX(1.0e-05, zstd(i)*zsig(i)/2.0)
1683!           ENDDO
1684!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
1685           IF (ok_strato) THEN
1686             CALL SUGWD_strato(klon,klev,paprs,pplay)
1687           ELSE
1688             CALL SUGWD(klon,klev,paprs,pplay)
1689           ENDIF
1690           
1691           DO i=1,klon
1692             zuthe(i)=0.
1693             zvthe(i)=0.
1694             if(zstd(i).gt.10.)then
1695               zuthe(i)=(1.-zgam(i))*cos(zthe(i))
1696               zvthe(i)=(1.-zgam(i))*sin(zthe(i))
1697             endif
1698           ENDDO
1699         ENDIF
1700!c
1701!c
1702         lmt_pas = NINT(86400./dtime * 1.0)   ! tous les jours
1703         WRITE(lunout,*)'La frequence de lecture surface est de ',                   &
1704       &                   lmt_pas
1705!c
1706      capemaxcels = 't_max(X)'
1707      t2mincels = 't_min(X)'
1708      t2maxcels = 't_max(X)'
1709      tinst = 'inst(X)'
1710      tave = 'ave(X)'
1711!IM cf. AM 081204 BEG
1712      write(lunout,*)'AVANT HIST IFLAG_CON=',iflag_con
1713!IM cf. AM 081204 END
1714!c
1715!c=============================================================
1716!c   Initialisation des sorties
1717!c=============================================================
1718
1719#ifdef CPP_IOIPSL
1720
1721!$OMP MASTER
1722       call phys_output_open(rlon,rlat,nCFMIP,tabijGCM,                              &
1723       &                       iGCM,jGCM,lonGCM,latGCM,                              &
1724       &                       jjmp1,nlevSTD,clevSTD,                                &
1725       &                       nbteta, ctetaSTD, dtime,ok_veget,                     &
1726       &                       type_ocean,iflag_pbl,ok_mensuel,ok_journe,            &
1727       &                       ok_hf,ok_instan,ok_LES,ok_ade,ok_aie,                 &
1728       &                       read_climoz, phys_out_filestations,                   &
1729       &                       new_aod, aerosol_couple,                              &
1730       &                       flag_aerosol_strat )
1731!$OMP END MASTER
1732!$OMP BARRIER
1733
1734#ifdef histISCCP
1735#include "ini_histISCCP.h"
1736#endif
1737
1738#ifdef histNMC
1739#include "ini_histhfNMC.h"
1740#include "ini_histdayNMC.h"
1741#include "ini_histmthNMC.h"
1742#endif
1743
1744#include "ini_histday_seri.h"
1745
1746#include "ini_paramLMDZ_phy.h"
1747
1748#endif
1749         ecrit_reg = ecrit_reg * un_jour
1750         ecrit_tra = ecrit_tra * un_jour
1751       
1752!cXXXPB Positionner date0 pour initialisation de ORCHIDEE
1753      date0 = jD_ref
1754      WRITE(*,*) 'physiq date0 : ',date0
1755!c
1756!c
1757!c
1758!c Prescrire l'ozone dans l'atmosphere
1759!c
1760!c
1761!cc         DO i = 1, klon
1762!cc         DO k = 1, klev
1763!cc            CALL o3cm (paprs(i,k)/100.,paprs(i,k+1)/100., wo(i,k),20)
1764!cc         ENDDO
1765!cc         ENDDO
1766!c
1767      IF (type_trac == 'inca') THEN
1768#ifdef INCA
1769         CALL VTe(VTphysiq)
1770         CALL VTb(VTinca)
1771!         iii = MOD(NINT(xjour),360)
1772!         calday = REAL(iii) + jH_cur
1773         calday = REAL(days_elapsed) + jH_cur
1774         WRITE(lunout,*) 'initial time chemini', days_elapsed, calday
1775
1776         CALL chemini(                                                               &
1777       &                   rg,                                                       &
1778       &                   ra,                                                       &
1779       &                   airephy,                                                  &
1780       &                   rlat,                                                     &
1781       &                   rlon,                                                     &
1782       &                   presnivs,                                                 &
1783       &                   calday,                                                   &
1784       &                   klon,                                                     &
1785       &                   nqtot,                                                    &
1786       &                   pdtphys,                                                  &
1787       &                   annee_ref,                                                &
1788       &                   day_ref,                                                  &
1789       &                   itau_phy)
1790
1791         CALL VTe(VTinca)
1792         CALL VTb(VTphysiq)
1793#endif
1794      END IF
1795!c
1796!c
1797!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
1798! Nouvelle initialisation pour le rayonnement RRTM
1799!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
1800
1801      call iniradia(klon,klev,paprs(1,1:klev+1))
1802
1803!$OMP single
1804      if (read_climoz >= 1) then
1805         call open_climoz(ncid_climoz, press_climoz)
1806      END IF
1807!$OMP end single
1808!c
1809!IM betaCRF
1810      pfree=70000. !Pa
1811      beta_pbl=1.
1812      beta_free=1.
1813      lon1_beta=-180.
1814      lon2_beta=+180.
1815      lat1_beta=90.
1816      lat2_beta=-90.
1817      mskocean_beta=.FALSE.
1818
1819      OPEN(99,file='beta_crf.data',status='old',                                     &
1820       &          form='formatted',err=9999)
1821      READ(99,*,end=9998) pfree
1822      READ(99,*,end=9998) beta_pbl
1823      READ(99,*,end=9998) beta_free
1824      READ(99,*,end=9998) lon1_beta
1825      READ(99,*,end=9998) lon2_beta
1826      READ(99,*,end=9998) lat1_beta
1827      READ(99,*,end=9998) lat2_beta
1828      READ(99,*,end=9998) mskocean_beta
18299998  Continue
1830      CLOSE(99)
18319999  Continue
1832      WRITE(*,*)'pfree=',pfree
1833      WRITE(*,*)'beta_pbl=',beta_pbl
1834      WRITE(*,*)'beta_free=',beta_free
1835      WRITE(*,*)'lon1_beta=',lon1_beta
1836      WRITE(*,*)'lon2_beta=',lon2_beta
1837      WRITE(*,*)'lat1_beta=',lat1_beta
1838      WRITE(*,*)'lat2_beta=',lat2_beta
1839      WRITE(*,*)'mskocean_beta=',mskocean_beta
1840      ENDIF
1841!
1842!   ****************     Fin  de   IF ( debut  )   ***************
1843!
1844!
1845! Incrementer le compteur de la physique
1846!
1847      itap   = itap + 1
1848!c
1849!
1850! Update fraction of the sub-surfaces (pctsrf) and
1851! initialize, where a new fraction has appeared, all variables depending
1852! on the surface fraction.
1853!
1854      CALL change_srf_frac(itap, dtime, days_elapsed+1,                              &
1855       &     pctsrf, falb1, falb2, ftsol, ustar, u10m, v10m, pbl_tke)
1856
1857! Update time and other variables in Reprobus
1858      IF (type_trac == 'repr') THEN
1859#ifdef REPROBUS
1860         CALL Init_chem_rep_xjour(jD_cur-jD_ref+day_ref)
1861         print*,'xjour equivalent rjourvrai',jD_cur-jD_ref+day_ref
1862         CALL Rtime(debut)
1863#endif
1864      END IF
1865
1866
1867! Tendances bidons pour les processus qui n'affectent pas certaines
1868! variables.
1869      du0(:,:)=0.
1870      dv0(:,:)=0.
1871      dq0(:,:)=0.
1872      dql0(:,:)=0.
1873!c
1874!c Mettre a zero des variables de sortie (pour securite)
1875!c
1876      DO i = 1, klon
1877         d_ps(i) = 0.0
1878      ENDDO
1879      DO k = 1, klev
1880      DO i = 1, klon
1881         d_t(i,k) = 0.0
1882         d_u(i,k) = 0.0
1883         d_v(i,k) = 0.0
1884      ENDDO
1885      ENDDO
1886      DO iq = 1, nqtot
1887      DO k = 1, klev
1888      DO i = 1, klon
1889         d_qx(i,k,iq) = 0.0
1890      ENDDO
1891      ENDDO
1892      ENDDO
1893      da(:,:)=0.
1894      mp(:,:)=0.
1895      phi(:,:,:)=0.
1896! RomP >>>
1897      phi2(:,:,:)=0.
1898      beta_prec_fisrt(:,:)=0.
1899      beta_prec(:,:)=0.
1900      epmlmMm(:,:,:)=0.
1901      eplaMm(:,:)=0.
1902      d1a(:,:)=0.
1903      dam(:,:)=0.
1904          pmflxr=0.
1905          pmflxs=0.
1906! RomP <<<
1907
1908!c
1909!c Ne pas affecter les valeurs entrees de u, v, h, et q
1910!c
1911      DO k = 1, klev
1912      DO i = 1, klon
1913         t_seri(i,k)  = t(i,k)
1914         u_seri(i,k)  = u(i,k)
1915         v_seri(i,k)  = v(i,k)
1916         q_seri(i,k)  = qx(i,k,ivap)
1917         ql_seri(i,k) = qx(i,k,iliq)
1918         qs_seri(i,k) = 0.
1919      ENDDO
1920      ENDDO
1921      tke0(:,:)=pbl_tke(:,:,is_ave)
1922      IF (nqtot.GE.3) THEN
1923      DO iq = 3, nqtot
1924      DO  k = 1, klev
1925      DO  i = 1, klon
1926         tr_seri(i,k,iq-2) = qx(i,k,iq)
1927      ENDDO
1928      ENDDO
1929      ENDDO
1930      ELSE
1931      DO k = 1, klev
1932      DO i = 1, klon
1933         tr_seri(i,k,1) = 0.0
1934      ENDDO
1935      ENDDO
1936      ENDIF
1937!C
1938      DO i = 1, klon
1939        ztsol(i) = 0.
1940      ENDDO
1941      DO nsrf = 1, nbsrf
1942        DO i = 1, klon
1943          ztsol(i) = ztsol(i) + ftsol(i,nsrf)*pctsrf(i,nsrf)
1944        ENDDO
1945      ENDDO
1946!IM
1947      IF (ip_ebil_phy.ge.1) THEN
1948        ztit='after dynamic'
1949        CALL diagetpq(airephy,ztit,ip_ebil_phy,1,1,dtime                             &
1950       &      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay              &
1951       &      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
1952!C     Comme les tendances de la physique sont ajoute dans la dynamique,
1953!C     on devrait avoir que la variation d'entalpie par la dynamique
1954!C     est egale a la variation de la physique au pas de temps precedent.
1955!C     Donc la somme de ces 2 variations devrait etre nulle.
1956        call diagphy(airephy,ztit,ip_ebil_phy                                        &
1957       &      , zero_v, zero_v, zero_v, zero_v, zero_v                               &
1958       &      , zero_v, zero_v, zero_v, ztsol                                        &
1959       &      , d_h_vcol+d_h_vcol_phy, d_qt, 0.                                      &
1960       &      , fs_bound, fq_bound )
1961      END IF
1962      PRINT *,'  Lluis 1 d_h_vcol: ',d_h_vcol,' d_h_vcol_phy: ',d_h_vcol_phy
1963
1964!c Diagnostiquer la tendance dynamique
1965!c
1966      IF (ancien_ok) THEN
1967         DO k = 1, klev
1968         DO i = 1, klon
1969            d_u_dyn(i,k) = (u_seri(i,k)-u_ancien(i,k))/dtime
1970            d_v_dyn(i,k) = (v_seri(i,k)-v_ancien(i,k))/dtime
1971            d_t_dyn(i,k) = (t_seri(i,k)-t_ancien(i,k))/dtime
1972            d_q_dyn(i,k) = (q_seri(i,k)-q_ancien(i,k))/dtime
1973         ENDDO
1974         ENDDO
1975!!! RomP >>>   td dyn traceur
1976       IF (nqtot.GE.3) THEN
1977          DO iq = 3, nqtot
1978          DO k = 1, klev
1979          DO i = 1, klon
1980            d_tr_dyn(i,k,iq-2)=                                                      &
1981       &       (tr_seri(i,k,iq-2)-tr_ancien(i,k,iq-2))/dtime
1982!         iiq=niadv(iq)
1983!         print*,i,k," d_tr_dyn",d_tr_dyn(i,k,iq-2),"tra:",iq,tname(iiq)
1984          ENDDO
1985          ENDDO
1986          ENDDO
1987       ENDIF
1988!!! RomP <<<
1989      ELSE
1990         DO k = 1, klev
1991         DO i = 1, klon
1992            d_u_dyn(i,k) = 0.0
1993            d_v_dyn(i,k) = 0.0
1994            d_t_dyn(i,k) = 0.0
1995            d_q_dyn(i,k) = 0.0
1996         ENDDO
1997         ENDDO
1998!!! RomP >>>   td dyn traceur
1999        IF (nqtot.GE.3) THEN
2000          DO iq = 3, nqtot
2001          DO k = 1, klev
2002          DO i = 1, klon
2003            d_tr_dyn(i,k,iq-2)= 0.0
2004          ENDDO
2005          ENDDO
2006          ENDDO
2007       ENDIF
2008!!! RomP <<<
2009         ancien_ok = .TRUE.
2010      ENDIF
2011!c
2012!c Ajouter le geopotentiel du sol:
2013!c
2014      DO k = 1, klev
2015      DO i = 1, klon
2016         zphi(i,k) = pphi(i,k) + pphis(i)
2017      ENDDO
2018      ENDDO
2019!c
2020!c Verifier les temperatures
2021!c
2022!IM BEG
2023      IF (check) THEN
2024       amn=MIN(ftsol(1,is_ter),1000.)
2025       amx=MAX(ftsol(1,is_ter),-1000.)
2026       DO i=2, klon
2027        amn=MIN(ftsol(i,is_ter),amn)
2028        amx=MAX(ftsol(i,is_ter),amx)
2029       ENDDO
2030!c
2031       PRINT*,' debut avant hgardfou min max ftsol',itap,amn,amx
2032      ENDIF !(check) THEN
2033
2034!IM END
2035!c
2036
2037      CALL hgardfou(t_seri,ftsol,'debutphy')
2038!c
2039!IM BEG
2040      IF (check) THEN
2041       amn=MIN(ftsol(1,is_ter),1000.)
2042       amx=MAX(ftsol(1,is_ter),-1000.)
2043       DO i=2, klon
2044        amn=MIN(ftsol(i,is_ter),amn)
2045        amx=MAX(ftsol(i,is_ter),amx)
2046       ENDDO
2047!c
2048       PRINT*,' debut apres hgardfou min max ftsol',itap,amn,amx
2049      ENDIF !(check) THEN
2050
2051!IM END
2052!c
2053!c Mettre en action les conditions aux limites (albedo, sst, etc.).
2054!c Prescrire l'ozone et calculer l'albedo sur l'ocean.
2055!c
2056      if (read_climoz >= 1) then
2057!C        Ozone from a file
2058!        Update required ozone index:
2059         ro3i = int((days_elapsed + jh_cur - jh_1jan)                                &
2060       &        / ioget_year_len(year_cur) * 360.) + 1
2061         if (ro3i == 361) ro3i = 360
2062!C        (This should never occur, except perhaps because of roundup
2063!C        error. See documentation.)
2064         if (ro3i /= co3i) then
2065!C           Update ozone field:
2066            if (read_climoz == 1) then
2067               call regr_pr_av(ncid_climoz, (/"tro3"/), julien=ro3i,                 &
2068       &              press_in_edg=press_climoz, paprs=paprs, v3=wo)
2069            else
2070!C              read_climoz == 2
2071               call regr_pr_av(ncid_climoz,                                          &
2072       &              (/"tro3         ", "tro3_daylight"/),                          &
2073       &              julien=ro3i, press_in_edg=press_climoz, paprs=paprs,           &
2074       &              v3=wo)
2075            end if
2076!           Convert from mole fraction of ozone to column density of ozone in a
2077!           cell, in kDU:
2078            forall (l = 1: read_climoz) wo(:, :, l) = wo(:, :, l)                    &
2079       &           * rmo3 / rmd * zmasse / dobson_u / 1e3
2080!C           (By regridding ozone values for LMDZ only once every 360th of
2081!C           year, we have already neglected the variation of pressure in one
2082!C           360th of year. So do not recompute "wo" at each time step even if
2083!C           "zmasse" changes a little.)
2084            co3i = ro3i
2085         end if
2086      elseif (MOD(itap-1,lmt_pas) == 0) THEN
2087!C        Once per day, update ozone from Royer:
2088         wo(:, :, 1) = ozonecm(rlat, paprs, rjour=real(days_elapsed+1))
2089      ENDIF
2090
2091!c
2092!c Re-evaporer l'eau liquide nuageuse
2093!c
2094      DO k = 1, klev  ! re-evaporation de l'eau liquide nuageuse
2095      DO i = 1, klon
2096         zlvdcp=RLVTT/RCPD/(1.0+RVTMP2*q_seri(i,k))
2097!c        zlsdcp=RLSTT/RCPD/(1.0+RVTMP2*q_seri(i,k))
2098         zlsdcp=RLVTT/RCPD/(1.0+RVTMP2*q_seri(i,k))
2099         zdelta = MAX(0.,SIGN(1.,RTT-t_seri(i,k)))
2100         zb = MAX(0.0,ql_seri(i,k))
2101         za = - MAX(0.0,ql_seri(i,k))                                                &
2102       &                  * (zlvdcp*(1.-zdelta)+zlsdcp*zdelta)
2103         t_seri(i,k) = t_seri(i,k) + za
2104         q_seri(i,k) = q_seri(i,k) + zb
2105         ql_seri(i,k) = 0.0
2106         d_t_eva(i,k) = za
2107         d_q_eva(i,k) = zb
2108      ENDDO
2109      ENDDO
2110!IM
2111      IF (ip_ebil_phy.ge.2) THEN
2112        ztit='after reevap'
2113        CALL diagetpq(airephy,ztit,ip_ebil_phy,2,1,dtime                             &
2114       &      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay              &
2115       &      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
2116         call diagphy(airephy,ztit,ip_ebil_phy                                       &
2117       &      , zero_v, zero_v, zero_v, zero_v, zero_v                               &
2118       &      , zero_v, zero_v, zero_v, ztsol                                        &
2119       &      , d_h_vcol, d_qt, d_ec                                                 &
2120       &      , fs_bound, fq_bound )
2121!C
2122      END IF
2123      PRINT *,'  Lluis 2 d_h_vcol: ',d_h_vcol,' d_h_vcol_phy: ',d_h_vcol_phy
2124!c
2125!c=========================================================================
2126! Calculs de l'orbite.
2127! Necessaires pour le rayonnement et la surface (calcul de l'albedo).
2128! doit donc etre plac\'e avant radlwsw et pbl_surface
2129
2130!!!   jyg 17 Sep 2010 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
2131      call ymds2ju(year_cur, mth_eq, day_eq,0., jD_eq)
2132      day_since_equinox = (jD_cur + jH_cur) - jD_eq
2133!
2134!   choix entre calcul de la longitude solaire vraie ou valeur fixee a
2135!   solarlong0
2136      if (solarlong0<-999.) then
2137       if (new_orbit) then
2138! calcul selon la routine utilisee pour les planetes
2139        call solarlong(day_since_equinox, zlongi, dist)
2140       else
2141! calcul selon la routine utilisee pour l'AR4
2142        CALL orbite(REAL(days_elapsed+1),zlongi,dist)
2143       endif
2144      else
2145           zlongi=solarlong0  ! longitude solaire vraie
2146           dist=1.            ! distance au soleil / moyenne
2147      endif
2148      if(prt_level.ge.1)                                                &
2149       &    write(lunout,*)'Longitude solaire ',zlongi,solarlong0,dist,&
2150       ' jD_cur: ',jD_cur,' jH_cur: ',jH_cur,' days_elapsed: ', &
2151       REAL(days_elapsed+1)
2152
2153
2154!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
2155! Calcul de l'ensoleillement :
2156! ============================
2157! Pour une solarlong0=1000., on calcule un ensoleillement moyen sur
2158! l'annee a partir d'une formule analytique.
2159! Cet ensoleillement est sym\'etrique autour de l'\'equateur et
2160! non nul aux poles.
2161      IF (abs(solarlong0-1000.)<1.e-4) then
2162         PRINT *,' Lluis calling zenang_an'
2163         call zenang_an(cycle_diurne,jH_cur,rlat,rlon,rmu0,fract)
2164      ELSE
2165!  Avec ou sans cycle diurne
2166         IF (cycle_diurne) THEN
2167           zdtime=dtime*REAL(radpas) ! pas de temps du rayonnement (s)
2168           CALL zenang(zlongi,jH_cur,zdtime,rlat,rlon,rmu0,fract)
2169         ELSE
2170           CALL angle(zlongi, rlat, fract, rmu0)
2171         ENDIF
2172      ENDIF
2173
2174      if (mydebug) then
2175        call writefield_phy('u_seri',u_seri,llm)
2176        call writefield_phy('v_seri',v_seri,llm)
2177        call writefield_phy('t_seri',t_seri,llm)
2178        call writefield_phy('q_seri',q_seri,llm)
2179      endif
2180
2181!ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc
2182!c Appel au pbl_surface : Planetary Boudary Layer et Surface
2183!c Cela implique tous les interactions des sous-surfaces et la partie diffusion
2184!c turbulent du couche limit.
2185!c
2186!c Certains varibales de sorties de pbl_surface sont utiliser que pour
2187!c ecriture des fihiers hist_XXXX.nc, ces sont :
2188!c   qsol,      zq2m,      s_pblh,  s_lcl,
2189!c   s_capCL,   s_oliqCL,  s_cteiCL,s_pblT,
2190!c   s_therm,   s_trmb1,   s_trmb2, s_trmb3,
2191!c   zxrugs,    zu10m,     zv10m,   fder,
2192!c   zxqsurf,   rh2m,      zxfluxu, zxfluxv,
2193!c   frugs,     agesno,    fsollw,  fsolsw,
2194!c   d_ts,      fevap,     fluxlat, t2m,
2195!c   wfbils,    wfbilo,    fluxt,   fluxu, fluxv,
2196!c
2197!c Certains ne sont pas utiliser du tout :
2198!c   dsens, devap, zxsnow, zxfluxt, zxfluxq, q2m, fluxq
2199!c
2200
2201!c Calcul de l'humidite de saturation au niveau du sol
2202
2203
2204
2205      if (iflag_pbl/=0) then
2206
2207      PRINT *,'  Lluis before pbl_surface qsol: ',qsol(llp),    &
2208        ' rmu0: ',rmu0(llp),' jH_cur: ',jH_cur
2209
2210      CALL pbl_surface(                                                              &
2211       &     dtime,     date0,     itap,    days_elapsed+1,                          &
2212       &     debut,     lafin,                                                       &
2213       &     rlon,      rlat,      rugoro,  rmu0,                                    &
2214       &     rain_fall, snow_fall, solsw,   sollw,                                   &
2215       &     t_seri,    q_seri,    u_seri,  v_seri,                                  &
2216       &     pplay,     paprs,     pctsrf,                                           &
2217       &     ftsol,     falb1,     falb2,   ustar, u10m,   v10m,                     &
2218       &     sollwdown, cdragh,    cdragm,  u1,    v1,                               &
2219       &     albsol1,   albsol2,   sens,    evap,                                    &
2220       &     zxtsol,    zxfluxlat, zt2m,    qsat2m,                                  &
2221       &     d_t_vdf,   d_q_vdf,   d_u_vdf, d_v_vdf, d_t_diss,                       &
2222       &     coefh,     coefm,     slab_wfbils,                                      &
2223       &     qsol,      zq2m,      s_pblh,  s_lcl,                                   &
2224       &     s_capCL,   s_oliqCL,  s_cteiCL,s_pblT,                                  &
2225       &     s_therm,   s_trmb1,   s_trmb2, s_trmb3,                                 &
2226       &     zxrugs,    zustar, zu10m,     zv10m,   fder,                            &
2227       &     zxqsurf,   rh2m,      zxfluxu, zxfluxv,                                 &
2228       &     frugs,     agesno,    fsollw,  fsolsw,                                  &
2229       &     d_ts,      fevap,     fluxlat, t2m,                                     &
2230       &     wfbils,    wfbilo,    fluxt,   fluxu,  fluxv,                           &
2231       &     dsens,     devap,     zxsnow,                                           &
2232       &     zxfluxt,   zxfluxq,   q2m,     fluxq, pbl_tke )
2233
2234      PRINT *,'  Lluis after pbl_surface qsol: ',qsol(llp),    &
2235        ' rmu0: ',rmu0(llp),' jH_cur: ',jH_cur
2236
2237!-----------------------------------------------------------------------------------------
2238! ajout des tendances de la diffusion turbulente
2239      CALL add_phys_tend                                                             &
2240       &     (d_u_vdf,d_v_vdf,d_t_vdf+d_t_diss,d_q_vdf,dql0,'vdf')
2241!-----------------------------------------------------------------------------------------
2242      if (mydebug) then
2243        call writefield_phy('u_seri',u_seri,llm)
2244        call writefield_phy('v_seri',v_seri,llm)
2245        call writefield_phy('t_seri',t_seri,llm)
2246        call writefield_phy('q_seri',q_seri,llm)
2247      endif
2248
2249         CALL evappot(klon,nbsrf,ftsol,pplay(:,1),cdragh,                            &
2250       &      t_seri(:,1),q_seri(:,1),u_seri(:,1),v_seri(:,1),evap_pot)
2251
2252
2253      IF (ip_ebil_phy.ge.2) THEN
2254        ztit='after surface_main'
2255        CALL diagetpq(airephy,ztit,ip_ebil_phy,2,2,dtime                             &
2256       &      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay              &
2257       &      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
2258         call diagphy(airephy,ztit,ip_ebil_phy                                       &
2259       &      , zero_v, zero_v, zero_v, zero_v, sens                                 &
2260       &      , evap  , zero_v, zero_v, ztsol                                        &
2261       &      , d_h_vcol, d_qt, d_ec                                                 &
2262       &      , fs_bound, fq_bound )
2263      END IF
2264
2265      ENDIF
2266      PRINT *,'  Lluis 3 d_h_vcol: ',d_h_vcol,' d_h_vcol_phy: ',d_h_vcol_phy
2267!c =================================================================== c
2268!c   Calcul de Qsat
2269
2270      DO k = 1, klev
2271      DO i = 1, klon
2272         zx_t = t_seri(i,k)
2273         IF (thermcep) THEN
2274            zdelta = MAX(0.,SIGN(1.,rtt-zx_t))
2275            zx_qs  = r2es * FOEEW(zx_t,zdelta)/pplay(i,k)
2276            zx_qs  = MIN(0.5,zx_qs)
2277            zcor   = 1./(1.-retv*zx_qs)
2278            zx_qs  = zx_qs*zcor
2279         ELSE
2280           IF (zx_t.LT.t_coup) THEN
2281              zx_qs = qsats(zx_t)/pplay(i,k)
2282           ELSE
2283              zx_qs = qsatl(zx_t)/pplay(i,k)
2284           ENDIF
2285         ENDIF
2286         zqsat(i,k)=zx_qs
2287      ENDDO
2288      ENDDO
2289
2290      if (prt_level.ge.1) then
2291      write(lunout,*) 'L   qsat (g/kg) avant clouds_gno'
2292      write(lunout,'(i4,f15.4)') (k,1000.*zqsat(igout,k),k=1,klev)
2293      endif
2294!c
2295!c Appeler la convection (au choix)
2296!c
2297      DO k = 1, klev
2298      DO i = 1, klon
2299         conv_q(i,k) = d_q_dyn(i,k)                                                  &
2300       &               + d_q_vdf(i,k)/dtime
2301         conv_t(i,k) = d_t_dyn(i,k)                                                  &
2302       &               + d_t_vdf(i,k)/dtime
2303      ENDDO
2304      ENDDO
2305      IF (check) THEN
2306         za = qcheck(klon,klev,paprs,q_seri,ql_seri,airephy)
2307         WRITE(lunout,*) "avantcon=", za
2308      ENDIF
2309      zx_ajustq = .FALSE.
2310      IF (iflag_con.EQ.2) zx_ajustq=.TRUE.
2311      IF (zx_ajustq) THEN
2312         DO i = 1, klon
2313            z_avant(i) = 0.0
2314         ENDDO
2315         DO k = 1, klev
2316         DO i = 1, klon
2317            z_avant(i) = z_avant(i) + (q_seri(i,k)+ql_seri(i,k))                     &
2318       &                        *(paprs(i,k)-paprs(i,k+1))/RG
2319         ENDDO
2320         ENDDO
2321      ENDIF
2322
2323!c Calcule de vitesse verticale a partir de flux de masse verticale
2324      DO k = 1, klev
2325         DO i = 1, klon
2326            omega(i,k) = RG*flxmass_w(i,k) / airephy(i)
2327         END DO
2328      END DO
2329      if (prt_level.ge.1) write(lunout,*) 'omega(igout, :) = ',                      &
2330       &     omega(igout, :)
2331
2332      IF (iflag_con.EQ.1) THEN
2333        abort_message ='reactiver le call conlmd dans physiq.F'
2334        CALL abort_gcm (modname,abort_message,1)
2335!c     CALL conlmd (dtime, paprs, pplay, t_seri, q_seri, conv_q,
2336!c    .             d_t_con, d_q_con,
2337!c    .             rain_con, snow_con, ibas_con, itop_con)
2338      ELSE IF (iflag_con.EQ.2) THEN
2339      CALL conflx(dtime, paprs, pplay, t_seri, q_seri,                               &
2340       &            conv_t, conv_q, -evap, omega,                                    &
2341       &            d_t_con, d_q_con, rain_con, snow_con,                            &
2342       &            pmfu, pmfd, pen_u, pde_u, pen_d, pde_d,                          &
2343       &            kcbot, kctop, kdtop, pmflxr, pmflxs)
2344      d_u_con = 0.
2345      d_v_con = 0.
2346
2347      WHERE (rain_con < 0.) rain_con = 0.
2348      WHERE (snow_con < 0.) snow_con = 0.
2349      DO i = 1, klon
2350         ibas_con(i) = klev+1 - kcbot(i)
2351         itop_con(i) = klev+1 - kctop(i)
2352      ENDDO
2353      ELSE IF (iflag_con.GE.3) THEN
2354!c nb of tracers for the KE convection:
2355!c MAF la partie traceurs est faite dans phytrac
2356!c on met ntra=1 pour limiter les appels mais on peut
2357!c supprimer les calculs / ftra.
2358              ntra = 1
2359
2360!c=====================================================================================
2361!cajout pour la parametrisation des poches froides:
2362!ccalcul de t_wake et t_undi: si pas de poches froides, t_wake=t_undi=t_seri
2363      do k=1,klev
2364            do i=1,klon
2365             if (iflag_wake>=1) then
2366             t_wake(i,k) = t_seri(i,k)                                               &
2367       &           +(1-wake_s(i))*wake_deltat(i,k)
2368             q_wake(i,k) = q_seri(i,k)                                               &
2369       &           +(1-wake_s(i))*wake_deltaq(i,k)
2370             t_undi(i,k) = t_seri(i,k)                                               &
2371       &           -wake_s(i)*wake_deltat(i,k)
2372             q_undi(i,k) = q_seri(i,k)                                               &
2373       &           -wake_s(i)*wake_deltaq(i,k)
2374             else
2375             t_wake(i,k) = t_seri(i,k)
2376             q_wake(i,k) = q_seri(i,k)
2377             t_undi(i,k) = t_seri(i,k)
2378             q_undi(i,k) = q_seri(i,k)
2379             endif
2380            enddo
2381         enddo
2382     
2383!cc--   Calcul de l'energie disponible ALE (J/kg) et de la puissance disponible ALP (W/m2)
2384!cc--    pour le soulevement des particules dans le modele convectif
2385!c
2386      do i = 1,klon
2387        ALE(i) = 0.
2388        ALP(i) = 0.
2389      enddo
2390!c
2391!ccalcul de ale_wake et alp_wake
2392       if (iflag_wake>=1) then
2393         if (itap .le. it_wape_prescr) then
2394          do i = 1,klon
2395           ale_wake(i) = wape_prescr
2396           alp_wake(i) = fip_prescr
2397          enddo
2398         else
2399          do i = 1,klon
2400!cjyg  ALE=WAPE au lieu de ALE = 1/2 Cstar**2
2401!ccc           ale_wake(i) = 0.5*wake_cstar(i)**2
2402           ale_wake(i) = wake_pe(i)
2403           alp_wake(i) = wake_fip(i)
2404          enddo
2405         endif
2406       else
2407         do i = 1,klon
2408           ale_wake(i) = 0.
2409           alp_wake(i) = 0.
2410         enddo
2411       endif
2412!ccombinaison avec ale et alp de couche limite: constantes si pas de couplage, valeurs calculees
2413!cdans le thermique sinon
2414       if (iflag_coupl.eq.0) then
2415          if (debut.and.prt_level.gt.9)                                              &
2416       &                     WRITE(lunout,*)'ALE et ALP imposes'
2417          do i = 1,klon
2418!con ne couple que ale
2419!c           ALE(i) = max(ale_wake(i),Ale_bl(i))
2420            ALE(i) = max(ale_wake(i),ale_bl_prescr)
2421!con ne couple que alp
2422!c           ALP(i) = alp_wake(i) + Alp_bl(i)
2423            ALP(i) = alp_wake(i) + alp_bl_prescr
2424          enddo
2425       else
2426         IF(prt_level>9)WRITE(lunout,*)'ALE et ALP couples au thermique'
2427!         do i = 1,klon
2428!             ALE(i) = max(ale_wake(i),Ale_bl(i))
2429! avant        ALP(i) = alp_wake(i) + Alp_bl(i)
2430!             ALP(i) = alp_wake(i) + Alp_bl(i) + alp_offset ! modif sb
2431!         write(20,*)'ALE',ALE(i),Ale_bl(i),ale_wake(i)
2432!         write(21,*)'ALP',ALP(i),Alp_bl(i),alp_wake(i)
2433!         enddo
2434
2435!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
2436! Modif FH 2010/04/27. Sans doute temporaire.
2437! Deux options pour le alp_offset : constant si >?? 0 ou proportionnel ??a
2438! w si <0
2439!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
2440       do i = 1,klon
2441          ALE(i) = max(ale_wake(i),Ale_bl(i))
2442!ccc nrlmd le 10/04/2012----------Stochastic triggering--------------
2443          if (iflag_trig_bl.ge.1) then
2444             ALE(i) = max(ale_wake(i),Ale_bl_trig(i))
2445          endif
2446!ccc fin nrlmd le 10/04/2012
2447          if (alp_offset>=0.) then
2448            ALP(i) = alp_wake(i) + Alp_bl(i) + alp_offset ! modif sb
2449          else
2450            ALP(i)=alp_wake(i)+Alp_bl(i)+alp_offset*min(omega(i,6),0.)
2451            if (alp(i)<0.) then
2452               print*,'ALP ',alp(i),alp_wake(i)                                      &
2453       &         ,Alp_bl(i),alp_offset*min(omega(i,6),0.)
2454            endif
2455          endif
2456       enddo
2457!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
2458
2459       endif
2460       do i=1,klon
2461          if (alp(i)>alp_max) then
2462             IF(prt_level>9)WRITE(lunout,*)                             &
2463       &       'WARNING SUPER ALP (seuil=',alp_max,                                  &
2464       &       '): i, alp, alp_wake,ale',i,alp(i),alp_wake(i),ale(i)
2465             alp(i)=alp_max
2466          endif
2467          if (ale(i)>ale_max) then
2468             IF(prt_level>9)WRITE(lunout,*)                             &
2469       &       'WARNING SUPER ALE (seuil=',ale_max,                                  &
2470       &       '): i, alp, alp_wake,ale',i,ale(i),ale_wake(i),alp(i)
2471             ale(i)=ale_max
2472          endif
2473       enddo
2474
2475!cfin calcul ale et alp
2476!c=================================================================================================
2477
2478
2479!c sb, oct02:
2480!c Schema de convection modularise et vectorise:
2481!c (driver commun aux versions 3 et 4)
2482!c
2483          IF (ok_cvl) THEN ! new driver for convectL
2484
2485             IF (type_trac == 'repr') THEN
2486                nbtr_tmp=ntra
2487             ELSE
2488                nbtr_tmp=nbtr
2489             END IF
2490          CALL concvl (iflag_con,iflag_clos,                                         &
2491       &        dtime,paprs,pplay,t_undi,q_undi,                                     &
2492       &        t_wake,q_wake,wake_s,                                                &
2493       &        u_seri,v_seri,tr_seri,nbtr_tmp,                                      &
2494       &        ALE,ALP,                                                             &
2495       &        ema_work1,ema_work2,                                                 &
2496       &        d_t_con,d_q_con,d_u_con,d_v_con,d_tr,                                &
2497       &        rain_con, snow_con, ibas_con, itop_con, sigd,                        &
2498       &        ema_cbmf,plcl,plfc,wbeff,upwd,dnwd,dnwd0,                            &
2499       &        Ma,mip,Vprecip,cape,cin,tvp,Tconv,iflagctrl,                         &
2500       &        pbase,bbase,dtvpdt1,dtvpdq1,dplcldt,dplcldr,qcondc,wd,               &
2501! RomP >>>
2502!!     .        pmflxr,pmflxs,da,phi,mp,
2503!!     .        ftd,fqd,lalim_conv,wght_th)                                          &
2504       &        pmflxr,pmflxs,da,phi,mp,phi2,d1a,dam,sij,clw,elij,                   &
2505       &        ftd,fqd,lalim_conv,wght_th,                                          &
2506       &        ev, ep,epmlmMm,eplaMm,                                               &
2507       &        wdtrainA,wdtrainM)
2508! RomP <<<
2509
2510!IM begin
2511!c       print*,'physiq: cin pbase dnwd0 ftd fqd ',cin(1),pbase(1),
2512!c    .dnwd0(1,1),ftd(1,1),fqd(1,1)
2513!IM end
2514!IM cf. FH
2515              clwcon0=qcondc
2516              pmfu(:,:)=upwd(:,:)+dnwd(:,:)
2517
2518              do i = 1, klon
2519                if (iflagctrl(i).le.1) itau_con(i)=itau_con(i)+1
2520              enddo
2521
2522          ELSE ! ok_cvl
2523
2524!c MAF conema3 ne contient pas les traceurs
2525          CALL conema3 (dtime,                                                       &
2526       &        paprs,pplay,t_seri,q_seri,                                           &
2527       &        u_seri,v_seri,tr_seri,ntra,                                          &
2528       &        ema_work1,ema_work2,                                                 &
2529       &        d_t_con,d_q_con,d_u_con,d_v_con,d_tr,                                &
2530       &        rain_con, snow_con, ibas_con, itop_con,                              &
2531       &        upwd,dnwd,dnwd0,bas,top,                                             &
2532       &        Ma,cape,tvp,rflag,                                                   &
2533       &        pbase                                                                &
2534       &        ,bbase,dtvpdt1,dtvpdq1,dplcldt,dplcldr                               &
2535       &        ,clwcon0)
2536
2537          ENDIF ! ok_cvl
2538
2539!c
2540!c Correction precip
2541          rain_con = rain_con * cvl_corr
2542          snow_con = snow_con * cvl_corr
2543!c
2544
2545           IF (.NOT. ok_gust) THEN
2546           do i = 1, klon
2547            wd(i)=0.0
2548           enddo
2549           ENDIF
2550
2551!c =================================================================== c
2552!c Calcul des proprietes des nuages convectifs
2553!c
2554
2555!c   calcul des proprietes des nuages convectifs
2556             clwcon0(:,:)=fact_cldcon*clwcon0(:,:)
2557             call clouds_gno                                                         &
2558       &       (klon,klev,q_seri,zqsat,clwcon0,ptconv,ratqsc,rnebcon0)
2559
2560!c =================================================================== c
2561
2562          DO i = 1, klon
2563           itop_con(i) = min(max(itop_con(i),1),klev)
2564           ibas_con(i) = min(max(ibas_con(i),1),itop_con(i))
2565          ENDDO
2566
2567          DO i = 1, klon
2568            ema_pcb(i)  = paprs(i,ibas_con(i))
2569          ENDDO
2570          DO i = 1, klon
2571! L'idicage de itop_con peut cacher un pb potentiel
2572! FH sous la dictee de JYG, CR
2573            ema_pct(i)  = paprs(i,itop_con(i)+1)
2574
2575            if (itop_con(i).gt.klev-3) then
2576              if(prt_level >= 9) then
2577                write(lunout,*)'La convection monte trop haut '
2578                write(lunout,*)'itop_con(,',i,',)=',itop_con(i)
2579              endif
2580            endif
2581          ENDDO     
2582      ELSE IF (iflag_con.eq.0) THEN
2583          write(lunout,*) 'On n appelle pas la convection'
2584          clwcon0=0.
2585          rnebcon0=0.
2586          d_t_con=0.
2587          d_q_con=0.
2588          d_u_con=0.
2589          d_v_con=0.
2590          rain_con=0.
2591          snow_con=0.
2592          bas=1
2593          top=1
2594      ELSE
2595          WRITE(lunout,*) "iflag_con non-prevu", iflag_con
2596          CALL abort
2597      ENDIF
2598
2599!c     CALL homogene(paprs, q_seri, d_q_con, u_seri,v_seri,
2600!c    .              d_u_con, d_v_con)
2601
2602!-----------------------------------------------------------------------------------------
2603! ajout des tendances de la diffusion turbulente
2604      CALL add_phys_tend(d_u_con,d_v_con,d_t_con,d_q_con,dql0,'con')
2605!-----------------------------------------------------------------------------------------
2606
2607      if (mydebug) then
2608        call writefield_phy('u_seri',u_seri,llm)
2609        call writefield_phy('v_seri',v_seri,llm)
2610        call writefield_phy('t_seri',t_seri,llm)
2611        call writefield_phy('q_seri',q_seri,llm)
2612      endif
2613
2614!IM
2615      IF (ip_ebil_phy.ge.2) THEN
2616        ztit='after convect'
2617        CALL diagetpq(airephy,ztit,ip_ebil_phy,2,2,dtime                             &
2618       &      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay              &
2619       &      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
2620         call diagphy(airephy,ztit,ip_ebil_phy                                       &
2621       &      , zero_v, zero_v, zero_v, zero_v, zero_v                               &
2622       &      , zero_v, rain_con, snow_con, ztsol                                    &
2623       &      , d_h_vcol, d_qt, d_ec                                                 &
2624       &      , fs_bound, fq_bound )
2625      END IF
2626!C
2627      PRINT *,'  Lluis 4 d_h_vcol: ',d_h_vcol,' d_h_vcol_phy: ',d_h_vcol_phy
2628      IF (check) THEN
2629          za = qcheck(klon,klev,paprs,q_seri,ql_seri,airephy)
2630          WRITE(lunout,*)"aprescon=", za
2631          zx_t = 0.0
2632          za = 0.0
2633          DO i = 1, klon
2634            za = za + airephy(i)/REAL(klon)
2635            zx_t = zx_t + (rain_con(i)+                                              &
2636       &                   snow_con(i))*airephy(i)/REAL(klon)
2637          ENDDO
2638          zx_t = zx_t/za*dtime
2639          WRITE(lunout,*)"Precip=", zx_t
2640      ENDIF
2641      IF (zx_ajustq) THEN
2642          DO i = 1, klon
2643            z_apres(i) = 0.0
2644          ENDDO
2645          DO k = 1, klev
2646            DO i = 1, klon
2647              z_apres(i) = z_apres(i) + (q_seri(i,k)+ql_seri(i,k))                   &
2648       &            *(paprs(i,k)-paprs(i,k+1))/RG
2649            ENDDO
2650          ENDDO
2651          DO i = 1, klon
2652            z_factor(i) = (z_avant(i)-(rain_con(i)+snow_con(i))*dtime)               &
2653       &          /z_apres(i)
2654          ENDDO
2655          DO k = 1, klev
2656            DO i = 1, klon
2657              IF (z_factor(i).GT.(1.0+1.0E-08) .OR.                                  &
2658       &            z_factor(i).LT.(1.0-1.0E-08)) THEN
2659                  q_seri(i,k) = q_seri(i,k) * z_factor(i)
2660              ENDIF
2661            ENDDO
2662          ENDDO
2663      ENDIF
2664      zx_ajustq=.FALSE.
2665
2666!c
2667!c=============================================================================
2668!cRR:Evolution de la poche froide: on ne fait pas de separation wake/env
2669!cpour la couche limite diffuse pour l instant
2670!c
2671      if (iflag_wake>=1) then
2672      DO k=1,klev
2673        DO i=1,klon
2674          dt_dwn(i,k)  = ftd(i,k)
2675          wdt_PBL(i,k) = 0.
2676          dq_dwn(i,k)  = fqd(i,k)
2677          wdq_PBL(i,k) = 0.
2678          M_dwn(i,k)   = dnwd0(i,k)
2679          M_up(i,k)    = upwd(i,k)
2680          dt_a(i,k)    = d_t_con(i,k)/dtime - ftd(i,k)
2681          udt_PBL(i,k) = 0.
2682          dq_a(i,k)    = d_q_con(i,k)/dtime - fqd(i,k)
2683          udq_PBL(i,k) = 0.
2684        ENDDO
2685      ENDDO
2686
2687      if (iflag_wake==2) then
2688        ok_wk_lsp(:)=max(sign(1.,wake_s(:)-wake_s_min_lsp),0.)
2689        DO k = 1,klev
2690         dt_dwn(:,k)= dt_dwn(:,k)+                                                   &
2691       &            ok_wk_lsp(:)*(d_t_eva(:,k)+d_t_lsc(:,k))/dtime
2692         dq_dwn(:,k)= dq_dwn(:,k)+                                                   &
2693       &            ok_wk_lsp(:)*(d_q_eva(:,k)+d_q_lsc(:,k))/dtime
2694        ENDDO
2695      endif
2696!c
2697!ccalcul caracteristiques de la poche froide
2698      call calWAKE (paprs,pplay,dtime                                                &
2699       &               ,t_seri,q_seri,omega                                          &
2700       &               ,dt_dwn,dq_dwn,M_dwn,M_up                                     &
2701       &               ,dt_a,dq_a,sigd                                               &
2702       &               ,wdt_PBL,wdq_PBL                                              &
2703       &               ,udt_PBL,udq_PBL                                              &
2704       &               ,wake_deltat,wake_deltaq,wake_dth                             &
2705       &               ,wake_h,wake_s,wake_dens                                      &
2706       &               ,wake_pe,wake_fip,wake_gfl                                    &
2707       &               ,dt_wake,dq_wake                                              &
2708       &               ,wake_k, t_undi,q_undi                                        &
2709       &               ,wake_omgbdth,wake_dp_omgb                                    &
2710       &               ,wake_dtKE,wake_dqKE                                          &
2711       &               ,wake_dtPBL,wake_dqPBL                                        &
2712       &               ,wake_omg,wake_dp_deltomg                                     &
2713       &               ,wake_spread,wake_Cstar,wake_d_deltat_gw                      &
2714       &               ,wake_ddeltat,wake_ddeltaq)
2715!c
2716!-----------------------------------------------------------------------------------------
2717! ajout des tendances des poches froides
2718! Faire rapidement disparaitre l'ancien dt_wake pour garder un d_t_wake
2719! coherent avec les autres d_t_...
2720      d_t_wake(:,:)=dt_wake(:,:)*dtime
2721      d_q_wake(:,:)=dq_wake(:,:)*dtime
2722      CALL add_phys_tend(du0,dv0,d_t_wake,d_q_wake,dql0,'wake')
2723!-----------------------------------------------------------------------------------------
2724
2725      endif
2726!c
2727!c===================================================================
2728!cJYG
2729      IF (ip_ebil_phy.ge.2) THEN
2730        ztit='after wake'
2731        CALL diagetpq(airephy,ztit,ip_ebil_phy,2,2,dtime                             &
2732       &      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay              &
2733       &      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
2734        call diagphy(airephy,ztit,ip_ebil_phy                                        &
2735       &      , zero_v, zero_v, zero_v, zero_v, zero_v                               &
2736       &      , zero_v, zero_v, zero_v, ztsol                                        &
2737       &      , d_h_vcol, d_qt, d_ec                                                 &
2738       &      , fs_bound, fq_bound )
2739      END IF
2740      PRINT *,'  Lluis 5 d_h_vcol: ',d_h_vcol,' d_h_vcol_phy: ',d_h_vcol_phy
2741!c      print*,'apres callwake iflag_cldcon=', iflag_cldcon
2742!c
2743!c===================================================================
2744!c Convection seche (thermiques ou ajustement)
2745!c===================================================================
2746!c
2747       call stratocu_if(klon,klev,pctsrf,paprs, pplay,t_seri                         &
2748       & ,seuil_inversion,weak_inversion,dthmin)
2749
2750
2751
2752      d_t_ajsb(:,:)=0.
2753      d_q_ajsb(:,:)=0.
2754      d_t_ajs(:,:)=0.
2755      d_u_ajs(:,:)=0.
2756      d_v_ajs(:,:)=0.
2757      d_q_ajs(:,:)=0.
2758      clwcon0th(:,:)=0.
2759!c
2760!c      fm_therm(:,:)=0.
2761!c      entr_therm(:,:)=0.
2762!c      detr_therm(:,:)=0.
2763!c
2764
2765      IF(prt_level>9)WRITE(lunout,*)                                                 &
2766       &    'AVANT LA CONVECTION SECHE , iflag_thermals='                            &
2767       &   ,iflag_thermals,'   nsplit_thermals=',nsplit_thermals
2768      if(iflag_thermals.lt.0) then
2769!c  Rien
2770!c  ====
2771         IF(prt_level>9)WRITE(lunout,*)'pas de convection'
2772
2773
2774      else
2775
2776!c  Thermiques
2777!c  ==========
2778         IF(prt_level>9)WRITE(lunout,*)'JUSTE AVANT , iflag_thermals='               &
2779       &   ,iflag_thermals,'   nsplit_thermals=',nsplit_thermals
2780
2781
2782!ccc nrlmd le 10/04/2012
2783         DO k=1,klev+1
2784           DO i=1,klon
2785           pbl_tke_input(i,k,is_oce)=pbl_tke(i,k,is_oce)
2786           pbl_tke_input(i,k,is_ter)=pbl_tke(i,k,is_ter)
2787           pbl_tke_input(i,k,is_lic)=pbl_tke(i,k,is_lic)
2788           pbl_tke_input(i,k,is_sic)=pbl_tke(i,k,is_sic)
2789           ENDDO
2790         ENDDO
2791!ccc fin nrlmd le 10/04/2012
2792
2793         if (iflag_thermals>=1) then
2794         call calltherm(pdtphys                                                      &
2795       &      ,pplay,paprs,pphi,weak_inversion                                       &
2796       &      ,u_seri,v_seri,t_seri,q_seri,zqsat,debut                               &
2797       &      ,d_u_ajs,d_v_ajs,d_t_ajs,d_q_ajs                                       &
2798       &      ,fm_therm,entr_therm,detr_therm                                        &
2799       &      ,zqasc,clwcon0th,lmax_th,ratqscth                                      &
2800       &      ,ratqsdiff,zqsatth                                                     &
2801!con rajoute ale et alp, et les caracteristiques de la couche alim                   &
2802       &      ,Ale_bl,Alp_bl,lalim_conv,wght_th, zmax0, f0, zw2,fraca                &
2803       &      ,ztv,zpspsk,ztla,zthl                                                  &
2804!ccc nrlmd le 10/04/2012                                                             &
2805       &      ,pbl_tke_input,pctsrf,omega,airephy                                    &
2806       &      ,zlcl_th,fraca0,w0,w_conv,therm_tke_max0,env_tke_max0                  &
2807       &      ,n2,s2,ale_bl_stat                                                     &
2808       &      ,therm_tke_max,env_tke_max                                             &
2809       &      ,alp_bl_det,alp_bl_fluct_m,alp_bl_fluct_tke                            &
2810       &      ,alp_bl_conv,alp_bl_stat                                               &
2811!ccc fin nrlmd le 10/04/2012                                                         &
2812       &      ,zqla,ztva )
2813
2814!ccc nrlmd le 10/04/2012
2815!c-----------Stochastic triggering-----------
2816      if (iflag_trig_bl.ge.1) then
2817!c
2818        IF (prt_level .GE. 10) THEN
2819         print *,'cin, ale_bl_stat, alp_bl_stat ',                                   &
2820       &            cin, ale_bl_stat, alp_bl_stat
2821        ENDIF
2822
2823!c----Initialisations
2824      do i=1,klon
2825      proba_notrig(i)=1.
2826      random_notrig(i)=1e6*ale_bl_stat(i)-int(1e6*ale_bl_stat(i))
2827        if ( ale_bl_trig(i) .lt. abs(cin(i))+1.e-10 ) then
2828        tau_trig(i)=tau_trig_shallow
2829        else
2830        tau_trig(i)=tau_trig_deep
2831        endif
2832      enddo
2833!c
2834        IF (prt_level .GE. 10) THEN
2835         print *,'random_notrig, tau_trig ',                                         &
2836       &            random_notrig, tau_trig
2837          print *,'s_trig,s2,n2 ',                                                   &
2838       &             s_trig,s2,n2
2839        ENDIF
2840
2841!c----Tirage al\'eatoire et calcul de ale_bl_trig
2842      do i=1,klon
2843        if ( (ale_bl_stat(i) .gt. abs(cin(i))+1.e-10) )  then
2844        proba_notrig(i)=(1.-exp(-s_trig/s2(i)))**                                    &
2845       &                  (n2(i)*dtime/tau_trig(i))
2846!c        print *, 'proba_notrig(i) ',proba_notrig(i)
2847          if (random_notrig(i) .ge. proba_notrig(i)) then
2848          ale_bl_trig(i)=ale_bl_stat(i)
2849          else
2850          ale_bl_trig(i)=0.
2851          endif
2852        else
2853        proba_notrig(i)=1.
2854        random_notrig(i)=0.
2855        ale_bl_trig(i)=0.
2856        endif
2857      enddo
2858!c
2859        IF (prt_level .GE. 10) THEN
2860         print *,'proba_notrig, ale_bl_trig ',                                       &
2861       &            proba_notrig, ale_bl_trig
2862        ENDIF
2863
2864      endif !(iflag_trig_bl)
2865
2866!c-----------Statistical closure-----------
2867      if (iflag_clos_bl.ge.1) then
2868
2869        do i=1,klon
2870        alp_bl(i)=alp_bl_stat(i)
2871        enddo
2872
2873      else
2874
2875      alp_bl_stat(:)=0.
2876
2877      endif !(iflag_clos_bl)
2878
2879        IF (prt_level .GE. 10) THEN
2880         print *,'ale_bl_trig, alp_bl_stat ',ale_bl_trig, alp_bl_stat
2881        ENDIF
2882
2883!ccc fin nrlmd le 10/04/2012
2884
2885! ----------------------------------------------------------------------
2886! Transport de la TKE par les panaches thermiques.
2887! FH : 2010/02/01
2888!     if (iflag_pbl.eq.10) then
2889!     call thermcell_dtke(klon,klev,nbsrf,pdtphys,fm_therm,entr_therm,
2890!    s           rg,paprs,pbl_tke)
2891!     endif
2892! ----------------------------------------------------------------------
2893!IM/FH: 2011/02/23
2894! Couplage Thermiques/Emanuel seulement si T<0
2895      if (iflag_coupl==2) then
2896        print*,'Couplage Thermiques/Emanuel seulement si T<0'
2897        do i=1,klon
2898           if (t_seri(i,lmax_th(i))>273.) then
2899              Ale_bl(i)=0.
2900           endif
2901        enddo
2902      endif
2903
2904      do i=1,klon
2905         zmax_th(i)=pphi(i,lmax_th(i))/rg
2906      enddo
2907
2908         endif
2909
2910
2911!c  Ajustement sec
2912!c  ==============
2913
2914! Dans le cas o\`u on active les thermiques, on fait partir l'ajustement
2915! a partir du sommet des thermiques.
2916! Dans le cas contraire, on demarre au niveau 1.
2917
2918         if (iflag_thermals.ge.13.or.iflag_thermals.eq.0) then
2919
2920         if(iflag_thermals.eq.0) then
2921            IF(prt_level>9)WRITE(lunout,*)'ajsec'
2922            limbas(:)=1
2923         else
2924            limbas(:)=lmax_th(:)
2925         endif
2926 
2927! Attention : le call ajsec_convV2 n'est maintenu que momentanneement
2928! pour des test de convergence numerique.
2929! Le nouveau ajsec est a priori mieux, meme pour le cas
2930! iflag_thermals = 0 (l'ancienne version peut faire des tendances
2931! non nulles numeriquement pour des mailles non concernees.
2932
2933         if (iflag_thermals.eq.0) then
2934            CALL ajsec_convV2(paprs, pplay, t_seri,q_seri                            &
2935       &      , d_t_ajsb, d_q_ajsb)
2936         else
2937            CALL ajsec(paprs, pplay, t_seri,q_seri,limbas                            &
2938       &      , d_t_ajsb, d_q_ajsb)
2939         endif
2940
2941!-----------------------------------------------------------------------------------------
2942! ajout des tendances de l'ajustement sec ou des thermiques
2943      CALL add_phys_tend(du0,dv0,d_t_ajsb,d_q_ajsb,dql0,'ajsb')
2944         d_t_ajs(:,:)=d_t_ajs(:,:)+d_t_ajsb(:,:)
2945         d_q_ajs(:,:)=d_q_ajs(:,:)+d_q_ajsb(:,:)
2946
2947!-----------------------------------------------------------------------------------------
2948
2949         endif
2950
2951      endif
2952
2953!c
2954!c===================================================================
2955!IM
2956      IF (ip_ebil_phy.ge.2) THEN
2957        ztit='after dry_adjust'
2958        CALL diagetpq(airephy,ztit,ip_ebil_phy,2,2,dtime                             &
2959       &      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay              &
2960       &      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
2961        call diagphy(airephy,ztit,ip_ebil_phy                                        &
2962       &      , zero_v, zero_v, zero_v, zero_v, zero_v                               &
2963       &      , zero_v, zero_v, zero_v, ztsol                                        &
2964       &      , d_h_vcol, d_qt, d_ec                                                 &
2965       &      , fs_bound, fq_bound )
2966      END IF
2967      PRINT *,'  Lluis 6 d_h_vcol: ',d_h_vcol,' d_h_vcol_phy: ',d_h_vcol_phy
2968
2969!c-------------------------------------------------------------------------
2970! Computation of ratqs, the width (normalized) of the subrid scale
2971! water distribution
2972      CALL  calcratqs(klon,klev,prt_level,lunout,                                    &
2973       &     iflag_ratqs,iflag_con,iflag_cldcon,pdtphys,                             &
2974       &     ratqsbas,ratqshaut,tau_ratqs,fact_cldcon,                               &
2975       &     ptconv,ptconvth,clwcon0th, rnebcon0th,                                  &
2976       &     paprs,pplay,q_seri,zqsat,fm_therm,                                      &
2977       &     ratqs,ratqsc)
2978
2979
2980!c
2981!c Appeler le processus de condensation a grande echelle
2982!c et le processus de precipitation
2983!c-------------------------------------------------------------------------
2984      IF (prt_level .GE.10) THEN
2985       print *,' ->fisrtilp '
2986      ENDIF
2987!c-------------------------------------------------------------------------
2988      CALL fisrtilp(dtime,paprs,pplay,                                               &
2989       &           t_seri, q_seri,ptconv,ratqs,                                      &
2990       &           d_t_lsc, d_q_lsc, d_ql_lsc, rneb, cldliq,                         &
2991       &           rain_lsc, snow_lsc,                                               &
2992       &           pfrac_impa, pfrac_nucl, pfrac_1nucl,                              &
2993       &           frac_impa, frac_nucl, beta_prec_fisrt,                            &
2994       &           prfl, psfl, rhcl,                                                 &
2995       &           zqasc, fraca,ztv,zpspsk,ztla,zthl,iflag_cldcon )
2996
2997      WHERE (rain_lsc < 0) rain_lsc = 0.
2998      WHERE (snow_lsc < 0) snow_lsc = 0.
2999!-----------------------------------------------------------------------------------------
3000! ajout des tendances de la diffusion turbulente
3001      CALL add_phys_tend(du0,dv0,d_t_lsc,d_q_lsc,d_ql_lsc,'lsc')
3002!-----------------------------------------------------------------------------------------
3003      DO k = 1, klev
3004      DO i = 1, klon
3005         cldfra(i,k) = rneb(i,k)
3006         IF (.NOT.new_oliq) cldliq(i,k) = ql_seri(i,k)
3007      ENDDO
3008      ENDDO
3009      IF (check) THEN
3010         za = qcheck(klon,klev,paprs,q_seri,ql_seri,airephy)
3011         WRITE(lunout,*)"apresilp=", za
3012         zx_t = 0.0
3013         za = 0.0
3014         DO i = 1, klon
3015            za = za + airephy(i)/REAL(klon)
3016            zx_t = zx_t + (rain_lsc(i)                                               &
3017       &                  + snow_lsc(i))*airephy(i)/REAL(klon)
3018        ENDDO
3019         zx_t = zx_t/za*dtime
3020         WRITE(lunout,*)"Precip=", zx_t
3021      ENDIF
3022!IM
3023      IF (ip_ebil_phy.ge.2) THEN
3024        ztit='after fisrt'
3025        CALL diagetpq(airephy,ztit,ip_ebil_phy,2,2,dtime                             &
3026       &      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay              &
3027       &      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
3028        call diagphy(airephy,ztit,ip_ebil_phy                                        &
3029       &      , zero_v, zero_v, zero_v, zero_v, zero_v                               &
3030       &      , zero_v, rain_lsc, snow_lsc, ztsol                                    &
3031       &      , d_h_vcol, d_qt, d_ec                                                 &
3032       &      , fs_bound, fq_bound )
3033      END IF
3034      PRINT *,'  Lluis 7 d_h_vcol: ',d_h_vcol,' d_h_vcol_phy: ',d_h_vcol_phy
3035      if (mydebug) then
3036        call writefield_phy('u_seri',u_seri,llm)
3037        call writefield_phy('v_seri',v_seri,llm)
3038        call writefield_phy('t_seri',t_seri,llm)
3039        call writefield_phy('q_seri',q_seri,llm)
3040      endif
3041!c
3042!c-------------------------------------------------------------------
3043!c  PRESCRIPTION DES NUAGES POUR LE RAYONNEMENT
3044!c-------------------------------------------------------------------
3045
3046!c 1. NUAGES CONVECTIFS
3047!c
3048!IM cf FH
3049!c     IF (iflag_cldcon.eq.-1) THEN ! seulement pour Tiedtke
3050      IF (iflag_cldcon.le.-1) THEN ! seulement pour Tiedtke
3051       snow_tiedtke=0.
3052!c     print*,'avant calcul de la pseudo precip '
3053!c     print*,'iflag_cldcon',iflag_cldcon
3054       if (iflag_cldcon.eq.-1) then
3055          rain_tiedtke=rain_con
3056       else
3057!c       print*,'calcul de la pseudo precip '
3058          rain_tiedtke=0.
3059!c         print*,'calcul de la pseudo precip 0'
3060          do k=1,klev
3061          do i=1,klon
3062             if (d_q_con(i,k).lt.0.) then
3063                rain_tiedtke(i)=rain_tiedtke(i)-d_q_con(i,k)/pdtphys                 &
3064       &         *(paprs(i,k)-paprs(i,k+1))/rg
3065             endif
3066          enddo
3067          enddo
3068       endif
3069!c
3070!c     call dump2d(iim,jjm,rain_tiedtke(2:klon-1),'PSEUDO PRECIP ')
3071!c
3072
3073!c Nuages diagnostiques pour Tiedtke
3074      CALL diagcld1(paprs,pplay,                                                     &
3075!IM cf FH  .             rain_con,snow_con,ibas_con,itop_con,                       &
3076       &             rain_tiedtke,snow_tiedtke,ibas_con,itop_con,                    &
3077       &             diafra,dialiq)
3078      DO k = 1, klev
3079      DO i = 1, klon
3080      IF (diafra(i,k).GT.cldfra(i,k)) THEN
3081         cldliq(i,k) = dialiq(i,k)
3082         cldfra(i,k) = diafra(i,k)
3083      ENDIF
3084      ENDDO
3085      ENDDO
3086
3087      ELSE IF (iflag_cldcon.ge.3) THEN
3088!c  On prend pour les nuages convectifs le max du calcul de la
3089!c  convection et du calcul du pas de temps precedent diminue d'un facteur
3090!c  facttemps
3091      facteur = pdtphys *facttemps
3092      do k=1,klev
3093         do i=1,klon
3094            rnebcon(i,k)=rnebcon(i,k)*facteur
3095            if (rnebcon0(i,k)*clwcon0(i,k).gt.rnebcon(i,k)*clwcon(i,k))              &
3096       &      then
3097                rnebcon(i,k)=rnebcon0(i,k)
3098                clwcon(i,k)=clwcon0(i,k)
3099            endif
3100         enddo
3101      enddo
3102
3103!c
3104!cjq - introduce the aerosol direct and first indirect radiative forcings
3105!cjq - Johannes Quaas, 27/11/2003 (quaas@lmd.jussieu.fr)
3106      IF (flag_aerosol .gt. 0) THEN
3107         IF (.NOT. aerosol_couple)                                                   &
3108       &        CALL readaerosol_optic(                                              &
3109       &        debut, new_aod, flag_aerosol, itap, jD_cur-jD_ref,                   &
3110       &        pdtphys, pplay, paprs, t_seri, rhcl, presnivs,                       &
3111       &        mass_solu_aero, mass_solu_aero_pi,                                   &
3112       &        tau_aero, piz_aero, cg_aero,                                         &
3113       &        tausum_aero, tau3d_aero)
3114      ELSE
3115         tausum_aero(:,:,:) = 0.
3116         tau_aero(:,:,:,:) = 0.
3117         piz_aero(:,:,:,:) = 0.
3118         cg_aero(:,:,:,:)  = 0.
3119      ENDIF
3120!c
3121!c--STRAT AEROSOL
3122!c--updates tausum_aero,tau_aero,piz_aero,cg_aero
3123      IF (flag_aerosol_strat) THEN
3124         PRINT *,'appel a readaerosolstrat', mth_cur
3125         CALL readaerosolstrato(debut)
3126      ENDIF
3127!c--fin STRAT AEROSOL
3128
3129!IM calcul nuages par le simulateur ISCCP
3130!c
3131#ifdef histISCCP
3132      IF (ok_isccp) THEN
3133!c
3134!IM lecture invtau, tautab des fichiers formattes
3135!c
3136      IF (debut) THEN
3137!$OMP MASTER
3138!c
3139      open(99,file='tautab.formatted', FORM='FORMATTED')
3140      read(99,'(f30.20)') tautab_omp
3141      close(99)
3142!c
3143      open(99,file='invtau.formatted',form='FORMATTED')
3144      read(99,'(i10)') invtau_omp
3145
3146!c     print*,'calcul_simulISCCP invtau_omp',invtau_omp
3147!c     write(6,'(a,8i10)') 'invtau_omp',(invtau_omp(i),i=1,100)
3148
3149      close(99)
3150!$OMP END MASTER
3151!$OMP BARRIER
3152      tautab=tautab_omp
3153      invtau=invtau_omp
3154!c
3155      ENDIF !debut
3156!c
3157!IM appel simulateur toutes les  NINT(freq_ISCCP/dtime) heures
3158       IF (MOD(itap,NINT(freq_ISCCP/dtime)).EQ.0) THEN
3159#include "calcul_simulISCCP.h"
3160       ENDIF !(MOD(itap,NINT(freq_ISCCP/dtime))
3161      ENDIF !ok_isccp
3162#endif
3163
3164!c   On prend la somme des fractions nuageuses et des contenus en eau
3165
3166      if (iflag_cldcon>=5) then
3167
3168        do k=1,klev
3169         ptconvth(:,k)=fm_therm(:,k+1)>0.
3170        enddo
3171
3172       if (iflag_coupl==4) then
3173
3174! Dans le cas iflag_coupl==4, on prend la somme des convertures
3175! convectives et lsc dans la partie des thermiques
3176! Le controle par iflag_coupl est peut etre provisoire.
3177         do k=1,klev
3178            do i=1,klon
3179               if (ptconv(i,k).and.ptconvth(i,k)) then
3180                   cldliq(i,k)=cldliq(i,k)+rnebcon(i,k)*clwcon(i,k)
3181                   cldfra(i,k)=min(cldfra(i,k)+rnebcon(i,k),1.)
3182               else if (ptconv(i,k)) then
3183                   cldfra(i,k)=rnebcon(i,k)
3184                   cldliq(i,k)=rnebcon(i,k)*clwcon(i,k)
3185               endif
3186            enddo
3187         enddo
3188
3189         else if (iflag_coupl==5) then
3190         do k=1,klev
3191            do i=1,klon
3192               cldfra(i,k)=min(cldfra(i,k)+rnebcon(i,k),1.)
3193               cldliq(i,k)=cldliq(i,k)+rnebcon(i,k)*clwcon(i,k)
3194            enddo
3195         enddo
3196
3197         else
3198
3199! Si on est sur un point touche par la convection profonde et pas
3200! par les thermiques, on prend la couverture nuageuse et l'eau nuageuse
3201! de la convection profonde.
3202
3203!IM/FH: 2011/02/23
3204! definition des points sur lesquels ls thermiques sont actifs
3205
3206         do k=1,klev
3207            do i=1,klon
3208               if (ptconv(i,k).and. .not. ptconvth(i,k)) then
3209                   cldfra(i,k)=rnebcon(i,k)
3210                   cldliq(i,k)=rnebcon(i,k)*clwcon(i,k)
3211               endif
3212            enddo
3213         enddo
3214
3215        endif
3216
3217      else
3218
3219! Ancienne version
3220      cldfra(:,:)=min(max(cldfra(:,:),rnebcon(:,:)),1.)
3221      cldliq(:,:)=cldliq(:,:)+rnebcon(:,:)*clwcon(:,:)
3222      endif
3223
3224      ENDIF
3225
3226!     plulsc(:)=0.
3227!     do k=1,klev,-1
3228!        do i=1,klon
3229!              zzz=prfl(:,k)+psfl(:,k)
3230!           if (.not.ptconvth.zzz.gt.0.)
3231!        enddo prfl, psfl,
3232!     enddo
3233!c
3234!c 2. NUAGES STARTIFORMES
3235!c
3236      IF (ok_stratus) THEN
3237      CALL diagcld2(paprs,pplay,t_seri,q_seri, diafra,dialiq)
3238      DO k = 1, klev
3239      DO i = 1, klon
3240      IF (diafra(i,k).GT.cldfra(i,k)) THEN
3241         cldliq(i,k) = dialiq(i,k)
3242         cldfra(i,k) = diafra(i,k)
3243      ENDIF
3244      ENDDO
3245      ENDDO
3246      ENDIF
3247!c
3248!c Precipitation totale
3249!c
3250      DO i = 1, klon
3251         rain_fall(i) = rain_con(i) + rain_lsc(i)
3252         snow_fall(i) = snow_con(i) + snow_lsc(i)
3253      ENDDO
3254!IM
3255      IF (ip_ebil_phy.ge.2) THEN
3256        ztit="after diagcld"
3257        CALL diagetpq(airephy,ztit,ip_ebil_phy,2,2,dtime                             &
3258       &      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay              &
3259       &      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
3260        call diagphy(airephy,ztit,ip_ebil_phy                                        &
3261       &      , zero_v, zero_v, zero_v, zero_v, zero_v                               &
3262       &      , zero_v, zero_v, zero_v, ztsol                                        &
3263       &      , d_h_vcol, d_qt, d_ec                                                 &
3264       &      , fs_bound, fq_bound )
3265      END IF
3266      PRINT *,'  Lluis 8 d_h_vcol: ',d_h_vcol,' d_h_vcol_phy: ',d_h_vcol_phy
3267!c
3268!c Calculer l'humidite relative pour diagnostique
3269!c
3270      DO k = 1, klev
3271      DO i = 1, klon
3272         zx_t = t_seri(i,k)
3273         IF (thermcep) THEN
3274            zdelta = MAX(0.,SIGN(1.,rtt-zx_t))
3275            zx_qs  = r2es * FOEEW(zx_t,zdelta)/pplay(i,k)
3276            zx_qs  = MIN(0.5,zx_qs)
3277            zcor   = 1./(1.-retv*zx_qs)
3278            zx_qs  = zx_qs*zcor
3279         ELSE
3280           IF (zx_t.LT.t_coup) THEN
3281              zx_qs = qsats(zx_t)/pplay(i,k)
3282           ELSE
3283              zx_qs = qsatl(zx_t)/pplay(i,k)
3284           ENDIF
3285         ENDIF
3286         zx_rh(i,k) = q_seri(i,k)/zx_qs
3287         zqsat(i,k)=zx_qs
3288      ENDDO
3289      ENDDO
3290
3291!IM Calcul temp.potentielle a 2m (tpot) et temp. potentielle
3292!c   equivalente a 2m (tpote) pour diagnostique
3293!c
3294      DO i = 1, klon
3295       tpot(i)=zt2m(i)*(100000./paprs(i,1))**RKAPPA
3296       IF (thermcep) THEN
3297        IF(zt2m(i).LT.RTT) then
3298         Lheat=RLSTT
3299        ELSE
3300         Lheat=RLVTT
3301        ENDIF
3302       ELSE
3303        IF (zt2m(i).LT.RTT) THEN
3304         Lheat=RLSTT
3305        ELSE
3306         Lheat=RLVTT
3307        ENDIF
3308       ENDIF
3309       tpote(i) = tpot(i)*                                                           &
3310       & EXP((Lheat *qsat2m(i))/(RCPD*zt2m(i)))
3311      ENDDO
3312
3313      IF (type_trac == 'inca') THEN
3314#ifdef INCA
3315         CALL VTe(VTphysiq)
3316         CALL VTb(VTinca)
3317         calday = REAL(days_elapsed + 1) + jH_cur
3318
3319         call chemtime(itap+itau_phy-1, date0, dtime)
3320         IF (config_inca == 'aero') THEN
3321            CALL AEROSOL_METEO_CALC(                                                 &
3322       &           calday,pdtphys,pplay,paprs,t,pmflxr,pmflxs,                       &
3323       &           prfl,psfl,pctsrf,airephy,rlat,rlon,u10m,v10m)
3324         END IF
3325
3326         zxsnow_dummy(:) = 0.0
3327
3328         CALL chemhook_begin (calday,                                                &
3329       &                          days_elapsed+1,                                    &
3330       &                          jH_cur,                                            &
3331       &                          pctsrf(1,1),                                       &
3332       &                          rlat,                                              &
3333       &                          rlon,                                              &
3334       &                          airephy,                                           &
3335       &                          paprs,                                             &
3336       &                          pplay,                                             &
3337       &                          coefh(:,:,is_ave),                                 &
3338       &                          pphi,                                              &
3339       &                          t_seri,                                            &
3340       &                          u,                                                 &
3341       &                          v,                                                 &
3342       &                          wo(:, :, 1),                                       &
3343       &                          q_seri,                                            &
3344       &                          zxtsol,                                            &
3345       &                          zxsnow_dummy,                                      &
3346       &                          solsw,                                             &
3347       &                          albsol1,                                           &
3348       &                          rain_fall,                                         &
3349       &                          snow_fall,                                         &
3350       &                          itop_con,                                          &
3351       &                          ibas_con,                                          &
3352       &                          cldfra,                                            &
3353       &                          iim,                                               &
3354       &                          jjm,                                               &
3355       &                          tr_seri,                                           &
3356       &                          ftsol,                                             &
3357       &                          paprs,                                             &
3358       &                          cdragh,                                            &
3359       &                          cdragm,                                            &
3360       &                          pctsrf,                                            &
3361       &                          pdtphys,                                           &
3362       &                            itap)
3363
3364         CALL VTe(VTinca)
3365         CALL VTb(VTphysiq)
3366#endif
3367      END IF !type_trac = inca
3368!c     
3369!c Calculer les parametres optiques des nuages et quelques
3370!c parametres pour diagnostiques:
3371!c
3372
3373      IF (aerosol_couple) THEN
3374         mass_solu_aero(:,:)    = ccm(:,:,1)
3375         mass_solu_aero_pi(:,:) = ccm(:,:,2)
3376      END IF
3377
3378      if (ok_newmicro) then
3379      CALL newmicro (ok_cdnc, bl95_b0, bl95_b1,                                      &
3380       &              paprs, pplay, t_seri, cldliq, cldfra,                          &
3381       &              cldtau, cldemi, cldh, cldl, cldm, cldt, cldq,                  &
3382       &              flwp, fiwp, flwc, fiwc,                                        &
3383       &              mass_solu_aero, mass_solu_aero_pi,                             &
3384       &              cldtaupi, re, fl, ref_liq, ref_ice)
3385      else
3386      CALL nuage (paprs, pplay,                                                      &
3387       &            t_seri, cldliq, cldfra, cldtau, cldemi,                          &
3388       &            cldh, cldl, cldm, cldt, cldq,                                    &
3389       &            ok_aie,                                                          &
3390       &            mass_solu_aero, mass_solu_aero_pi,                               &
3391       &            bl95_b0, bl95_b1,                                                &
3392       &            cldtaupi, re, fl)
3393      endif
3394!c
3395!IM betaCRF
3396!c
3397      cldtaurad   = cldtau
3398      cldtaupirad = cldtaupi
3399      cldemirad   = cldemi                                                           &
3400       &!c
3401      if(lon1_beta.EQ.-180..AND.lon2_beta.EQ.180..AND.                               &
3402       &lat1_beta.EQ.90..AND.lat2_beta.EQ.-90.) THEN
3403!c
3404!c global
3405!c
3406       DO k=1, klev
3407       DO i=1, klon
3408        if (pplay(i,k).GE.pfree) THEN
3409         beta(i,k) = beta_pbl
3410        else
3411         beta(i,k) = beta_free
3412        endif
3413        if (mskocean_beta) THEN
3414         beta(i,k) = beta(i,k) * pctsrf(i,is_oce)
3415        endif
3416        cldtaurad(i,k)   = cldtau(i,k) * beta(i,k)
3417        cldtaupirad(i,k) = cldtaupi(i,k) * beta(i,k)
3418        cldemirad(i,k)   = cldemi(i,k) * beta(i,k)
3419        cldfrarad(i,k)   = cldfra(i,k) * beta(i,k)
3420       ENDDO
3421       ENDDO
3422!c
3423      else
3424!c
3425!c regional
3426!c
3427       DO k=1, klev
3428       DO i=1,klon
3429!c
3430        if (rlon(i).ge.lon1_beta.AND.rlon(i).le.lon2_beta.AND.                       &
3431       &      rlat(i).le.lat1_beta.AND.rlat(i).ge.lat2_beta) THEN
3432         if (pplay(i,k).GE.pfree) THEN
3433          beta(i,k) = beta_pbl
3434         else
3435          beta(i,k) = beta_free
3436         endif
3437         if (mskocean_beta) THEN
3438          beta(i,k) = beta(i,k) * pctsrf(i,is_oce)
3439         endif
3440        cldtaurad(i,k)   = cldtau(i,k) * beta(i,k)
3441        cldtaupirad(i,k) = cldtaupi(i,k) * beta(i,k)
3442        cldemirad(i,k)   = cldemi(i,k) * beta(i,k)
3443        cldfrarad(i,k)   = cldfra(i,k) * beta(i,k)
3444        endif
3445!c
3446       ENDDO
3447       ENDDO
3448!c
3449      endif
3450!c
3451!c Appeler le rayonnement mais calculer tout d'abord l'albedo du sol.
3452!c
3453      IF (MOD(itaprad,radpas).EQ.0) THEN
3454
3455      DO i = 1, klon
3456         albsol1(i) = falb1(i,is_oce) * pctsrf(i,is_oce)                             &
3457       &             + falb1(i,is_lic) * pctsrf(i,is_lic)                            &
3458       &             + falb1(i,is_ter) * pctsrf(i,is_ter)                            &
3459       &             + falb1(i,is_sic) * pctsrf(i,is_sic)
3460         albsol2(i) = falb2(i,is_oce) * pctsrf(i,is_oce)                             &
3461       &               + falb2(i,is_lic) * pctsrf(i,is_lic)                          &
3462       &               + falb2(i,is_ter) * pctsrf(i,is_ter)                          &
3463       &               + falb2(i,is_sic) * pctsrf(i,is_sic)
3464      ENDDO
3465
3466      if (mydebug) then
3467        call writefield_phy('u_seri',u_seri,llm)
3468        call writefield_phy('v_seri',v_seri,llm)
3469        call writefield_phy('t_seri',t_seri,llm)
3470        call writefield_phy('q_seri',q_seri,llm)
3471      endif
3472     
3473      IF (aerosol_couple) THEN
3474#ifdef INCA
3475         CALL radlwsw_inca                                                           &
3476       &        (kdlon,kflev,dist, rmu0, fract, solaire,                             &
3477       &        paprs, pplay,zxtsol,albsol1, albsol2, t_seri,q_seri,                 &
3478       &        wo(:, :, 1),                                                         &
3479       &        cldfrarad, cldemirad, cldtaurad,                                     &
3480       &        heat,heat0,cool,cool0,radsol,albpla,                                 &
3481       &        topsw,toplw,solsw,sollw,                                             &
3482       &        sollwdown,                                                           &
3483       &        topsw0,toplw0,solsw0,sollw0,                                         &
3484       &        lwdn0, lwdn, lwup0, lwup,                                            &
3485       &        swdn0, swdn, swup0, swup,                                            &
3486       &        ok_ade, ok_aie,                                                      &
3487       &        tau_aero, piz_aero, cg_aero,                                         &
3488       &        topswad_aero, solswad_aero,                                          &
3489       &        topswad0_aero, solswad0_aero,                                        &
3490       &        topsw_aero, topsw0_aero,                                             &
3491       &        solsw_aero, solsw0_aero,                                             &
3492       &        cldtaupirad,                                                         &
3493       &        topswai_aero, solswai_aero)
3494           
3495#endif
3496      ELSE
3497!c
3498!IM calcul radiatif pour le cas actuel
3499!c
3500       RCO2 = RCO2_act
3501       RCH4 = RCH4_act
3502       RN2O = RN2O_act
3503       RCFC11 = RCFC11_act
3504       RCFC12 = RCFC12_act
3505!c
3506      IF (prt_level .GE.10) THEN
3507       print *,' ->radlwsw, number 1 '
3508      ENDIF
3509!c
3510      PRINT *,'  Lluis before calling radlwsw rmu0: ',rmu0(llp),   &
3511        ' dist: ',dist,' frac: ',fract(llp),' jH_cur: ',jH_cur
3512         CALL radlwsw                                                                &
3513       &        (dist, rmu0, fract,                                                  &
3514       &        paprs, pplay,zxtsol,albsol1, albsol2,                                &
3515       &        t_seri,q_seri,wo,                                                    &
3516       &        cldfrarad, cldemirad, cldtaurad,                                     &
3517       &        ok_ade.OR.flag_aerosol_strat, ok_aie, flag_aerosol,                  &
3518       &        flag_aerosol_strat,                                                  &
3519       &        tau_aero, piz_aero, cg_aero,                                         &
3520       &        cldtaupirad,new_aod,                                                 &
3521       &        zqsat, flwc, fiwc,                                                   &
3522       &        heat,heat0,cool,cool0,radsol,albpla,                                 &
3523       &        topsw,toplw,solsw,sollw,                                             &
3524       &        sollwdown,                                                           &
3525       &        topsw0,toplw0,solsw0,sollw0,                                         &
3526       &        lwdn0, lwdn, lwup0, lwup,                                            &
3527       &        swdn0, swdn, swup0, swup,                                            &
3528       &        topswad_aero, solswad_aero,                                          &
3529       &        topswai_aero, solswai_aero,                                          &
3530       &        topswad0_aero, solswad0_aero,                                        &
3531       &        topsw_aero, topsw0_aero,                                             &
3532       &        solsw_aero, solsw0_aero,                                             &
3533       &        topswcf_aero, solswcf_aero)
3534      PRINT *,'  Lluis after calling radlwsw rmu0: ',rmu0(llp),   &
3535        ' dist: ',dist,' frac: ',fract(llp),' jH_cur: ',jH_cur
3536         
3537!c
3538!IM 2eme calcul radiatif pour le cas perturbe ou au moins un
3539!IM des taux doit etre different du taux actuel
3540!IM Par defaut on a les taux perturbes egaux aux taux actuels
3541!c
3542
3543      if (ok_4xCO2atm) then
3544       if (RCO2_per.NE.RCO2_act.OR.RCH4_per.NE.RCH4_act.OR.                          &
3545       &RN2O_per.NE.RN2O_act.OR.RCFC11_per.NE.RCFC11_act.OR.                         &
3546       &RCFC12_per.NE.RCFC12_act) THEN
3547!c
3548       RCO2 = RCO2_per
3549       RCH4 = RCH4_per
3550       RN2O = RN2O_per
3551       RCFC11 = RCFC11_per
3552       RCFC12 = RCFC12_per
3553!c
3554      IF (prt_level .GE.10) THEN
3555       print *,' ->radlwsw, number 2 '
3556      ENDIF
3557!c
3558         CALL radlwsw                                                                &
3559       &        (dist, rmu0, fract,                                                  &
3560       &        paprs, pplay,zxtsol,albsol1, albsol2,                                &
3561       &        t_seri,q_seri,wo,                                                    &
3562       &        cldfra, cldemi, cldtau,                                              &
3563       &        ok_ade.OR.flag_aerosol_strat, ok_aie, flag_aerosol,                  &
3564       &        flag_aerosol_strat,                                                  &
3565       &        tau_aero, piz_aero, cg_aero,                                         &
3566       &        cldtaupi,new_aod,                                                    &
3567       &        zqsat, flwc, fiwc,                                                   &
3568       &        heatp,heat0p,coolp,cool0p,radsolp,albplap,                           &
3569       &        topswp,toplwp,solswp,sollwp,                                         &
3570       &        sollwdownp,                                                          &
3571       &        topsw0p,toplw0p,solsw0p,sollw0p,                                     &
3572       &        lwdn0p, lwdnp, lwup0p, lwupp,                                        &
3573       &        swdn0p, swdnp, swup0p, swupp,                                        &
3574       &        topswad_aerop, solswad_aerop,                                        &
3575       &        topswai_aerop, solswai_aerop,                                        &
3576       &        topswad0_aerop, solswad0_aerop,                                      &
3577       &        topsw_aerop, topsw0_aerop,                                           &
3578       &        solsw_aerop, solsw0_aerop,                                           &
3579       &        topswcf_aerop, solswcf_aerop)
3580       endif
3581      endif
3582!c
3583      ENDIF ! aerosol_couple
3584      itaprad = 0
3585      ENDIF ! MOD(itaprad,radpas)
3586      itaprad = itaprad + 1
3587
3588      IF (iflag_radia.eq.0) THEN
3589         IF (prt_level.ge.9) THEN
3590            PRINT *,'--------------------------------------------------'
3591            PRINT *,'>>>> ATTENTION rayonnement desactive pour ce cas'
3592            PRINT *,'>>>>           heat et cool mis a zero '
3593            PRINT *,'--------------------------------------------------'
3594         END IF
3595         heat=0.
3596         cool=0.
3597         sollw=0.   ! MPL 01032011
3598         solsw=0.
3599         radsol=0.
3600         swup=0.    ! MPL 27102011 pour les fichiers AMMA_profiles et AMMA_scalars
3601         swup0=0.
3602         swdn=0.
3603         swdn0=0.
3604         lwup=0.
3605         lwup0=0.
3606         lwdn=0.
3607         lwdn0=0.
3608      END IF
3609
3610!c
3611!c Ajouter la tendance des rayonnements (tous les pas)
3612!c
3613      DO k = 1, klev
3614      DO i = 1, klon
3615         t_seri(i,k) = t_seri(i,k)                                                   &
3616       &               + (heat(i,k)-cool(i,k)) * dtime/RDAY
3617      ENDDO
3618      ENDDO
3619!c
3620      if (mydebug) then
3621        call writefield_phy('u_seri',u_seri,llm)
3622        call writefield_phy('v_seri',v_seri,llm)
3623        call writefield_phy('t_seri',t_seri,llm)
3624        call writefield_phy('q_seri',q_seri,llm)
3625      endif
3626 
3627!IM
3628      IF (ip_ebil_phy.ge.2) THEN
3629        ztit='after rad'
3630        CALL diagetpq(airephy,ztit,ip_ebil_phy,2,2,dtime                             &
3631       &      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay              &
3632       &      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
3633        call diagphy(airephy,ztit,ip_ebil_phy                                        &
3634       &      , topsw, toplw, solsw, sollw, zero_v                                   &
3635       &      , zero_v, zero_v, zero_v, ztsol                                        &
3636       &      , d_h_vcol, d_qt, d_ec                                                 &
3637       &      , fs_bound, fq_bound )
3638      END IF
3639      PRINT *,'  Lluis 9 d_h_vcol: ',d_h_vcol,' d_h_vcol_phy: ',d_h_vcol_phy
3640!c
3641!c
3642!c Calculer l'hydrologie de la surface
3643!c
3644!c      CALL hydrol(dtime,pctsrf,rain_fall, snow_fall, zxevap,
3645!c     .            agesno, ftsol,fqsurf,fsnow, ruis)
3646!c
3647
3648!c
3649!c Calculer le bilan du sol et la derive de temperature (couplage)
3650!c
3651      DO i = 1, klon
3652!c         bils(i) = radsol(i) - sens(i) - evap(i)*RLVTT
3653!c a la demande de JLD
3654         bils(i) = radsol(i) - sens(i) + zxfluxlat(i)
3655      ENDDO
3656!c
3657!cmoddeblott(jan95)
3658!c Appeler le programme de parametrisation de l'orographie
3659!c a l'echelle sous-maille:
3660!c
3661      IF (prt_level .GE.10) THEN
3662       print *,' call orography ? ', ok_orodr
3663      ENDIF
3664!c
3665      IF (ok_orodr) THEN
3666!c
3667!c  selection des points pour lesquels le shema est actif:
3668        igwd=0
3669        DO i=1,klon
3670        itest(i)=0
3671!c        IF ((zstd(i).gt.10.0)) THEN
3672        IF (((zpic(i)-zmea(i)).GT.100.).AND.(zstd(i).GT.10.0)) THEN
3673          itest(i)=1
3674          igwd=igwd+1
3675          idx(igwd)=i
3676        ENDIF
3677        ENDDO
3678!c        igwdim=MAX(1,igwd)
3679!c
3680        IF (ok_strato) THEN
3681       
3682          CALL drag_noro_strato(klon,klev,dtime,paprs,pplay,                         &
3683       &                   zmea,zstd, zsig, zgam, zthe,zpic,zval,                    &
3684       &                   igwd,idx,itest,                                           &
3685       &                   t_seri, u_seri, v_seri,                                   &
3686       &                   zulow, zvlow, zustrdr, zvstrdr,                           &
3687       &                   d_t_oro, d_u_oro, d_v_oro)
3688
3689       ELSE
3690        CALL drag_noro(klon,klev,dtime,paprs,pplay,                                  &
3691       &                   zmea,zstd, zsig, zgam, zthe,zpic,zval,                    &
3692       &                   igwd,idx,itest,                                           &
3693       &                   t_seri, u_seri, v_seri,                                   &
3694       &                   zulow, zvlow, zustrdr, zvstrdr,                           &
3695       &                   d_t_oro, d_u_oro, d_v_oro)
3696       ENDIF
3697!c
3698!c  ajout des tendances
3699!-----------------------------------------------------------------------------------------
3700! ajout des tendances de la trainee de l'orographie
3701      CALL add_phys_tend(d_u_oro,d_v_oro,d_t_oro,dq0,dql0,'oro')
3702!-----------------------------------------------------------------------------------------
3703!c
3704      ENDIF ! fin de test sur ok_orodr
3705!c
3706      if (mydebug) then
3707        call writefield_phy('u_seri',u_seri,llm)
3708        call writefield_phy('v_seri',v_seri,llm)
3709        call writefield_phy('t_seri',t_seri,llm)
3710        call writefield_phy('q_seri',q_seri,llm)
3711      endif
3712     
3713      IF (ok_orolf) THEN
3714!c
3715!c  selection des points pour lesquels le shema est actif:
3716        igwd=0
3717        DO i=1,klon
3718        itest(i)=0
3719        IF ((zpic(i)-zmea(i)).GT.100.) THEN
3720          itest(i)=1
3721          igwd=igwd+1
3722          idx(igwd)=i
3723        ENDIF
3724        ENDDO
3725!c        igwdim=MAX(1,igwd)
3726!c
3727        IF (ok_strato) THEN
3728
3729          CALL lift_noro_strato(klon,klev,dtime,paprs,pplay,                         &
3730       &                   rlat,zmea,zstd,zpic,zgam,zthe,zpic,zval,                  &
3731       &                   igwd,idx,itest,                                           &
3732       &                   t_seri, u_seri, v_seri,                                   &
3733       &                   zulow, zvlow, zustrli, zvstrli,                           &
3734       &                   d_t_lif, d_u_lif, d_v_lif               )
3735       
3736        ELSE
3737          CALL lift_noro(klon,klev,dtime,paprs,pplay,                                &
3738       &                   rlat,zmea,zstd,zpic,                                      &
3739       &                   itest,                                                    &
3740       &                   t_seri, u_seri, v_seri,                                   &
3741       &                   zulow, zvlow, zustrli, zvstrli,                           &
3742       &                   d_t_lif, d_u_lif, d_v_lif)
3743       ENDIF
3744!c   
3745!-----------------------------------------------------------------------------------------
3746! ajout des tendances de la portance de l'orographie
3747      CALL add_phys_tend(d_u_lif,d_v_lif,d_t_lif,dq0,dql0,'lif')
3748!-----------------------------------------------------------------------------------------
3749!c
3750      ENDIF ! fin de test sur ok_orolf
3751!C  HINES GWD PARAMETRIZATION
3752
3753       IF (ok_hines) then
3754
3755         CALL hines_gwd(klon,klev,dtime,paprs,pplay,                                 &
3756       &                  rlat,t_seri,u_seri,v_seri,                                 &
3757       &                  zustrhi,zvstrhi,                                           &
3758       &                  d_t_hin, d_u_hin, d_v_hin)
3759!c
3760!c  ajout des tendances
3761        CALL add_phys_tend(d_u_hin,d_v_hin,d_t_hin,dq0,dql0,'hin')
3762
3763      ENDIF
3764!c
3765
3766!c
3767!IM cf. FLott BEG
3768!C STRESS NECESSAIRES: TOUTE LA PHYSIQUE
3769
3770      if (mydebug) then
3771        call writefield_phy('u_seri',u_seri,llm)
3772        call writefield_phy('v_seri',v_seri,llm)
3773        call writefield_phy('t_seri',t_seri,llm)
3774        call writefield_phy('q_seri',q_seri,llm)
3775      endif
3776
3777      DO i = 1, klon
3778        zustrph(i)=0.
3779        zvstrph(i)=0.
3780      ENDDO
3781      DO k = 1, klev
3782      DO i = 1, klon
3783       zustrph(i)=zustrph(i)+(u_seri(i,k)-u(i,k))/dtime*                             &
3784       &            (paprs(i,k)-paprs(i,k+1))/rg
3785       zvstrph(i)=zvstrph(i)+(v_seri(i,k)-v(i,k))/dtime*                             &
3786       &            (paprs(i,k)-paprs(i,k+1))/rg
3787      ENDDO
3788      ENDDO
3789!c
3790!IM calcul composantes axiales du moment angulaire et couple des montagnes
3791!c
3792!      IF (is_sequential .and. ok_orodr) THEN
3793!        CALL aaam_bud (27,klon,klev,jD_cur-jD_ref,jH_cur,                            &
3794!       &                 ra,rg,romega,                                               &
3795!       &                 rlat,rlon,pphis,                                            &
3796!       &                 zustrdr,zustrli,zustrph,                                    &
3797!       &                 zvstrdr,zvstrli,zvstrph,                                    &
3798!       &                 paprs,u,v,                                                  &
3799!       &                 aam, torsfc)
3800!       ENDIF
3801!IM cf. FLott END
3802!IM
3803      IF (ip_ebil_phy.ge.2) THEN
3804        ztit='after orography'
3805        CALL diagetpq(airephy,ztit,ip_ebil_phy,2,2,dtime                             &
3806       &      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay              &
3807       &      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
3808         call diagphy(airephy,ztit,ip_ebil_phy                                       &
3809       &      , zero_v, zero_v, zero_v, zero_v, zero_v                               &
3810       &      , zero_v, zero_v, zero_v, ztsol                                        &
3811       &      , d_h_vcol, d_qt, d_ec                                                 &
3812       &      , fs_bound, fq_bound )
3813      END IF
3814      PRINT *,'  Lluis 10 d_h_vcol: ',d_h_vcol,' d_h_vcol_phy: ',d_h_vcol_phy
3815!c
3816!c
3817!====================================================================
3818! Interface Simulateur COSP (Calipso, ISCCP, MISR, ..)
3819!====================================================================
3820! Abderrahmane 24.08.09
3821
3822      IF (ok_cosp) THEN
3823! adeclarer
3824#ifdef CPP_COSP
3825       IF (MOD(itap,NINT(freq_cosp/dtime)).EQ.0) THEN
3826
3827       print*,'freq_cosp',freq_cosp
3828          mr_ozone=wo(:, :, 1) * dobson_u * 1e3 / zmasse
3829!       print*,'Dans physiq.F avant appel cosp ref_liq,ref_ice=',
3830!     s        ref_liq,ref_ice
3831          call phys_cosp(itap,dtime,freq_cosp,                                       &
3832       &                   ok_mensuelCOSP,ok_journeCOSP,ok_hfCOSP,                   &
3833       &                   ecrit_mth,ecrit_day,ecrit_hf,                             &
3834       &                   klon,klev,rlon,rlat,presnivs,overlap,                     &
3835       &                   ref_liq,ref_ice,                                          &
3836       &                   pctsrf(:,is_ter)+pctsrf(:,is_lic),                        &
3837       &                   zu10m,zv10m,pphis,                                        &
3838       &                   zphi,paprs(:,1:klev),pplay,zxtsol,t_seri,                 &
3839       &                   qx(:,:,ivap),zx_rh,cldfra,rnebcon,flwc,fiwc,              &
3840       &                   prfl(:,1:klev),psfl(:,1:klev),                            &
3841       &                   pmflxr(:,1:klev),pmflxs(:,1:klev),                        &
3842       &                   mr_ozone,cldtau, cldemi)
3843
3844!     L          calipso2D,calipso3D,cfadlidar,parasolrefl,atb,betamol,
3845!     L          cfaddbze,clcalipso2,dbze,cltlidarradar,
3846!     M          clMISR,
3847!     R          clisccp2,boxtauisccp,boxptopisccp,tclisccp,ctpisccp,
3848!     I          tauisccp,albisccp,meantbisccp,meantbclrisccp)
3849
3850         ENDIF
3851
3852#endif
3853       ENDIF  !ok_cosp
3854!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
3855!cAA
3856!cAA Installation de l'interface online-offline pour traceurs
3857!cAA
3858!c====================================================================
3859!c   Calcul  des tendances traceurs
3860!c====================================================================
3861!C
3862
3863       IF (type_trac=='repr') THEN
3864          sh_in(:,:) = q_seri(:,:)
3865       ELSE
3866          sh_in(:,:) = qx(:,:,ivap)
3867       END IF
3868
3869      call phytrac (                                                                 &
3870       &     itap,     days_elapsed+1,    jH_cur,   debut,                           &
3871       &     lafin,    dtime,     u, v,     t,                                       &
3872       &     paprs,    pplay,     pmfu,     pmfd,                                    &
3873       &     pen_u,    pde_u,     pen_d,    pde_d,                                   &
3874       &     cdragh,   coefh(:,:,is_ave),     fm_therm, entr_therm,                  &
3875       &     u1,       v1,        ftsol,    pctsrf,                                  &
3876       &     ustar,     u10m,      v10m,                                             &
3877       &     rlat,     rlon,                                                         &
3878       &     frac_impa,frac_nucl, beta_prec_fisrt,beta_prec,                         &
3879       &     presnivs, pphis,     pphi,     albsol1,                                 &
3880       &     sh_in,    rhcl,      cldfra,   rneb,                                    &
3881       &     diafra,   cldliq,    itop_con, ibas_con,                                &
3882       &     pmflxr,   pmflxs,    prfl,     psfl,                                    &
3883       &     da,       phi,       mp,       upwd,                                    &
3884       &     phi2,     d1a,       dam,      sij,                                     &
3885       &     wdtrainA, wdtrainM,  sigd,     clw,elij,                                &
3886       &     ev,       ep,        epmlmMm,  eplaMm,                                  &
3887       &     dnwd,     aerosol_couple,      flxmass_w,                               &
3888       &     tau_aero, piz_aero,  cg_aero,  ccm,                                     &
3889       &     rfname,                                                                 &
3890       &     d_tr_dyn,                                                               &
3891       &     tr_seri)
3892
3893      IF (offline) THEN
3894
3895       IF (prt_level.ge.9)                                                           &
3896       &    print*,'Attention on met a 0 les thermiques pour phystoke'
3897         call phystokenc (                                                                  &
3898       &                   nlon,klev,pdtphys,rlon,rlat,                              &
3899       &                   t,pmfu, pmfd, pen_u, pde_u, pen_d, pde_d,                 &
3900       &                   fm_therm,entr_therm,                                      &
3901       &                   cdragh,coefh(:,:,is_ave),u1,v1,ftsol,pctsrf,              &
3902       &                   frac_impa, frac_nucl,                                     &
3903       &                   pphis,airephy,dtime,itap,                                 &
3904       &                   qx(:,:,ivap),da,phi,mp,upwd,dnwd)
3905
3906
3907      ENDIF
3908
3909!c
3910!c Calculer le transport de l'eau et de l'energie (diagnostique)
3911!c
3912      CALL transp (paprs,zxtsol,                                                     &
3913       &                   t_seri, q_seri, u_seri, v_seri, zphi,                     &
3914       &                   ve, vq, ue, uq)
3915!c
3916!IM global posePB BEG
3917      IF(1.EQ.0) THEN
3918!c
3919      CALL transp_lay (paprs,zxtsol,                                                 &
3920       &                   t_seri, q_seri, u_seri, v_seri, zphi,                     &
3921       &                   ve_lay, vq_lay, ue_lay, uq_lay)
3922!c
3923      ENDIF !(1.EQ.0) THEN
3924!IM global posePB END
3925!c Accumuler les variables a stocker dans les fichiers histoire:
3926!c
3927
3928!================================================================
3929! Conversion of kinetic and potential energy into heat, for
3930! parameterisation of subgrid-scale motions
3931!================================================================
3932
3933      d_t_ec(:,:)=0.
3934      forall (k=1: llm) exner(:, k) = (pplay(:, k)/paprs(:,1))**RKAPPA
3935      CALL ener_conserv(klon,klev,pdtphys,u,v,t,qx(:,:,ivap),                        &
3936       &        u_seri,v_seri,t_seri,q_seri,pbl_tke(:,:,is_ave)-tke0(:,:),           &
3937       &        zmasse,exner,d_t_ec)
3938      t_seri(:,:)=t_seri(:,:)+d_t_ec(:,:)
3939
3940!IM
3941      IF (ip_ebil_phy.ge.1) THEN
3942        ztit='after physic'
3943        CALL diagetpq(airephy,ztit,ip_ebil_phy,1,1,dtime                             &
3944       &      , t_seri,q_seri,ql_seri,qs_seri,u_seri,v_seri,paprs,pplay              &
3945       &      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
3946!C     Comme les tendances de la physique sont ajoute dans la dynamique,
3947!C     on devrait avoir que la variation d'entalpie par la dynamique
3948!C     est egale a la variation de la physique au pas de temps precedent.
3949!C     Donc la somme de ces 2 variations devrait etre nulle.
3950
3951       PRINT *,'  LLuis sending: d_h_vcol: ',d_h_vcol,' d_qt ',d_qt,' d_ec ',d_ec
3952
3953        call diagphy(airephy,ztit,ip_ebil_phy                                        &
3954       &      , topsw, toplw, solsw, sollw, sens                                     &
3955       &      , evap, rain_fall, snow_fall, ztsol                                    &
3956       &      , d_h_vcol, d_qt, d_ec                                                 &
3957       &      , fs_bound, fq_bound )
3958!C
3959      d_h_vcol_phy=d_h_vcol
3960!C
3961      END IF
3962      PRINT *,'  Lluis 11 d_h_vcol: ',d_h_vcol,' d_h_vcol_phy: ',d_h_vcol_phy
3963      PRINT *,'Lluis Reaching the SORTIES point'
3964
3965!C
3966!c=======================================================================
3967!c   SORTIES
3968!c=======================================================================
3969
3970!IM Interpolation sur les niveaux de pression du NMC
3971!c   -------------------------------------------------
3972!c
3973#include "calcul_STDlev.h"
3974!c
3975!c slp sea level pressure
3976      slp(:) = paprs(:,1)*exp(pphis(:)/(RD*t_seri(:,1)))
3977!c
3978!ccc prw = eau precipitable
3979      DO i = 1, klon
3980       prw(i) = 0.
3981       DO k = 1, klev
3982        prw(i) = prw(i) +                                                            &
3983       &           q_seri(i,k)*(paprs(i,k)-paprs(i,k+1))/RG
3984       ENDDO
3985      ENDDO
3986!c
3987!IM initialisation + calculs divers diag AMIP2
3988!c
3989#include "calcul_divers.h"
3990!c
3991      IF (type_trac == 'inca') THEN
3992#ifdef INCA
3993         CALL VTe(VTphysiq)
3994         CALL VTb(VTinca)
3995
3996         CALL chemhook_end (                                                         &
3997       &                        dtime,                                               &
3998       &                        pplay,                                               &
3999       &                        t_seri,                                              &
4000       &                        tr_seri,                                             &
4001       &                        nbtr,                                                &
4002       &                        paprs,                                               &
4003       &                        q_seri,                                              &
4004       &                        airephy,                                             &
4005       &                        pphi,                                                &
4006       &                        pphis,                                               &
4007       &                        zx_rh)
4008
4009         CALL VTe(VTinca)
4010         CALL VTb(VTphysiq)
4011#endif
4012      END IF
4013
4014
4015!c
4016!c Convertir les incrementations en tendances
4017!c
4018      IF (prt_level .GE.10) THEN
4019        print *,'Convertir les incrementations en tendances '
4020      ENDIF
4021!c
4022      if (mydebug) then
4023        call writefield_phy('u_seri',u_seri,llm)
4024        call writefield_phy('v_seri',v_seri,llm)
4025        call writefield_phy('t_seri',t_seri,llm)
4026        call writefield_phy('q_seri',q_seri,llm)
4027      endif
4028
4029      DO k = 1, klev
4030      DO i = 1, klon
4031         d_u(i,k) = ( u_seri(i,k) - u(i,k) ) / dtime
4032         d_v(i,k) = ( v_seri(i,k) - v(i,k) ) / dtime
4033         d_t(i,k) = ( t_seri(i,k)-t(i,k) ) / dtime
4034         d_qx(i,k,ivap) = ( q_seri(i,k) - qx(i,k,ivap) ) / dtime
4035         d_qx(i,k,iliq) = ( ql_seri(i,k) - qx(i,k,iliq) ) / dtime
4036      ENDDO
4037      ENDDO
4038!c
4039      IF (nqtot.GE.3) THEN
4040      DO iq = 3, nqtot
4041      DO  k = 1, klev
4042      DO  i = 1, klon
4043         d_qx(i,k,iq) = ( tr_seri(i,k,iq-2) - qx(i,k,iq) ) / dtime
4044      ENDDO
4045      ENDDO
4046      ENDDO
4047      ENDIF
4048!c
4049!IM rajout diagnostiques bilan KP pour analyse MJO par Jun-Ichi Yano
4050!IM global posePB#include "write_bilKP_ins.h"
4051!IM global posePB#include "write_bilKP_ave.h"
4052!c
4053
4054!c Sauvegarder les valeurs de t et q a la fin de la physique:
4055!c
4056      DO k = 1, klev
4057      DO i = 1, klon
4058         u_ancien(i,k) = u_seri(i,k)
4059         v_ancien(i,k) = v_seri(i,k)
4060         t_ancien(i,k) = t_seri(i,k)
4061         q_ancien(i,k) = q_seri(i,k)
4062      ENDDO
4063      ENDDO
4064
4065!!! RomP >>>
4066      IF (nqtot.GE.3) THEN
4067        DO iq = 3, nqtot
4068        DO k = 1, klev
4069        DO i = 1, klon
4070           tr_ancien(i,k,iq-2) = tr_seri(i,k,iq-2)
4071        ENDDO
4072        ENDDO
4073        ENDDO
4074      ENDIF
4075!!! RomP <<<
4076!==========================================================================
4077! Sorties des tendances pour un point particulier
4078! a utiliser en 1D, avec igout=1 ou en 3D sur un point particulier
4079! pour le debug
4080! La valeur de igout est attribuee plus haut dans le programme
4081!==========================================================================
4082
4083      if (prt_level.ge.1) then
4084      write(lunout,*) 'FIN DE PHYSIQ !!!!!!!!!!!!!!!!!!!!'
4085      write(lunout,*)                                                                &
4086       & 'nlon,klev,nqtot,debut,lafin,jD_cur, jH_cur, pdtphys pct tlos'
4087      write(lunout,*)                                                                &
4088       &  nlon,klev,nqtot,debut,lafin, jD_cur, jH_cur ,pdtphys,                      &
4089       &  pctsrf(igout,is_ter), pctsrf(igout,is_lic),pctsrf(igout,is_oce),           &
4090       &  pctsrf(igout,is_sic)
4091      write(lunout,*) 'd_t_dyn,d_t_con,d_t_lsc,d_t_ajsb,d_t_ajs,d_t_eva'
4092      do k=1,klev
4093         write(lunout,*) d_t_dyn(igout,k),d_t_con(igout,k),                          &
4094       &   d_t_lsc(igout,k),d_t_ajsb(igout,k),d_t_ajs(igout,k),                      &
4095       &   d_t_eva(igout,k)
4096      enddo
4097      write(lunout,*) 'cool,heat'
4098      do k=1,klev
4099         write(lunout,*) cool(igout,k),heat(igout,k)
4100      enddo
4101
4102      write(lunout,*) 'd_t_oli,d_t_vdf,d_t_oro,d_t_lif,d_t_ec'
4103      do k=1,klev
4104         write(lunout,*) d_t_oli(igout,k),d_t_vdf(igout,k),                          &
4105       & d_t_oro(igout,k),d_t_lif(igout,k),d_t_ec(igout,k)
4106      enddo
4107
4108      write(lunout,*) 'd_ps ',d_ps(igout)
4109      write(lunout,*) 'd_u, d_v, d_t, d_qx1, d_qx2 '
4110      do k=1,klev,klon
4111         write(lunout,*) d_u(igout,k),d_v(igout,k),d_t(igout,k),                     &
4112       &  d_qx(igout,k,1),d_qx(igout,k,2)
4113      enddo
4114      endif
4115
4116!==========================================================================
4117
4118!c============================================================
4119!c   Calcul de la temperature potentielle
4120!c============================================================
4121      DO k = 1, klev
4122      DO i = 1, klon
4123!cJYG/IM theta en debut du pas de temps
4124!cJYG/IM       theta(i,k)=t(i,k)*(100000./pplay(i,k))**(RD/RCPD)
4125!cJYG/IM theta en fin de pas de temps de physique
4126        theta(i,k)=t_seri(i,k)*(100000./pplay(i,k))**(RD/RCPD)
4127!c thetal: 2 lignes suivantes a decommenter si vous avez les fichiers     MPL 20130625
4128!c fth_fonctions.F90 et parkind1.F90
4129!c sinon thetal=theta
4130!c       thetal(i,k)=fth_thetal(pplay(i,k),t_seri(i,k),q_seri(i,k),
4131!c    :         ql_seri(i,k))
4132        thetal(i,k)=theta(i,k)
4133      ENDDO
4134      ENDDO
4135!c
4136
4137!c 22.03.04 BEG
4138!c=============================================================
4139!c   Ecriture des sorties
4140!c=============================================================
4141#ifdef CPP_IOIPSL
4142 
4143!c Recupere des varibles calcule dans differents modules
4144!c pour ecriture dans histxxx.nc
4145
4146      ! Get some variables from module fonte_neige_mod
4147!L. Fita, LMD. November 2013
4148!! It is not working after removing starphy.nc and limit.nc?
4149      CALL fonte_neige_get_vars(pctsrf,                                              &
4150       &     zxfqcalving, zxfqfonte, zxffonte)
4151
4152
4153
4154!c=============================================================
4155! Separation entre thermiques et non thermiques dans les sorties
4156! de fisrtilp
4157!c=============================================================
4158
4159      if (iflag_thermals>=1) then
4160      d_t_lscth=0.
4161      d_t_lscst=0.
4162      d_q_lscth=0.
4163      d_q_lscst=0.
4164      do k=1,klev
4165         do i=1,klon
4166            if (ptconvth(i,k)) then
4167                d_t_lscth(i,k)=d_t_eva(i,k)+d_t_lsc(i,k)
4168                d_q_lscth(i,k)=d_q_eva(i,k)+d_q_lsc(i,k)
4169            else
4170                d_t_lscst(i,k)=d_t_eva(i,k)+d_t_lsc(i,k)
4171                d_q_lscst(i,k)=d_q_eva(i,k)+d_q_lsc(i,k)
4172            endif
4173         enddo
4174      enddo
4175
4176      do i=1,klon
4177      plul_st(i)=prfl(i,lmax_th(i)+1)+psfl(i,lmax_th(i)+1)
4178      plul_th(i)=prfl(i,1)+psfl(i,1)
4179      enddo
4180      endif
4181
4182      PRINT *,'  Lluis WRITING outputs! itap: ',itap,' itau_phy: ',itau_phy,         &
4183        ' itau_w: ',itau_w
4184      PRINT *,'  Lluis writting outputs qsol: ',qsol(llp),    &
4185        ' ftsol: ',ftsol(llp,:)
4186
4187#include "phys_output_write_new.h"
4188
4189
4190#ifdef histISCCP
4191#include "write_histISCCP.h"
4192#endif
4193
4194      PRINT *,'  Lluis WRITING histfiles!'
4195
4196#ifdef histNMC
4197#include "write_histhfNMC.h"
4198#include "write_histdayNMC.h"
4199#include "write_histmthNMC.h"
4200#endif
4201
4202#include "write_histday_seri.h"
4203
4204#include "write_paramLMDZ_phy.h"
4205
4206#endif
4207
4208!c 22.03.04 END
4209!c
4210!c====================================================================
4211!c Si c'est la fin, il faut conserver l'etat de redemarrage
4212!c====================================================================
4213!c
4214
4215!c        -----------------------------------------------------------------
4216!c        WSTATS: Saving statistics
4217!c        -----------------------------------------------------------------
4218!c        ("stats" stores and accumulates 8 key variables in file "stats.nc"
4219!c        which can later be used to make the statistic files of the run:
4220!c        "stats")          only possible in 3D runs !
4221
4222         
4223         IF (callstats) THEN
4224
4225           call wstats(klon,o_psol%name,"Surface pressure","Pa"                      &
4226       &                 ,2,paprs(:,1))
4227           call wstats(klon,o_tsol%name,"Surface temperature","K",                   &
4228       &                 2,zxtsol)
4229           zx_tmp_fi2d(:) = rain_fall(:) + snow_fall(:)
4230           call wstats(klon,o_precip%name,"Precip Totale liq+sol",                   &
4231       &                 "kg/(s*m2)",2,zx_tmp_fi2d)
4232           zx_tmp_fi2d(:) = rain_lsc(:) + snow_lsc(:)
4233           call wstats(klon,o_plul%name,"Large-scale Precip",                        &
4234       &                 "kg/(s*m2)",2,zx_tmp_fi2d)
4235           zx_tmp_fi2d(:) = rain_con(:) + snow_con(:)
4236           call wstats(klon,o_pluc%name,"Convective Precip",                         &
4237       &                 "kg/(s*m2)",2,zx_tmp_fi2d)
4238           call wstats(klon,o_sols%name,"Solar rad. at surf.",                       &
4239       &                 "W/m2",2,solsw)
4240           call wstats(klon,o_soll%name,"IR rad. at surf.",                          &
4241       &                 "W/m2",2,sollw)
4242          zx_tmp_fi2d(:) = topsw(:)-toplw(:)
4243          call wstats(klon,o_nettop%name,"Net dn radiatif flux at TOA",              &
4244       &                 "W/m2",2,zx_tmp_fi2d)
4245
4246
4247
4248           call wstats(klon,o_temp%name,"Air temperature","K",                       &
4249       &                 3,t_seri)
4250           call wstats(klon,o_vitu%name,"Zonal wind","m.s-1",                        &
4251       &                 3,u_seri)
4252           call wstats(klon,o_vitv%name,"Meridional wind",                           &
4253       &                "m.s-1",3,v_seri)
4254           call wstats(klon,o_vitw%name,"Vertical wind",                             &
4255       &                "m.s-1",3,omega)
4256           call wstats(klon,o_ovap%name,"Specific humidity", "kg/kg",                &
4257       &                 3,q_seri)
4258 
4259
4260
4261           IF(lafin) THEN
4262             write (*,*) "Writing stats..."
4263             call mkstats(ierr)
4264           ENDIF
4265
4266         ENDIF !if callstats
4267
4268      IF (lafin) THEN
4269         itau_phy = itau_phy + itap
4270         CALL phyredem ("restartphy.nc")
4271!         open(97,form="unformatted",file="finbin")
4272!         write(97) u_seri,v_seri,t_seri,q_seri
4273!         close(97)
4274!$OMP MASTER
4275         if (read_climoz >= 1) then
4276            if (is_mpi_root) then
4277               call nf95_close(ncid_climoz)
4278            end if
4279            deallocate(press_climoz) ! pointer
4280         end if
4281!$OMP END MASTER
4282      ENDIF
4283     
4284!      first=.false.
4285
4286! Lluis
4287  PRINT *,'  Lluis: ',klev,'  UBOUNDS: ',UBOUND(t_seri), UBOUND(u_seri),             &
4288    UBOUND(d_q_con), UBOUND(d_t_con)
4289  PRINT *,'  Lluis llp ',llp,' itap: ',itap,' zlev t_seri u_seri d_q_con d_t_con_____'
4290  DO i=1,klev
4291     PRINT *,i,t_seri(llp,i), u_seri(llp,i), d_q_con(llp,i), d_t_con(llp,i)
4292  END DO
4293
4294
4295      RETURN
4296      END SUBROUTINE physiq
4297
4298      FUNCTION qcheck(klon,klev,paprs,q,ql,aire)
4299      IMPLICIT none
4300!c
4301!c Calculer et imprimer l'eau totale. A utiliser pour verifier
4302!c la conservation de l'eau
4303!c
4304#include "YOMCST.h"
4305      INTEGER klon,klev
4306      REAL paprs(klon,klev+1), q(klon,klev), ql(klon,klev)
4307      REAL aire(klon)
4308      REAL qtotal, zx, qcheck
4309      INTEGER i, k
4310!c
4311      zx = 0.0
4312      DO i = 1, klon
4313         zx = zx + aire(i)
4314      ENDDO
4315      qtotal = 0.0
4316      DO k = 1, klev
4317      DO i = 1, klon
4318         qtotal = qtotal + (q(i,k)+ql(i,k)) * aire(i)                                &
4319       &                     *(paprs(i,k)-paprs(i,k+1))/RG
4320      ENDDO
4321      ENDDO
4322!c
4323      qcheck = qtotal/zx
4324!c
4325      RETURN
4326      END
4327
4328      SUBROUTINE gr_fi_ecrit(nfield,nlon,iim,jjmp1,fi,ecrit)
4329      IMPLICIT none
4330!c
4331!c Tranformer une variable de la grille physique a
4332!c la grille d'ecriture
4333!c
4334      INTEGER nfield,nlon,iim,jjmp1, jjm
4335      REAL fi(nlon,nfield), ecrit(iim*jjmp1,nfield)
4336!c
4337      INTEGER i, n, ig
4338!c
4339      jjm = jjmp1 - 1
4340      DO n = 1, nfield
4341         DO i=1,iim
4342            ecrit(i,n) = fi(1,n)
4343            ecrit(i+jjm*iim,n) = fi(nlon,n)
4344         ENDDO
4345         DO ig = 1, nlon - 2
4346           ecrit(iim+ig,n) = fi(1+ig,n)
4347         ENDDO
4348      ENDDO
4349      RETURN
4350      END SUBROUTINE gr_fi_ecrit
Note: See TracBrowser for help on using the repository browser.