source: LMDZ6/branches/Portage_acc/libf/phylmd/phys_state_var_mod.F90 @ 4584

Last change on this file since 4584 was 4584, checked in by Laurent Fairhead, 15 months ago

Merged trunk revisions from r4443 to r4582 (HEAD) into branch

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