source: LMDZ5/branches/LMDZ5_SPLA/libf/phylmd/physiq.F90 @ 2302

Last change on this file since 2302 was 2217, checked in by jescribano, 10 years ago

Bugs corrections. Included a correction/tunning factor for the Chimere-dust emissions, Constant of MB95 equal to 2.61 as in MB95. No spurious increase of u* before horizontal flux calculations in the dust emission scheme. Values of AG00 binding energies fixed as the original AG00 divided by 3 as is Sow et al 2011 ACPD.

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