source: LMDZ6/trunk/libf/phylmd/phys_state_var_mod.F90 @ 5342

Last change on this file since 5342 was 5282, checked in by abarral, 3 months ago

Turn iniprint.h clesphys.h into modules
Remove unused description.h

  • 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: 37.3 KB
RevLine 
[1403]1!
2! $Id: phys_state_var_mod.F90 5282 2024-10-28 12:11:48Z abarral $
3!
[909]4      MODULE phys_state_var_mod
5! Variables sauvegardees pour le startphy.nc
6!======================================================================
7!
8!
9!======================================================================
10! Declaration des variables
11      USE dimphy
[5084]12      USE netcdf, only: nf90_fill_real
[952]13      INTEGER, PARAMETER :: nlevSTD=17
[1352]14      INTEGER, PARAMETER :: nlevSTD8=8
15      INTEGER, PARAMETER :: nlevSTD3=3
[952]16      INTEGER, PARAMETER :: nout=3
17      INTEGER, PARAMETER :: napisccp=1
[3150]18      INTEGER, SAVE :: radpas  ! radiation is called every "radpas" step
19      INTEGER, SAVE :: cvpas   ! convection is called every "cvpas" step
[3435]20      INTEGER, SAVE :: cvpas_0 = 1 ! reference value for cvpas
[3150]21      INTEGER, SAVE :: wkpas   ! wake scheme is called every "wkpas" step
[2271]22      REAL, PARAMETER :: missing_val_nf90=nf90_fill_real
[1352]23!$OMP THREADPRIVATE(radpas)
[2707]24!$OMP THREADPRIVATE(cvpas)
[3150]25!$OMP THREADPRIVATE(cvpas_0)
[2730]26!$OMP THREADPRIVATE(wkpas)
[3435]27      REAL, SAVE :: phys_tstep=0, solaire_etat0
28!$OMP THREADPRIVATE(phys_tstep, solaire_etat0)
[967]29
[2399]30      REAL, ALLOCATABLE, SAVE :: pctsrf(:,:)
31!$OMP THREADPRIVATE(pctsrf)
[909]32      REAL, ALLOCATABLE, SAVE :: ftsol(:,:)
[967]33!$OMP THREADPRIVATE(ftsol)
[3888]34      REAL, ALLOCATABLE, SAVE :: beta_aridity(:,:)
35!$OMP THREADPRIVATE(beta_aridity)
[2243]36      REAL,ALLOCATABLE,SAVE :: qsol(:),fevap(:,:),z0m(:,:),z0h(:,:),agesno(:,:)
37!$OMP THREADPRIVATE(qsol,fevap,z0m,z0h,agesno)
[2952]38!FC drag des arbres
39      REAL, ALLOCATABLE, SAVE :: treedrg(:,:,:)
40!$OMP THREADPRIVATE(treedrg)
41
[967]42!      character(len=6), SAVE :: ocean
43!!!!!!$OMP THREADPRIVATE(ocean)
44!      logical, SAVE :: ok_veget
45!!!!!!$OMP THREADPRIVATE(ok_veget)
[909]46      REAL, ALLOCATABLE, SAVE :: falb1(:,:), falb2(:,:)
[967]47!$OMP THREADPRIVATE(falb1, falb2)
[2227]48
49!albedo SB >>>
50      REAL, ALLOCATABLE, SAVE :: falb_dif(:,:,:), falb_dir(:,:,:)
[3756]51      REAL, ALLOCATABLE, SAVE :: chl_con(:)
[2227]52!$OMP THREADPRIVATE(falb_dir,falb_dif,chl_con)
53!albedo SB <<<
54
55
[4523]56      REAL, ALLOCATABLE, SAVE :: rain_fall(:), snow_fall(:), bs_fall(:)
57!$OMP THREADPRIVATE( rain_fall, snow_fall, bs_fall)
[3756]58      REAL, ALLOCATABLE, SAVE :: solsw(:), solswfdiff(:), sollw(:)
59!$OMP THREADPRIVATE(solsw, solswfdiff, sollw)
[909]60      REAL, ALLOCATABLE, SAVE :: radsol(:)
[967]61!$OMP THREADPRIVATE(radsol)
[2366]62      REAL, ALLOCATABLE, SAVE :: swradcorr(:)
63!$OMP THREADPRIVATE(swradcorr)
[4088]64#ifdef ISO
65      REAL,ALLOCATABLE,SAVE :: xtsol(:,:),fxtevap(:,:,:)
66!$OMP THREADPRIVATE(xtsol,fxtevap)
67      REAL, ALLOCATABLE, SAVE :: xtrain_fall(:,:), xtsnow_fall(:,:)
68!$OMP THREADPRIVATE(xtrain_fall,xtsnow_fall)
69#endif
[967]70
[909]71!clesphy0 param physiq
72!
73! Parametres de l'Orographie a l'Echelle Sous-Maille (OESM):
74!
75      REAL, ALLOCATABLE, SAVE :: zmea(:), zstd(:), zsig(:), zgam(:)
[967]76!$OMP THREADPRIVATE(zmea, zstd, zsig, zgam)
[909]77      REAL, ALLOCATABLE, SAVE :: zthe(:), zpic(:), zval(:)
[967]78!$OMP THREADPRIVATE(zthe, zpic, zval)
[909]79!     REAL tabcntr0(100)
80      REAL, ALLOCATABLE, SAVE :: rugoro(:)
[967]81!$OMP THREADPRIVATE(rugoro)
[909]82      REAL, ALLOCATABLE, SAVE :: t_ancien(:,:), q_ancien(:,:)
[967]83!$OMP THREADPRIVATE(t_ancien, q_ancien)
[4523]84      REAL, ALLOCATABLE, SAVE :: ql_ancien(:,:), qs_ancien(:,:), qbs_ancien(:,:)
85!$OMP THREADPRIVATE(ql_ancien, qs_ancien, qbs_ancien)
86      REAL, ALLOCATABLE, SAVE :: prw_ancien(:), prlw_ancien(:), prsw_ancien(:), prbsw_ancien(:)
87!$OMP THREADPRIVATE(prw_ancien, prlw_ancien, prsw_ancien, prbsw_ancien)
[4088]88#ifdef ISO
[4984]89      REAL, ALLOCATABLE, SAVE :: xt_ancien(:,:,:),xtl_ancien(:,:,:),xts_ancien(:,:,:), &
90              xtbs_ancien(:,:,:)
91!$OMP THREADPRIVATE(xt_ancien,xtl_ancien,xts_ancien,xtbs_ancien)
[4088]92#endif
[1054]93      REAL, ALLOCATABLE, SAVE :: u_ancien(:,:), v_ancien(:,:)
94!$OMP THREADPRIVATE(u_ancien, v_ancien)
[5204]95      REAL, ALLOCATABLE, SAVE :: cf_ancien(:,:), rvc_ancien(:,:)
96!$OMP THREADPRIVATE(cf_ancien, rvc_ancien)
[1742]97!!! RomP >>>
98      REAL, ALLOCATABLE, SAVE :: tr_ancien(:,:,:)
99!$OMP THREADPRIVATE(tr_ancien)
100!!! RomP <<<
[909]101      LOGICAL, SAVE :: ancien_ok
[967]102!$OMP THREADPRIVATE(ancien_ok)
[909]103      REAL, ALLOCATABLE, SAVE :: clwcon(:,:),rnebcon(:,:)
[967]104!$OMP THREADPRIVATE(clwcon,rnebcon)
[4613]105      REAL, ALLOCATABLE, SAVE :: qtc_cv(:,:),sigt_cv(:,:),detrain_cv(:,:),fm_cv(:,:)
106!$OMP THREADPRIVATE(qtc_cv,sigt_cv,detrain_cv,fm_cv)
[909]107      REAL, ALLOCATABLE, SAVE :: ratqs(:,:)
[967]108!$OMP THREADPRIVATE(ratqs)
[909]109      REAL, ALLOCATABLE, SAVE :: pbl_tke(:,:,:) ! turb kinetic energy
[1761]110      REAL, ALLOCATABLE, SAVE :: coefh(:,:,:) ! Kz enthalpie
111      REAL, ALLOCATABLE, SAVE :: coefm(:,:,:) ! Kz momentum
112!$OMP THREADPRIVATE(pbl_tke, coefh,coefm)
[927]113      REAL, ALLOCATABLE, SAVE :: zmax0(:), f0(:) !
[967]114!$OMP THREADPRIVATE(zmax0,f0)
[1827]115      REAL, ALLOCATABLE, SAVE :: sig1(:,:), w01(:,:)
116!$OMP THREADPRIVATE(sig1,w01)
[942]117      REAL, ALLOCATABLE, SAVE :: entr_therm(:,:), fm_therm(:,:)
[967]118!$OMP THREADPRIVATE(entr_therm,fm_therm)
[952]119      REAL, ALLOCATABLE, SAVE :: detr_therm(:,:)
[967]120!$OMP THREADPRIVATE(detr_therm)
[952]121!IM 150408
122!     pour phsystoke avec thermiques
123      REAL,ALLOCATABLE,SAVE :: clwcon0th(:,:),rnebcon0th(:,:)
[967]124!$OMP THREADPRIVATE(clwcon0th,rnebcon0th)
[952]125! radiation outputs
[3082]126      REAL,ALLOCATABLE,SAVE :: swdnc0(:,:), swdn0(:,:), swdn(:,:)
127!$OMP THREADPRIVATE(swdnc0,swdn0,swdn)
128      REAL,ALLOCATABLE,SAVE :: swupc0(:,:), swup0(:,:), swup(:,:)
129!$OMP THREADPRIVATE(swupc0, swup0,swup)
[952]130      REAL,ALLOCATABLE,SAVE :: SWdn200clr(:), SWdn200(:)
[967]131!$OMP THREADPRIVATE(SWdn200clr,SWdn200)
[952]132      REAL,ALLOCATABLE,SAVE :: SWup200clr(:), SWup200(:)
[967]133!$OMP THREADPRIVATE(SWup200clr,SWup200)
[3106]134      REAL,ALLOCATABLE,SAVE :: lwdnc0(:,:), lwdn0(:,:), lwdn(:,:)
135!$OMP THREADPRIVATE(lwdnc0,lwdn0,lwdn)
136      REAL,ALLOCATABLE,SAVE :: lwupc0(:,:), lwup0(:,:), lwup(:,:)
137!$OMP THREADPRIVATE(lwupc0,lwup0,lwup)
[952]138      REAL,ALLOCATABLE,SAVE :: LWdn200clr(:), LWdn200(:)
[967]139!$OMP THREADPRIVATE(LWdn200clr,LWdn200)
[952]140      REAL,ALLOCATABLE,SAVE :: LWup200clr(:), LWup200(:)
[967]141!$OMP THREADPRIVATE(LWup200clr,LWup200)
[952]142      REAL,ALLOCATABLE,SAVE :: LWdnTOA(:), LWdnTOAclr(:)
[967]143!$OMP THREADPRIVATE(LWdnTOA,LWdnTOAclr)
[952]144! pressure level
145      REAL,ALLOCATABLE,SAVE :: tsumSTD(:,:,:)
[967]146!$OMP THREADPRIVATE(tsumSTD)
[952]147      REAL,ALLOCATABLE,SAVE :: usumSTD(:,:,:), vsumSTD(:,:,:)
[967]148!$OMP THREADPRIVATE(usumSTD,vsumSTD)
[952]149      REAL,ALLOCATABLE,SAVE :: wsumSTD(:,:,:), phisumSTD(:,:,:)
[967]150!$OMP THREADPRIVATE(wsumSTD,phisumSTD)
[952]151      REAL,ALLOCATABLE,SAVE :: qsumSTD(:,:,:), rhsumSTD(:,:,:)
[967]152!$OMP THREADPRIVATE(qsumSTD,rhsumSTD)
[952]153      REAL,ALLOCATABLE,SAVE :: tnondef(:,:,:)
[967]154!$OMP THREADPRIVATE(tnondef)
[952]155      REAL,ALLOCATABLE,SAVE :: uvsumSTD(:,:,:)
[967]156!$OMP THREADPRIVATE(uvsumSTD)
[952]157      REAL,ALLOCATABLE,SAVE :: vqsumSTD(:,:,:)
[967]158!$OMP THREADPRIVATE(vqsumSTD)
[952]159      REAL,ALLOCATABLE,SAVE :: vTsumSTD(:,:,:)
[967]160!$OMP THREADPRIVATE(vTsumSTD)
[952]161      REAL,ALLOCATABLE,SAVE :: wqsumSTD(:,:,:)
[967]162!$OMP THREADPRIVATE(wqsumSTD)
[952]163      REAL,ALLOCATABLE,SAVE :: vphisumSTD(:,:,:)
[967]164!$OMP THREADPRIVATE(vphisumSTD)
[952]165      REAL,ALLOCATABLE,SAVE :: wTsumSTD(:,:,:)
[967]166!$OMP THREADPRIVATE(wTsumSTD)
[952]167      REAL,ALLOCATABLE,SAVE :: u2sumSTD(:,:,:)
[967]168!$OMP THREADPRIVATE(u2sumSTD)
[952]169      REAL,ALLOCATABLE,SAVE :: v2sumSTD(:,:,:)
[967]170!$OMP THREADPRIVATE(v2sumSTD)
[952]171      REAL,ALLOCATABLE,SAVE :: T2sumSTD(:,:,:)
[967]172!$OMP THREADPRIVATE(T2sumSTD)
[1398]173      REAL,ALLOCATABLE,SAVE :: O3sumSTD(:,:,:), O3daysumSTD(:,:,:)
174!$OMP THREADPRIVATE(O3sumSTD,O3daysumSTD)
[1352]175!IM begin
176      REAL,ALLOCATABLE,SAVE :: wlevSTD(:,:), ulevSTD(:,:), vlevSTD(:,:)
[1362]177!$OMP THREADPRIVATE(wlevSTD,ulevSTD,vlevSTD)
[1352]178      REAL,ALLOCATABLE,SAVE :: tlevSTD(:,:), qlevSTD(:,:), rhlevSTD(:,:)
[1362]179!$OMP THREADPRIVATE(tlevSTD,qlevSTD,rhlevSTD)
[1352]180      REAL,ALLOCATABLE,SAVE :: philevSTD(:,:)
[1362]181!$OMP THREADPRIVATE(philevSTD)
[1352]182      REAL,ALLOCATABLE,SAVE :: uvSTD(:,:)
[1362]183!$OMP THREADPRIVATE(uvSTD)
[1352]184      REAL,ALLOCATABLE,SAVE :: vqSTD(:,:)
[1362]185!$OMP THREADPRIVATE(vqSTD)
[1352]186      REAL,ALLOCATABLE,SAVE :: vTSTD(:,:)
[1362]187!$OMP THREADPRIVATE(vTSTD)
[1352]188      REAL,ALLOCATABLE,SAVE :: wqSTD(:,:)
[1362]189!$OMP THREADPRIVATE(wqSTD)
[1352]190      REAL,ALLOCATABLE,SAVE :: vphiSTD(:,:)
[1362]191!$OMP THREADPRIVATE(vphiSTD)
[1352]192      REAL,ALLOCATABLE,SAVE :: wTSTD(:,:)
[1362]193!$OMP THREADPRIVATE(wTSTD)
[1352]194      REAL,ALLOCATABLE,SAVE :: u2STD(:,:)
[1362]195!$OMP THREADPRIVATE(u2STD)
[1352]196      REAL,ALLOCATABLE,SAVE :: v2STD(:,:)
[1362]197!$OMP THREADPRIVATE(v2STD)
[1352]198      REAL,ALLOCATABLE,SAVE :: T2STD(:,:)
[1362]199!$OMP THREADPRIVATE(T2STD)
[1398]200      REAL,ALLOCATABLE,SAVE :: O3STD(:,:), O3daySTD(:,:)
201!$OMP THREADPRIVATE(O3STD,O3daySTD)
[1352]202!IM end
[952]203      INTEGER,ALLOCATABLE,SAVE :: seed_old(:,:)
[967]204!$OMP THREADPRIVATE(seed_old)
[952]205      REAL,ALLOCATABLE,SAVE :: zuthe(:),zvthe(:)
[967]206!$OMP THREADPRIVATE(zuthe,zvthe)
[952]207      REAL,ALLOCATABLE,SAVE :: alb_neig(:)
[967]208!$OMP THREADPRIVATE(alb_neig)
[952]209!cloud base mass flux
[1398]210      REAL,ALLOCATABLE,SAVE :: ema_cbmf(:)
211!$OMP THREADPRIVATE(ema_cbmf)
[952]212!cloud base pressure & cloud top pressure
213      REAL,ALLOCATABLE,SAVE :: ema_pcb(:), ema_pct(:)
[967]214!$OMP THREADPRIVATE(ema_pcb,ema_pct)
[3496]215      REAL,ALLOCATABLE,SAVE :: Mipsh(:,:)     ! mass flux shed from  adiab. ascents
216!$OMP THREADPRIVATE(Mipsh)
217      REAL,ALLOCATABLE,SAVE :: Ma(:,:)       ! undilute upward mass flux
[967]218!$OMP THREADPRIVATE(Ma)
[952]219      REAL,ALLOCATABLE,SAVE :: qcondc(:,:)    ! in-cld water content from convect
[967]220!$OMP THREADPRIVATE(qcondc)
[952]221      REAL,ALLOCATABLE,SAVE :: wd(:) ! sb
[967]222!$OMP THREADPRIVATE(wd)
[952]223      REAL,ALLOCATABLE,SAVE :: sigd(:)
[967]224!$OMP THREADPRIVATE(sigd)
[952]225!
226      REAL,ALLOCATABLE,SAVE :: cin(:)
[967]227!$OMP THREADPRIVATE(cin)
[2635]228! ftd : convective heating due to unsaturated downdraughts
[952]229      REAL,ALLOCATABLE,SAVE :: ftd(:,:)
[967]230!$OMP THREADPRIVATE(ftd)
[2635]231! fqd : convective moistening due to unsaturated downdraughts
[4613]232      REAL,ALLOCATABLE,SAVE :: fqd(:,:),fqcomp(:,:)     
233!$OMP THREADPRIVATE(fqd,fqcomp)
[4088]234#ifdef ISO
235      REAL, ALLOCATABLE, SAVE :: fxtd(:,:,:)
236!$OMP THREADPRIVATE(fxtd)
237#endif
[952]238!34EK
239! -- Variables de controle de ALE et ALP
240!ALE : Energie disponible pour soulevement : utilisee par la
241!      convection d'Emanuel pour le declenchement et la regulation
242      REAL,ALLOCATABLE,SAVE :: ALE(:)
[967]243!$OMP THREADPRIVATE(ALE)
[952]244!ALP : Puissance  disponible pour soulevement
245      REAL,ALLOCATABLE,SAVE :: ALP(:)
[967]246!$OMP THREADPRIVATE(ALP)
[952]247!
248! nouvelles variables pour le couplage convection-couche limite
249      REAL,ALLOCATABLE,SAVE :: Ale_bl(:)
[967]250!$OMP THREADPRIVATE(Ale_bl)
[952]251      REAL,ALLOCATABLE,SAVE :: Alp_bl(:)
[967]252!$OMP THREADPRIVATE(Alp_bl)
[952]253      INTEGER,ALLOCATABLE,SAVE :: lalim_conv(:)
[967]254!$OMP THREADPRIVATE(lalim_conv)
[952]255      REAL,ALLOCATABLE,SAVE :: wght_th(:,:)
[967]256!$OMP THREADPRIVATE(wght_th)
[3080]257      REAL,ALLOCATABLE,SAVE    :: ale_wake(:)
258!$OMP THREADPRIVATE(ale_wake)
259      REAL,ALLOCATABLE,SAVE    :: ale_bl_stat(:)
260!$OMP THREADPRIVATE(ale_bl_stat)
[952]261!
262! variables de la wake
263! wake_deltat : ecart de temperature avec la zone non perturbee
264! wake_deltaq : ecart d'humidite avec la zone non perturbee
[2635]265! wake_s      : fraction surfacique occupee par la poche froide
[4744]266! awake_s     : surface fraction covered by active wakes
267! wake_dens   : number of wakes per unit area
[3208]268! awake_dens  : number of active wakes per unit area
[3956]269! cv_gen      : birth rate of cumulonimbus per unit area.
[2635]270! wake_occ    : occurence of wakes (= 1 if wakes occur, =0 otherwise)
[952]271! wake_Cstar  : vitesse d'etalement de la poche
[1403]272! wake_pe     : wake potential energy - WAPE
[952]273! wake_fip    : Gust Front Impinging power - ALP
274      REAL,ALLOCATABLE,SAVE :: wake_deltat(:,:)
[967]275!$OMP THREADPRIVATE(wake_deltat)
[952]276      REAL,ALLOCATABLE,SAVE :: wake_deltaq(:,:)
[967]277!$OMP THREADPRIVATE(wake_deltaq)
[4088]278#ifdef ISO
279      REAL, ALLOCATABLE, SAVE :: wake_deltaxt(:,:,:)
280!$OMP THREADPRIVATE(wake_deltaxt)
281#endif
[4744]282      REAL,ALLOCATABLE,SAVE :: wake_s(:), awake_s(:)
283!$OMP THREADPRIVATE(wake_s, awake_s)
284      REAL,ALLOCATABLE,SAVE :: wake_dens(:), awake_dens(:)
285!$OMP THREADPRIVATE(wake_dens, awake_dens)
[3956]286      REAL,ALLOCATABLE,SAVE :: cv_gen(:)
287!$OMP THREADPRIVATE(cv_gen)
[952]288      REAL,ALLOCATABLE,SAVE :: wake_Cstar(:)
[967]289!$OMP THREADPRIVATE(wake_Cstar)
[1403]290      REAL,ALLOCATABLE,SAVE :: wake_pe(:)
291!$OMP THREADPRIVATE(wake_pe)
[952]292      REAL,ALLOCATABLE,SAVE :: wake_fip(:)
[967]293!$OMP THREADPRIVATE(wake_fip)
[952]294!
[2159]295!jyg<
296! variables related to the spitting of the PBL between wake and
297! off-wake regions.
298! wake_delta_pbl_TKE : difference TKE_w - TKE_x
299      REAL,ALLOCATABLE,SAVE :: wake_delta_pbl_TKE(:,:,:)
300!$OMP THREADPRIVATE(wake_delta_pbl_TKE)
[3888]301!nrlmd<
302      REAL, ALLOCATABLE, SAVE :: delta_tsurf(:,:) ! Surface temperature difference inside-outside cold pool
303!$OMP THREADPRIVATE(delta_tsurf)
304!>nrlmd
[2159]305!>jyg
306!
[952]307! pfrac_impa : Produits des coefs lessivage impaction
308! pfrac_nucl : Produits des coefs lessivage nucleation
309! pfrac_1nucl: Produits des coefs lessi nucl (alpha = 1)
310      REAL,ALLOCATABLE,SAVE :: pfrac_impa(:,:), pfrac_nucl(:,:)
[967]311!$OMP THREADPRIVATE(pfrac_impa,pfrac_nucl)
[952]312      REAL,ALLOCATABLE,SAVE :: pfrac_1nucl(:,:)
[967]313!$OMP THREADPRIVATE(pfrac_1nucl)
[952]314!
315      REAL,ALLOCATABLE,SAVE :: total_rain(:), nday_rain(:) 
[967]316!$OMP THREADPRIVATE(total_rain,nday_rain)
[4556]317      REAL,ALLOCATABLE,SAVE :: ndayrain_mth(:)
318!$OMP THREADPRIVATE(ndayrain_mth)
[3435]319      REAL,ALLOCATABLE,SAVE :: paire_ter(:)
320!$OMP THREADPRIVATE(paire_ter)
[952]321! albsol1: albedo du sol total pour SW visible
322! albsol2: albedo du sol total pour SW proche IR
323      REAL,ALLOCATABLE,SAVE :: albsol1(:), albsol2(:)
[967]324!$OMP THREADPRIVATE(albsol1,albsol2)
[1279]325
[2227]326!albedo SB >>>
327      REAL,ALLOCATABLE,SAVE :: albsol_dif(:,:),albsol_dir(:,:)
328!$OMP THREADPRIVATE(albsol_dif,albsol_dir)
329!albedo SB <<<
330
331
[1279]332      REAL, ALLOCATABLE, SAVE:: wo(:, :, :)
333      ! column-density of ozone in a layer, in kilo-Dobsons
334      ! Third dimension has size 1 or 2.
335      ! "wo(:, :, 1)" is for the average day-night field,
336      ! "wo(:, :, 2)" is for daylight time.
337      !$OMP THREADPRIVATE(wo)
338
[952]339! heat : chauffage solaire
340! heat0: chauffage solaire ciel clair
341! cool : refroidissement infrarouge
342! cool0 : refroidissement infrarouge ciel clair
343! sollwdown : downward LW flux at surface
344! sollwdownclr : downward CS LW flux at surface
345! toplwdown : downward CS LW flux at TOA
346! toplwdownclr : downward CS LW flux at TOA
[3479]347! heat_volc : chauffage solaire du au volcanisme
348! cool_volc : refroidissement infrarouge du au volcanisme
[952]349      REAL,ALLOCATABLE,SAVE :: clwcon0(:,:),rnebcon0(:,:)
[967]350!$OMP THREADPRIVATE(clwcon0,rnebcon0)
[952]351      REAL,ALLOCATABLE,SAVE :: heat(:,:)   
[967]352!$OMP THREADPRIVATE(heat)
[952]353      REAL,ALLOCATABLE,SAVE :: heat0(:,:)
[967]354!$OMP THREADPRIVATE(heat0)
[952]355      REAL,ALLOCATABLE,SAVE :: cool(:,:)
[967]356!$OMP THREADPRIVATE(cool)
[952]357      REAL,ALLOCATABLE,SAVE :: cool0(:,:)
[967]358!$OMP THREADPRIVATE(cool0)
[3479]359      REAL,ALLOCATABLE,SAVE :: heat_volc(:,:)   
360!$OMP THREADPRIVATE(heat_volc)
361      REAL,ALLOCATABLE,SAVE :: cool_volc(:,:)
362!$OMP THREADPRIVATE(cool_volc)
[952]363      REAL,ALLOCATABLE,SAVE :: topsw(:), toplw(:)
[967]364!$OMP THREADPRIVATE(topsw,toplw)
[952]365      REAL,ALLOCATABLE,SAVE :: sollwdown(:)
[967]366!$OMP THREADPRIVATE(sollwdown)
[2240]367      REAL,ALLOCATABLE,SAVE :: gustiness(:)
368!$OMP THREADPRIVATE(gustiness)
[952]369      REAL,ALLOCATABLE,SAVE :: sollwdownclr(:)
[967]370!$OMP THREADPRIVATE(sollwdownclr)
[952]371      REAL,ALLOCATABLE,SAVE :: toplwdown(:)
[967]372!$OMP THREADPRIVATE(toplwdown)
[952]373      REAL,ALLOCATABLE,SAVE :: toplwdownclr(:)
[967]374!$OMP THREADPRIVATE(toplwdownclr)
[952]375      REAL,ALLOCATABLE,SAVE :: topsw0(:),toplw0(:),solsw0(:),sollw0(:)
[967]376!$OMP THREADPRIVATE(topsw0,toplw0,solsw0,sollw0)
[952]377      REAL,ALLOCATABLE,SAVE :: albpla(:)
[967]378!$OMP THREADPRIVATE(albpla)
[1539]379
380!IM ajout variables CFMIP2/CMIP5
381      REAL,ALLOCATABLE,SAVE :: heatp(:,:), coolp(:,:)
382!$OMP THREADPRIVATE(heatp, coolp)
383      REAL,ALLOCATABLE,SAVE :: heat0p(:,:), cool0p(:,:)
384!$OMP THREADPRIVATE(heat0p, cool0p)
385      REAL,ALLOCATABLE,SAVE :: radsolp(:), topswp(:), toplwp(:)
386!$OMP THREADPRIVATE(radsolp, topswp, toplwp)
387      REAL,ALLOCATABLE,SAVE :: albplap(:)
388!$OMP THREADPRIVATE(albplap)
[3756]389      REAL,ALLOCATABLE,SAVE :: solswp(:), solswfdiffp(:), sollwp(:)
390!$OMP THREADPRIVATE(solswp, solswfdiffp, sollwp)
[1539]391      REAL,ALLOCATABLE,SAVE :: sollwdownp(:)
392!$OMP THREADPRIVATE(sollwdownp)
393      REAL,ALLOCATABLE,SAVE :: topsw0p(:),toplw0p(:)
394      REAL,ALLOCATABLE,SAVE :: solsw0p(:),sollw0p(:)
395!$OMP THREADPRIVATE(topsw0p,toplw0p,solsw0p,sollw0p)
[3106]396      REAL,ALLOCATABLE,SAVE :: lwdnc0p(:,:), lwdn0p(:,:), lwdnp(:,:)
397      REAL,ALLOCATABLE,SAVE :: lwupc0p(:,:), lwup0p(:,:), lwupp(:,:)
398!$OMP THREADPRIVATE(lwdnc0p, lwdn0p, lwdnp, lwupc0p, lwup0p, lwupp)
[3082]399      REAL,ALLOCATABLE,SAVE :: swdnc0p(:,:), swdn0p(:,:), swdnp(:,:)
400      REAL,ALLOCATABLE,SAVE :: swupc0p(:,:), swup0p(:,:), swupp(:,:)
401!$OMP THREADPRIVATE(swdnc0p, swdn0p, swdnp, swupc0p, swup0p, swupp)
[1539]402
[4677]403!AI ajout variables double appel Ecrad (3Deffect)
404      REAL,ALLOCATABLE,SAVE :: heat_s2(:,:), cool_s2(:,:)
405!$OMP THREADPRIVATE(heat_s2, cool_s2)
406      REAL,ALLOCATABLE,SAVE :: heat0_s2(:,:), cool0_s2(:,:)
407!$OMP THREADPRIVATE(heat0_s2, cool0_s2)
408      REAL,ALLOCATABLE,SAVE :: radsol_s2(:), topsw_s2(:), toplw_s2(:)
409!$OMP THREADPRIVATE(radsol_s2, topsw_s2, toplw_s2)
410      REAL,ALLOCATABLE,SAVE :: albpla_s2(:)
411!$OMP THREADPRIVATE(albpla_s2)
412      REAL,ALLOCATABLE,SAVE :: solsw_s2(:), solswfdiff_s2(:), sollw_s2(:)
413!$OMP THREADPRIVATE(solsw_s2, solswfdiff_s2, sollw_s2)
[4773]414      REAL,ALLOCATABLE,SAVE :: sollwdown_s2(:), sollwdownclr_s2(:)
415!$OMP THREADPRIVATE(sollwdown_s2, sollwdownclr_s2)
[4677]416      REAL,ALLOCATABLE,SAVE :: topsw0_s2(:),toplw0_s2(:)
417      REAL,ALLOCATABLE,SAVE :: solsw0_s2(:),sollw0_s2(:)
418!$OMP THREADPRIVATE(topsw0_s2,toplw0_s2,solsw0_s2,sollw0_s2)
419      REAL,ALLOCATABLE,SAVE :: lwdnc0_s2(:,:), lwdn0_s2(:,:), lwdn_s2(:,:)
420      REAL,ALLOCATABLE,SAVE :: lwupc0_s2(:,:), lwup0_s2(:,:), lwup_s2(:,:)
421!$OMP THREADPRIVATE(lwdnc0_s2,lwdn0_s2,lwdn_s2,lwupc0_s2,lwup0_s2,lwup_s2)       
422      REAL,ALLOCATABLE,SAVE :: swdnc0_s2(:,:), swdn0_s2(:,:), swdn_s2(:,:)
423      REAL,ALLOCATABLE,SAVE :: swupc0_s2(:,:), swup0_s2(:,:), swup_s2(:,:)
424!$OMP THREADPRIVATE(swdnc0_s2, swdn0_s2, swdn_s2, swupc0_s2, swup0_s2, swup_s2)
425
[952]426! pbase : cloud base pressure
427! bbase : cloud base buoyancy
428      REAL,ALLOCATABLE,SAVE :: cape(:)
[967]429!$OMP THREADPRIVATE(cape)
[952]430      REAL,ALLOCATABLE,SAVE :: pbase(:)
[967]431!$OMP THREADPRIVATE(pbase)
[952]432      REAL,ALLOCATABLE,SAVE :: bbase(:)
[967]433!$OMP THREADPRIVATE(bbase)
[952]434!
435      REAL,SAVE,ALLOCATABLE :: zqasc(:,:)
[967]436!$OMP THREADPRIVATE( zqasc)
[952]437      INTEGER,ALLOCATABLE,SAVE :: ibas_con(:), itop_con(:)
[967]438!$OMP THREADPRIVATE(ibas_con,itop_con)
[952]439      REAL,SAVE,ALLOCATABLE :: rain_con(:)
[967]440!$OMP THREADPRIVATE(rain_con)
[952]441      REAL,SAVE,ALLOCATABLE :: snow_con(:)
[967]442!$OMP THREADPRIVATE(snow_con)
[952]443!
[4088]444#ifdef ISO
445      REAL,SAVE,ALLOCATABLE :: xtrain_con(:,:)
446!$OMP THREADPRIVATE(xtrain_con)
447      REAL,SAVE,ALLOCATABLE :: xtsnow_con(:,:)
448!$OMP THREADPRIVATE(xtsnow_con)
449#endif
[952]450      REAL,SAVE,ALLOCATABLE :: rlonPOS(:)
[967]451!$OMP THREADPRIVATE(rlonPOS)
[952]452      REAL,SAVE,ALLOCATABLE :: newsst(:)
[967]453!$OMP THREADPRIVATE(newsst)
[1813]454      REAL,SAVE,ALLOCATABLE :: ustar(:,:),u10m(:,:), v10m(:,:),wstar(:,:)
455!$OMP THREADPRIVATE(ustar,u10m,v10m,wstar)
[952]456!
457! ok_ade=T -ADE=topswad-topsw
458! ok_aie=T ->
459!       ok_ade=T -AIE=topswai-topswad
[1279]460!       ok_ade=F -AIE=topswai-topsw
[952]461!
462!topswad, solswad : Aerosol direct effect
463      REAL,SAVE,ALLOCATABLE :: topswad(:), solswad(:)
[967]464!$OMP THREADPRIVATE(topswad,solswad)
[952]465!topswai, solswai : Aerosol indirect effect
466      REAL,SAVE,ALLOCATABLE :: topswai(:), solswai(:)
[967]467!$OMP THREADPRIVATE(topswai,solswai)
[959]468
[1279]469      REAL,SAVE,ALLOCATABLE :: tau_aero(:,:,:,:), piz_aero(:,:,:,:), cg_aero(:,:,:,:)
470!$OMP THREADPRIVATE(tau_aero, piz_aero, cg_aero)
[2146]471      REAL,SAVE,ALLOCATABLE :: tau_aero_sw_rrtm(:,:,:,:), piz_aero_sw_rrtm(:,:,:,:), cg_aero_sw_rrtm(:,:,:,:)
472!$OMP THREADPRIVATE(tau_aero_sw_rrtm, piz_aero_sw_rrtm, cg_aero_sw_rrtm)
473      REAL,SAVE,ALLOCATABLE :: tau_aero_lw_rrtm(:,:,:,:), piz_aero_lw_rrtm(:,:,:,:), cg_aero_lw_rrtm(:,:,:,:)
474!$OMP THREADPRIVATE(tau_aero_lw_rrtm, piz_aero_lw_rrtm, cg_aero_lw_rrtm)
[952]475      REAL,SAVE,ALLOCATABLE :: ccm(:,:,:)
[967]476!$OMP THREADPRIVATE(ccm)
[952]477
[1638]478      REAL,SAVE,ALLOCATABLE :: ale_bl_trig(:)
479!$OMP THREADPRIVATE(ale_bl_trig)
480
[5208]481      REAL,SAVE,ALLOCATABLE :: ratqs_inter_(:,:),sigma_qtherm(:,:)
482!$OMP THREADPRIVATE(ratqs_inter_,sigma_qtherm)
[3856]483
[4088]484#ifdef ISO
485#ifdef ISOTRAC
486      INTEGER,SAVE,ALLOCATABLE :: bassin_map(:)
487!$OMP THREADPRIVATE(bassin_map)
488      INTEGER,SAVE,ALLOCATABLE :: boite_map(:,:)
489!$OMP THREADPRIVATE(boite_map)
490#endif   
491#endif
[2333]492      REAL, ALLOCATABLE, SAVE:: du_gwd_rando(:, :), du_gwd_front(:, :)
493      !$OMP THREADPRIVATE(du_gwd_rando, du_gwd_front)
[1938]494      ! tendencies on wind due to gravity waves
495
[3435]496      LOGICAL,SAVE :: is_initialized=.FALSE.
497!$OMP THREADPRIVATE(is_initialized)   
498
[3815]499      ! Ocean-atmosphere interface:
[909]500
[3815]501      REAL, ALLOCATABLE, SAVE:: ds_ns(:) ! (klon)
502      ! "delta salinity near surface". Salinity variation in the
503      ! near-surface turbulent layer. That is subskin salinity minus
504      ! foundation salinity. In ppt.
505
506      REAL, ALLOCATABLE, SAVE:: dt_ns(:) ! (klon)
507      ! "delta temperature near surface". Temperature variation in the
508      ! near-surface turbulent layer. That is subskin temperature
509      ! minus foundation temperature. (Can be negative.) In K.
510     
511      REAL, ALLOCATABLE, SAVE:: delta_sst(:) ! (klon)
512      ! Ocean-air interface temperature minus bulk SST, in
513      ! K. Allocated and defined only if activate_ocean_skin >= 1.
514
515      REAL, ALLOCATABLE, SAVE:: delta_sal(:) ! (klon)
516      ! Ocean-air interface salinity minus bulk salinity, in ppt
517     
[4370]518      REAL, ALLOCATABLE, SAVE:: dter(:) ! (klon)
519      ! Temperature variation in the diffusive microlayer, that is
520      ! ocean-air interface temperature minus subskin temperature. In K.
[3815]521
[4370]522      REAL, SAVE, ALLOCATABLE:: dser(:) ! (klon)
523      ! Salinity variation in the diffusive microlayer, that is
524      ! ocean-air interface salinity minus subskin salinity. In ppt.
525
526      real, SAVE, ALLOCATABLE:: dt_ds(:) ! (klon)
527      ! (tks / tkt) * dTer, in K
528
529      !$OMP THREADPRIVATE(delta_sal, ds_ns, dt_ns, delta_sst, dter, dser, dt_ds)
530
[3815]531    CONTAINS
532
[909]533!======================================================================
[1279]534SUBROUTINE phys_state_var_init(read_climoz)
[1785]535USE dimphy
536USE aero_mod
[2320]537USE infotrac_phy, ONLY : nbtr
[4088]538#ifdef ISO
[4143]539USE infotrac_phy, ONLY : ntraciso=>ntiso,niso
[4088]540#endif
[5282]541USE clesphys_mod_h
[1785]542USE indice_sol_mod
[3815]543use config_ocean_skin_m, only: activate_ocean_skin
[4370]544use surface_data, only: type_ocean
[909]545IMPLICIT NONE
[1279]546
547integer, intent(in)::  read_climoz
548! read ozone climatology
549! Allowed values are 0, 1 and 2
550! 0: do not read an ozone climatology
551! 1: read a single ozone climatology that will be used day and night
552! 2: read two ozone climatologies, the average day and night
553! climatology and the daylight climatology
554
[3781]555
556      print*, 'is_initialized', is_initialized
[3435]557      IF (is_initialized) RETURN
558      is_initialized=.TRUE.
[952]559      ALLOCATE(pctsrf(klon,nbsrf))
560      ALLOCATE(ftsol(klon,nbsrf))
[3888]561      ALLOCATE(beta_aridity(klon,nbsrf))
[2243]562      ALLOCATE(qsol(klon),fevap(klon,nbsrf))
563      ALLOCATE(z0m(klon,nbsrf+1),z0h(klon,nbsrf+1),agesno(klon,nbsrf))
[2952]564!FC
565      ALLOCATE(treedrg(klon,klev,nbsrf))
[952]566      ALLOCATE(falb1(klon,nbsrf))
567      ALLOCATE(falb2(klon,nbsrf))
[2227]568!albedo SB >>>
[3781]569      print*, 'allocate falb'
[2227]570      ALLOCATE(falb_dir(klon,nsw,nbsrf),falb_dif(klon,nsw,nbsrf))
[3956]571!!      print*, 'allocate falb good', falb_dir(1,1,1)
[2227]572      ALLOCATE(chl_con(klon))
573!albedo SB <<<
[952]574      ALLOCATE(rain_fall(klon))
575      ALLOCATE(snow_fall(klon))
[4523]576      ALLOCATE(bs_fall(klon))
[3756]577      ALLOCATE(solsw(klon), solswfdiff(klon), sollw(klon))
[3435]578      sollw=0.0
[952]579      ALLOCATE(radsol(klon))
[2366]580      ALLOCATE(swradcorr(klon))
[952]581      ALLOCATE(zmea(klon), zstd(klon), zsig(klon), zgam(klon))
582      ALLOCATE(zthe(klon), zpic(klon), zval(klon))
[909]583
[952]584      ALLOCATE(rugoro(klon))
585      ALLOCATE(t_ancien(klon,klev), q_ancien(klon,klev))
[4523]586      ALLOCATE(ql_ancien(klon,klev), qs_ancien(klon,klev), qbs_ancien(klon,klev))
587      ALLOCATE(prw_ancien(klon), prlw_ancien(klon), prsw_ancien(klon), prbsw_ancien(klon))
[1054]588      ALLOCATE(u_ancien(klon,klev), v_ancien(klon,klev))
[5204]589      ALLOCATE(cf_ancien(klon,klev), rvc_ancien(klon,klev))
[1742]590!!! Rom P >>>
591      ALLOCATE(tr_ancien(klon,klev,nbtr))
592!!! Rom P <<<
[952]593      ALLOCATE(clwcon(klon,klev),rnebcon(klon,klev))
[4613]594      ALLOCATE(qtc_cv(klon,klev),sigt_cv(klon,klev),detrain_cv(klon,klev),fm_cv(klon,klev))
[952]595      ALLOCATE(ratqs(klon,klev))
[1761]596      ALLOCATE(pbl_tke(klon,klev+1,nbsrf+1))
[2159]597!nrlmd<
598      ALLOCATE(delta_tsurf(klon,nbsrf))
599!>nrlmd
[1761]600      ALLOCATE(coefh(klon,klev+1,nbsrf+1))
601      ALLOCATE(coefm(klon,klev+1,nbsrf+1))
[4296]602      ! initialize cleanly coefh,coefm
603      ! (most of the time in the code these are assumed to be on klev levels)
604      coefh(:,:,:)=0
605      coefm(:,:,:)=0
[927]606      ALLOCATE(zmax0(klon), f0(klon))
[1827]607      ALLOCATE(sig1(klon,klev), w01(klon,klev))
[942]608      ALLOCATE(entr_therm(klon,klev), fm_therm(klon,klev+1))
[952]609      ALLOCATE(detr_therm(klon,klev))
610!     pour phsystoke avec thermiques
611      ALLOCATE(clwcon0th(klon,klev),rnebcon0th(klon,klev))
612! radiation outputs
[3082]613      ALLOCATE(swdnc0(klon,klevp1), swdn0(klon,klevp1), swdn(klon,klevp1))
614      ALLOCATE(swupc0(klon,klevp1), swup0(klon,klevp1), swup(klon,klevp1))
[3106]615      ALLOCATE(lwdnc0(klon,klevp1), lwdn0(klon,klevp1), lwdn(klon,klevp1))
616      ALLOCATE(lwupc0(klon,klevp1), lwup0(klon,klevp1), lwup(klon,klevp1))
[952]617      ALLOCATE(SWdn200clr(klon), SWdn200(klon))
618      ALLOCATE(SWup200clr(klon), SWup200(klon))
619      ALLOCATE(LWdn200clr(klon), LWdn200(klon))
620      ALLOCATE(LWup200clr(klon), LWup200(klon))
621      ALLOCATE(LWdnTOA(klon), LWdnTOAclr(klon))
622! pressure level
623      ALLOCATE(tsumSTD(klon,nlevSTD,nout))
624      ALLOCATE(usumSTD(klon,nlevSTD,nout), vsumSTD(klon,nlevSTD,nout))
625      ALLOCATE(wsumSTD(klon,nlevSTD,nout), phisumSTD(klon,nlevSTD,nout))
626      ALLOCATE(qsumSTD(klon,nlevSTD,nout), rhsumSTD(klon,nlevSTD,nout))
627      ALLOCATE(tnondef(klon,nlevSTD,nout))
628      ALLOCATE(uvsumSTD(klon,nlevSTD,nout))
629      ALLOCATE(vqsumSTD(klon,nlevSTD,nout))
630      ALLOCATE(vTsumSTD(klon,nlevSTD,nout))
631      ALLOCATE(wqsumSTD(klon,nlevSTD,nout))
632      ALLOCATE(vphisumSTD(klon,nlevSTD,nout))
633      ALLOCATE(wTsumSTD(klon,nlevSTD,nout))
634      ALLOCATE(u2sumSTD(klon,nlevSTD,nout))
635      ALLOCATE(v2sumSTD(klon,nlevSTD,nout))
636      ALLOCATE(T2sumSTD(klon,nlevSTD,nout))
[1398]637      ALLOCATE(O3sumSTD(klon,nlevSTD,nout))
638      ALLOCATE(O3daysumSTD(klon,nlevSTD,nout))
[1352]639!IM beg
640      ALLOCATE(wlevSTD(klon,nlevSTD), ulevSTD(klon,nlevSTD), vlevSTD(klon,nlevSTD))
641      ALLOCATE(tlevSTD(klon,nlevSTD), qlevSTD(klon,nlevSTD), rhlevSTD(klon,nlevSTD))
642      ALLOCATE(philevSTD(klon,nlevSTD))
643      ALLOCATE(uvSTD(klon,nlevSTD),vqSTD(klon,nlevSTD))
644      ALLOCATE(vTSTD(klon,nlevSTD),wqSTD(klon,nlevSTD))
645      ALLOCATE(vphiSTD(klon,nlevSTD),wTSTD(klon,nlevSTD))
646      ALLOCATE(u2STD(klon,nlevSTD),v2STD(klon,nlevSTD))
647      ALLOCATE(T2STD(klon,nlevSTD))
[1398]648      ALLOCATE(O3STD(klon,nlevSTD))
649      ALLOCATE(O3daySTD(klon,nlevSTD))
[1352]650!IM end
[952]651      ALLOCATE(seed_old(klon,napisccp))
652      ALLOCATE(zuthe(klon),zvthe(klon))
653      ALLOCATE(alb_neig(klon))
654!cloud base mass flux
[1398]655      ALLOCATE(ema_cbmf(klon))
[952]656!cloud base pressure & cloud top pressure
657      ALLOCATE(ema_pcb(klon), ema_pct(klon))
658!
[3496]659      ALLOCATE(Mipsh(klon,klev))
[952]660      ALLOCATE(Ma(klon,klev))
661      ALLOCATE(qcondc(klon,klev))
662      ALLOCATE(wd(klon))
663      ALLOCATE(sigd(klon))
664      ALLOCATE(cin(klon), ALE(klon), ALP(klon))
[4613]665      ALLOCATE(ftd(klon,klev), fqd(klon,klev),fqcomp(klon,klev))
[952]666      ALLOCATE(Ale_bl(klon))
[3080]667      ALLOCATE(ale_wake(klon))
668      ALLOCATE(ale_bl_stat(klon))
[3439]669      ale_bl_stat(:)=0
[952]670      ALLOCATE(Alp_bl(klon))
671      ALLOCATE(lalim_conv(klon))
672      ALLOCATE(wght_th(klon,klev))
673      ALLOCATE(wake_deltat(klon,klev), wake_deltaq(klon,klev))
[4744]674      ALLOCATE(wake_s(klon), awake_s(klon), wake_dens(klon), awake_dens(klon))
[3956]675!!      awake_dens = 0.  ! initialized in phyetat0
676      ALLOCATE(cv_gen(klon))
[2635]677      ALLOCATE(wake_Cstar(klon))
[1403]678      ALLOCATE(wake_pe(klon), wake_fip(klon))
[2159]679!jyg<
[2181]680      ALLOCATE(wake_delta_pbl_TKE(klon,klev+1,nbsrf+1))
[2159]681!>jyg
[952]682      ALLOCATE(pfrac_impa(klon,klev), pfrac_nucl(klon,klev))
683      ALLOCATE(pfrac_1nucl(klon,klev))
684      ALLOCATE(total_rain(klon), nday_rain(klon))
[4556]685      ALLOCATE(ndayrain_mth(klon))
[3435]686      ALLOCATE(paire_ter(klon))
[952]687      ALLOCATE(albsol1(klon), albsol2(klon))
[2227]688!albedo SB >>>
689      ALLOCATE(albsol_dir(klon,nsw),albsol_dif(klon,nsw))
690!albedo SB <<<
[1279]691
692      if (read_climoz <= 1) then
693         ALLOCATE(wo(klon,klev, 1))
694      else
695         ! read_climoz == 2
696         ALLOCATE(wo(klon,klev, 2))
697      end if
698     
[952]699      ALLOCATE(clwcon0(klon,klev),rnebcon0(klon,klev))
700      ALLOCATE(heat(klon,klev), heat0(klon,klev))
701      ALLOCATE(cool(klon,klev), cool0(klon,klev))
[3479]702      ALLOCATE(heat_volc(klon,klev), cool_volc(klon,klev))
[952]703      ALLOCATE(topsw(klon), toplw(klon))
704      ALLOCATE(sollwdown(klon), sollwdownclr(klon))
[3435]705      sollwdown = 0.
[952]706      ALLOCATE(toplwdown(klon), toplwdownclr(klon))
707      ALLOCATE(topsw0(klon),toplw0(klon),solsw0(klon),sollw0(klon))
[3435]708      sollw0 = 0.
[952]709      ALLOCATE(albpla(klon))
[1539]710!IM ajout variables CFMIP2/CMIP5
711      ALLOCATE(heatp(klon,klev), coolp(klon,klev))
712      ALLOCATE(heat0p(klon,klev), cool0p(klon,klev))
713      ALLOCATE(radsolp(klon), topswp(klon), toplwp(klon))
714      ALLOCATE(albplap(klon))
[3756]715      ALLOCATE(solswp(klon), solswfdiffp(klon), sollwp(klon))
[2240]716      ALLOCATE(gustiness(klon))
[1539]717      ALLOCATE(sollwdownp(klon))
718      ALLOCATE(topsw0p(klon),toplw0p(klon))
719      ALLOCATE(solsw0p(klon),sollw0p(klon))
[3106]720      ALLOCATE(lwdnc0p(klon,klevp1), lwdn0p(klon,klevp1), lwdnp(klon,klevp1))
721      ALLOCATE(lwupc0p(klon,klevp1), lwup0p(klon,klevp1), lwupp(klon,klevp1))
[3082]722      ALLOCATE(swdnc0p(klon,klevp1), swdn0p(klon,klevp1), swdnp(klon,klevp1))
723      ALLOCATE(swupc0p(klon,klevp1), swup0p(klon,klevp1), swupp(klon,klevp1))
[1539]724
[4677]725!AI Ajout pour Ecrad (3Deffect)       
726      ALLOCATE(heat_s2(klon,klev), cool_s2(klon,klev))
727      ALLOCATE(heat0_s2(klon,klev), cool0_s2(klon,klev))
728      ALLOCATE(radsol_s2(klon), topsw_s2(klon), toplw_s2(klon))
729      ALLOCATE(albpla_s2(klon))
730      ALLOCATE(solsw_s2(klon), solswfdiff_s2(klon), sollw_s2(klon))
[4773]731      ALLOCATE(sollwdown_s2(klon),sollwdownclr_s2(klon))
[4677]732      ALLOCATE(topsw0_s2(klon),toplw0_s2(klon))
733      ALLOCATE(solsw0_s2(klon),sollw0_s2(klon))
734      ALLOCATE(lwdnc0_s2(klon,klevp1), lwdn0_s2(klon,klevp1), lwdn_s2(klon,klevp1))
735      ALLOCATE(lwupc0_s2(klon,klevp1), lwup0_s2(klon,klevp1), lwup_s2(klon,klevp1))
736      ALLOCATE(swdnc0_s2(klon,klevp1), swdn0_s2(klon,klevp1), swdn_s2(klon,klevp1))
737      ALLOCATE(swupc0_s2(klon,klevp1), swup0_s2(klon,klevp1), swup_s2(klon,klevp1))
738
[952]739      ALLOCATE(cape(klon))
740      ALLOCATE(pbase(klon),bbase(klon))
741      ALLOCATE(zqasc(klon,klev))
742      ALLOCATE(ibas_con(klon), itop_con(klon))
743      ALLOCATE(rain_con(klon), snow_con(klon))
744      ALLOCATE(rlonPOS(klon))
745      ALLOCATE(newsst(klon))
[1813]746      ALLOCATE(ustar(klon,nbsrf),u10m(klon,nbsrf), v10m(klon,nbsrf),wstar(klon,nbsrf+1))
[952]747      ALLOCATE(topswad(klon), solswad(klon))
748      ALLOCATE(topswai(klon), solswai(klon))
[1279]749      ALLOCATE(tau_aero(klon,klev,naero_grp,nbands),piz_aero(klon,klev,naero_grp,nbands),cg_aero(klon,klev,naero_grp,nbands))
[2146]750      ALLOCATE(tau_aero_sw_rrtm(klon,klev,2,nbands_sw_rrtm),piz_aero_sw_rrtm(klon,klev,2,nbands_sw_rrtm))
751      ALLOCATE(cg_aero_sw_rrtm(klon,klev,2,nbands_sw_rrtm))
752      ALLOCATE(tau_aero_lw_rrtm(klon,klev,2,nbands_lw_rrtm),piz_aero_lw_rrtm(klon,klev,2,nbands_lw_rrtm))
753      ALLOCATE(cg_aero_lw_rrtm(klon,klev,2,nbands_lw_rrtm))
[1279]754      ALLOCATE(ccm(klon,klev,nbands))
[4088]755
756#ifdef ISO
757      ALLOCATE(xtsol(niso,klon),fxtevap(ntraciso,klon,nbsrf))
758      ALLOCATE(fxtd(ntraciso,klon,klev))
759      ALLOCATE(wake_deltaxt(ntraciso,klon,klev))
760      ALLOCATE(xt_ancien(ntraciso,klon,klev))
761      ALLOCATE(xtl_ancien(ntraciso,klon,klev))
762      ALLOCATE(xts_ancien(ntraciso,klon,klev))
[4984]763      ALLOCATE(xtbs_ancien(ntraciso,klon,klev))
[4088]764      ALLOCATE(xtrain_fall(ntraciso,klon))
765      ALLOCATE(xtsnow_fall(ntraciso,klon))
766      ALLOCATE(xtrain_con(ntraciso,klon))
767      ALLOCATE(xtsnow_con(ntraciso,klon))
768#ifdef ISOTRAC
769      ALLOCATE(bassin_map(klon))
770      ALLOCATE(boite_map(klon,klev)) 
771#endif     
772#endif
773
[1638]774      ALLOCATE(ale_bl_trig(klon))
[5208]775      ALLOCATE(ratqs_inter_(klon,klev),sigma_qtherm(klon,klev))
[3435]776      IF (ok_gwd_rando) THEN
[3756]777        ALLOCATE(du_gwd_rando(klon, klev))
[3435]778        du_gwd_rando(:,:)=0.
779      ENDIF
780      IF (.not. ok_hines .and. ok_gwd_rando) THEN
781        ALLOCATE(du_gwd_front(klon, klev))
782        du_gwd_front(:,:) = 0 !ym missing init   
783      ENDIF
[909]784
[4370]785      if (activate_ocean_skin >= 1) then
786         ALLOCATE(delta_sal(klon), ds_ns(klon), dt_ns(klon), delta_sst(klon), &
787              dter(klon), dser(klon))
788         if (activate_ocean_skin == 2 .and. type_ocean == "couple") &
789              allocate(dt_ds(klon))
790      end if
791
[3815]792    END SUBROUTINE phys_state_var_init
793
[909]794!======================================================================
[3815]795    SUBROUTINE phys_state_var_end
796      ! Useful only for lmdz1d.
[5282]797      USE clesphys_mod_h
[1785]798USE indice_sol_mod
[3815]799use config_ocean_skin_m, only: activate_ocean_skin
[4370]800use surface_data, only: type_ocean
[909]801IMPLICIT NONE
802
[3756]803      DEALLOCATE(pctsrf, ftsol, falb1, falb2)
[3888]804      DEALLOCATE(beta_aridity)
[3756]805      DEALLOCATE(qsol,fevap,z0m,z0h,agesno)
[2952]806!FC
[3756]807      DEALLOCATE(treedrg)
[4523]808      DEALLOCATE(rain_fall, snow_fall, bs_fall,solsw, solswfdiff, sollw, radsol, swradcorr)
[3756]809      DEALLOCATE(zmea, zstd, zsig, zgam)
810      DEALLOCATE(zthe, zpic, zval)
811      DEALLOCATE(rugoro, t_ancien, q_ancien, clwcon, rnebcon)
[5204]812      DEALLOCATE(qs_ancien, ql_ancien, qbs_ancien)
[4523]813      DEALLOCATE(prw_ancien, prlw_ancien, prsw_ancien, prbsw_ancien)
[4613]814      DEALLOCATE(qtc_cv,sigt_cv,detrain_cv,fm_cv)
[3756]815      DEALLOCATE(u_ancien, v_ancien)
[5204]816      DEALLOCATE(cf_ancien, rvc_ancien)
[3756]817      DEALLOCATE(tr_ancien)                           !RomP
818      DEALLOCATE(ratqs, pbl_tke,coefh,coefm)
819      DEALLOCATE(zmax0, f0)
820      DEALLOCATE(sig1, w01)
821      DEALLOCATE(entr_therm, fm_therm)
822      DEALLOCATE(detr_therm)
823      DEALLOCATE(clwcon0th, rnebcon0th)
[952]824! radiation outputs
[3756]825      DEALLOCATE(swdnc0, swdn0, swdn)
826      DEALLOCATE(swupc0, swup0, swup)
827      DEALLOCATE(lwdnc0, lwdn0, lwdn)
828      DEALLOCATE(lwupc0, lwup0, lwup)
829      DEALLOCATE(SWdn200clr, SWdn200)
830      DEALLOCATE(SWup200clr, SWup200)
831      DEALLOCATE(LWdn200clr, LWdn200)
832      DEALLOCATE(LWup200clr, LWup200)
833      DEALLOCATE(LWdnTOA, LWdnTOAclr)
[952]834! pressure level
[3756]835      DEALLOCATE(tsumSTD)
836      DEALLOCATE(usumSTD, vsumSTD)
837      DEALLOCATE(wsumSTD, phisumSTD)
838      DEALLOCATE(tnondef)
839      DEALLOCATE(qsumSTD, rhsumSTD)
840      DEALLOCATE(uvsumSTD)
841      DEALLOCATE(vqsumSTD)
842      DEALLOCATE(vTsumSTD)
843      DEALLOCATE(wqsumSTD)
844      DEALLOCATE(vphisumSTD)
845      DEALLOCATE(wTsumSTD)
846      DEALLOCATE(u2sumSTD)
847      DEALLOCATE(v2sumSTD)
848      DEALLOCATE(T2sumSTD)
849      DEALLOCATE(O3sumSTD)
850      DEALLOCATE(O3daysumSTD)
[1352]851!IM beg
[3756]852      DEALLOCATE(wlevSTD,ulevSTD,vlevSTD,tlevSTD,qlevSTD,rhlevSTD,philevSTD)
853      DEALLOCATE(uvSTD,vqSTD,vTSTD,wqSTD,vphiSTD,wTSTD,u2STD,v2STD,T2STD,O3STD,O3daySTD)
[1352]854!IM end
[3756]855      DEALLOCATE(seed_old)
856      DEALLOCATE(zuthe, zvthe)
857      DEALLOCATE(alb_neig)
858      DEALLOCATE(ema_cbmf)
859      DEALLOCATE(ema_pcb, ema_pct)
860      DEALLOCATE(Mipsh, Ma, qcondc)
861      DEALLOCATE(wd, sigd)
862      DEALLOCATE(cin, ALE, ALP)
[4613]863      DEALLOCATE(ftd, fqd, fqcomp)
[3756]864      DEALLOCATE(Ale_bl, Alp_bl)
865      DEALLOCATE(ale_wake)
866      DEALLOCATE(ale_bl_stat)
867      DEALLOCATE(lalim_conv, wght_th)
868      DEALLOCATE(wake_deltat, wake_deltaq)
[4744]869      DEALLOCATE(wake_s, awake_s, wake_dens, awake_dens)
[3956]870      DEALLOCATE(cv_gen)
[3756]871      DEALLOCATE(wake_Cstar, wake_pe, wake_fip)
[2159]872!jyg<
[3756]873      DEALLOCATE(wake_delta_pbl_TKE)
[3888]874!nrlmd<
875      DEALLOCATE(delta_tsurf)
876!>nrlmd
[2159]877!>jyg
[3756]878      DEALLOCATE(pfrac_impa, pfrac_nucl)
879      DEALLOCATE(pfrac_1nucl)
880      DEALLOCATE(total_rain, nday_rain)
[4556]881      DEALLOCATE(ndayrain_mth)
[3756]882      DEALLOCATE(paire_ter)
883      DEALLOCATE(albsol1, albsol2)
[2227]884!albedo SB >>>
[3756]885      DEALLOCATE(albsol_dir,albsol_dif,falb_dir,falb_dif,chl_con)
[2227]886!albedo SB <<<
[3756]887      DEALLOCATE(wo)
888      DEALLOCATE(clwcon0,rnebcon0)
889      DEALLOCATE(heat, heat0)
890      DEALLOCATE(cool, cool0)
891      DEALLOCATE(heat_volc, cool_volc)
892      DEALLOCATE(topsw, toplw)
893      DEALLOCATE(sollwdown, sollwdownclr)
894      DEALLOCATE(gustiness)
895      DEALLOCATE(toplwdown, toplwdownclr)
896      DEALLOCATE(topsw0,toplw0,solsw0,sollw0)
897      DEALLOCATE(albpla)
[4677]898
899!AI Ajout pour Ecrad (3Deffect)
900      DEALLOCATE(heat_s2, cool_s2)
901      DEALLOCATE(heat0_s2, cool0_s2)
902      DEALLOCATE(radsol_s2, topsw_s2, toplw_s2)
903      DEALLOCATE(albpla_s2)
904      DEALLOCATE(solsw_s2, solswfdiff_s2, sollw_s2)
[4773]905      DEALLOCATE(sollwdown_s2, sollwdownclr_s2)
[4677]906      DEALLOCATE(topsw0_s2,toplw0_s2)
907      DEALLOCATE(solsw0_s2,sollw0_s2)
908      DEALLOCATE(lwdnc0_s2, lwdn0_s2, lwdn_s2)
909      DEALLOCATE(lwupc0_s2, lwup0_s2, lwup_s2)
910      DEALLOCATE(swdnc0_s2, swdn0_s2, swdn_s2)
911      DEALLOCATE(swupc0_s2, swup0_s2, swup_s2)
912
[1539]913!IM ajout variables CFMIP2/CMIP5
[3756]914      DEALLOCATE(heatp, coolp)
915      DEALLOCATE(heat0p, cool0p)
916      DEALLOCATE(radsolp, topswp, toplwp)
917      DEALLOCATE(albplap)
918      DEALLOCATE(solswp, solswfdiffp, sollwp)
919      DEALLOCATE(sollwdownp)
920      DEALLOCATE(topsw0p,toplw0p)
921      DEALLOCATE(solsw0p,sollw0p)
922      DEALLOCATE(lwdnc0p, lwdn0p, lwdnp)
923      DEALLOCATE(lwupc0p, lwup0p, lwupp)
924      DEALLOCATE(swdnc0p, swdn0p, swdnp)
925      DEALLOCATE(swupc0p, swup0p, swupp)
926      DEALLOCATE(cape)
927      DEALLOCATE(pbase,bbase)
928      DEALLOCATE(zqasc)
929      DEALLOCATE(ibas_con, itop_con)
930      DEALLOCATE(rain_con, snow_con)
931      DEALLOCATE(rlonPOS)
932      DEALLOCATE(newsst)
933      DEALLOCATE(ustar,u10m, v10m,wstar)
934      DEALLOCATE(topswad, solswad)
935      DEALLOCATE(topswai, solswai)
936      DEALLOCATE(tau_aero,piz_aero,cg_aero)
937      DEALLOCATE(tau_aero_sw_rrtm,piz_aero_sw_rrtm,cg_aero_sw_rrtm)
938      DEALLOCATE(tau_aero_lw_rrtm,piz_aero_lw_rrtm,cg_aero_lw_rrtm)
939      DEALLOCATE(ccm)
940      if (ok_gwd_rando) DEALLOCATE(du_gwd_rando)
941      if (.not. ok_hines .and. ok_gwd_rando) DEALLOCATE(du_gwd_front)
942      DEALLOCATE(ale_bl_trig)
[5208]943      DEALLOCATE(ratqs_inter_,sigma_qtherm)
[3815]944
[4370]945      if (activate_ocean_skin >= 1) then
946         deALLOCATE(delta_sal, ds_ns, dt_ns, delta_sst, dter, dser)
947         if (activate_ocean_skin == 2 .and. type_ocean == "couple") &
948              deALLOCATE(dt_ds)
949      end if
[3815]950
[4088]951#ifdef ISO   
952      DEALLOCATE(xtsol,fxtevap) 
[4984]953      DEALLOCATE(xt_ancien,xtl_ancien,xts_ancien,xtbs_ancien, fxtd, wake_deltaxt)
[4088]954      DEALLOCATE(xtrain_fall, xtsnow_fall, xtrain_con, xtsnow_con)
955#ifdef ISOTRAC
956      DEALLOCATE(bassin_map,boite_map)
957#endif       
958#endif
[3435]959      is_initialized=.FALSE.
[3815]960     
[909]961END SUBROUTINE phys_state_var_end
962
963      END MODULE phys_state_var_mod
Note: See TracBrowser for help on using the repository browser.