source: LMDZ6/trunk/libf/phylmd/dyn1d/1DUTILS.h @ 5425

Last change on this file since 5425 was 5392, checked in by Laurent Fairhead, 13 days ago

Wrong place for END SUBROUTINE statement
END FUNCTION statement missing

  • Property svn:keywords set to Id
File size: 60.6 KB
RevLine 
[2018]1
[2017]2      SUBROUTINE conf_unicol
[2019]3!
[2017]4      use IOIPSL
[5267]5
[2311]6      USE print_control_mod, ONLY: lunout
[5301]7      USE tsoilnudge_mod_h
8      USE fcg_gcssold_mod_h
9      USE flux_arp_mod_h
[5302]10      USE compar1d_mod_h
[2017]11      IMPLICIT NONE
[2019]12!-----------------------------------------------------------------------
13!     Auteurs :   A. Lahellec  .
14!
15!   Declarations :
16!   --------------
[2017]17
[5302]18
[2019]19!
20!
21!   local:
22!   ------
[2017]23
[2019]24!      CHARACTER ch1*72,ch2*72,ch3*72,ch4*12
[5272]25
[2019]26!
27!  -------------------------------------------------------------------
28!
29!      .........    Initilisation parametres du lmdz1D      ..........
30!
31!---------------------------------------------------------------------
32!   initialisations:
33!   ----------------
[2017]34
35!Config  Key  = lunout
36!Config  Desc = unite de fichier pour les impressions
37!Config  Def  = 6
[5272]38!Config  Help = unite de fichier pour les impressions
[2017]39!Config         (defaut sortie standard = 6)
40      lunout=6
41!      CALL getin('lunout', lunout)
42      IF (lunout /= 5 .and. lunout /= 6) THEN
43        OPEN(lunout,FILE='lmdz.out')
44      ENDIF
45
46!Config  Key  = prt_level
[2716]47!Config  Desc = niveau d'impressions de debogage
[2017]48!Config  Def  = 0
[2716]49!Config  Help = Niveau d'impression pour le debogage
[2017]50!Config         (0 = minimum d'impression)
[2019]51!      prt_level = 0
52!      CALL getin('prt_level',prt_level)
[2017]53
[2019]54!-----------------------------------------------------------------------
55!  Parametres de controle du run:
56!-----------------------------------------------------------------------
[2017]57
58!Config  Key  = restart
59!Config  Desc = on repart des startphy et start1dyn
60!Config  Def  = false
61!Config  Help = les fichiers restart doivent etre renomme en start
[2019]62       restart =.false.
[2017]63       CALL getin('restart',restart)
64
65!Config  Key  = forcing_type
66!Config  Desc = defines the way the SCM is forced:
67!Config  Def  = 0
68!!Config  Help = 0 ==> forcing_les = .true.
69!             initial profiles from file prof.inp.001
[5272]70!             no forcing by LS convergence ;
[2017]71!             surface temperature imposed ;
72!             radiative cooling may be imposed (iflag_radia=0 in physiq.def)
73!         = 1 ==> forcing_radconv = .true.
[5272]74!             idem forcing_type = 0, but the imposed radiative cooling
75!             is set to 0 (hence, if iflag_radia=0 in physiq.def,
[2017]76!             then there is no radiative cooling at all)
77!         = 2 ==> forcing_toga = .true.
[5272]78!             initial profiles from TOGA-COARE IFA files
79!             LS convergence and SST imposed from TOGA-COARE IFA files
[2017]80!         = 3 ==> forcing_GCM2SCM = .true.
81!             initial profiles from the GCM output
82!             LS convergence imposed from the GCM output
83!         = 4 ==> forcing_twpi = .true.
[5272]84!             initial profiles from TWPICE nc files
85!             LS convergence and SST imposed from TWPICE nc files
[2017]86!         = 5 ==> forcing_rico = .true.
87!             initial profiles from RICO idealized
[5272]88!             LS convergence imposed from  RICO (cst)
[2017]89!         = 6 ==> forcing_amma = .true.
[2191]90!         = 10 ==> forcing_case = .true.
[5272]91!             initial profiles from case.nc file
[2017]92!         = 40 ==> forcing_GCSSold = .true.
93!             initial profile from GCSS file
94!             LS convergence imposed from GCSS file
95!         = 50 ==> forcing_fire = .true.
96!         = 59 ==> forcing_sandu = .true.
97!             initial profiles from sanduref file: see prof.inp.001
98!             SST varying with time and divergence constante: see ifa_sanduref.txt file
99!             Radiation has to be computed interactively
100!         = 60 ==> forcing_astex = .true.
[5272]101!             initial profiles from file: see prof.inp.001
[2017]102!             SST,divergence,ug,vg,ufa,vfa varying with time : see ifa_astex.txt file
103!             Radiation has to be computed interactively
104!         = 61 ==> forcing_armcu = .true.
[5272]105!             initial profiles from file: see prof.inp.001
[2017]106!             sensible and latent heat flux imposed: see ifa_arm_cu_1.txt
107!             large scale advective forcing & radiative tendencies applied below 1000m: see ifa_arm_cu_2.txt
[5272]108!             use geostrophic wind ug=10m/s vg=0m/s. Duration of the case 53100s
[2017]109!             Radiation to be switched off
[2716]110!         > 100 ==> forcing_case = .true. or forcing_case2 = .true.
[5272]111!             initial profiles from case.nc file
[2017]112!
113       forcing_type = 0
114       CALL getin('forcing_type',forcing_type)
115         imp_fcg_gcssold   = .false.
[5272]116         ts_fcg_gcssold    = .false.
117         Tp_fcg_gcssold    = .false.
118         Tp_ini_gcssold    = .false.
119         xTurb_fcg_gcssold = .false.
[2017]120        IF (forcing_type .eq.40) THEN
121          CALL getin('imp_fcg',imp_fcg_gcssold)
122          CALL getin('ts_fcg',ts_fcg_gcssold)
123          CALL getin('tp_fcg',Tp_fcg_gcssold)
124          CALL getin('tp_ini',Tp_ini_gcssold)
125          CALL getin('turb_fcg',xTurb_fcg_gcssold)
126        ENDIF
127
[2716]128!Parametres de forcage
[2191]129!Config  Key  = tend_t
130!Config  Desc = forcage ou non par advection de T
131!Config  Def  = false
132!Config  Help = forcage ou non par advection de T
133       tend_t =0
134       CALL getin('tend_t',tend_t)
135
136!Config  Key  = tend_q
137!Config  Desc = forcage ou non par advection de q
138!Config  Def  = false
139!Config  Help = forcage ou non par advection de q
140       tend_q =0
141       CALL getin('tend_q',tend_q)
142
143!Config  Key  = tend_u
144!Config  Desc = forcage ou non par advection de u
145!Config  Def  = false
146!Config  Help = forcage ou non par advection de u
147       tend_u =0
148       CALL getin('tend_u',tend_u)
149
150!Config  Key  = tend_v
151!Config  Desc = forcage ou non par advection de v
152!Config  Def  = false
153!Config  Help = forcage ou non par advection de v
154       tend_v =0
155       CALL getin('tend_v',tend_v)
156
157!Config  Key  = tend_w
158!Config  Desc = forcage ou non par vitesse verticale
159!Config  Def  = false
160!Config  Help = forcage ou non par vitesse verticale
161       tend_w =0
162       CALL getin('tend_w',tend_w)
163
164!Config  Key  = tend_rayo
165!Config  Desc = forcage ou non par dtrad
166!Config  Def  = false
167!Config  Help = forcage ou non par dtrad
168       tend_rayo =0
169       CALL getin('tend_rayo',tend_rayo)
170
171
172!Config  Key  = nudge_t
173!Config  Desc = constante de nudging de T
174!Config  Def  = false
175!Config  Help = constante de nudging de T
176       nudge_t =0.
177       CALL getin('nudge_t',nudge_t)
178
179!Config  Key  = nudge_q
180!Config  Desc = constante de nudging de q
181!Config  Def  = false
182!Config  Help = constante de nudging de q
183       nudge_q =0.
184       CALL getin('nudge_q',nudge_q)
185
186!Config  Key  = nudge_u
187!Config  Desc = constante de nudging de u
188!Config  Def  = false
189!Config  Help = constante de nudging de u
190       nudge_u =0.
191       CALL getin('nudge_u',nudge_u)
192
193!Config  Key  = nudge_v
194!Config  Desc = constante de nudging de v
195!Config  Def  = false
196!Config  Help = constante de nudging de v
197       nudge_v =0.
198       CALL getin('nudge_v',nudge_v)
199
200!Config  Key  = nudge_w
201!Config  Desc = constante de nudging de w
202!Config  Def  = false
203!Config  Help = constante de nudging de w
204       nudge_w =0.
205       CALL getin('nudge_w',nudge_w)
206
207
[2181]208!Config  Key  = iflag_nudge
209!Config  Desc = atmospheric nudging ttype (decimal code)
210!Config  Def  = 0
211!Config  Help = 0 ==> no nudging
212!  If digit number n of iflag_nudge is set, then nudging of type n is on
213!  If digit number n of iflag_nudge is not set, then nudging of type n is off
214!   (digits are numbered from the right)
215       iflag_nudge = 0
216       CALL getin('iflag_nudge',iflag_nudge)
217
[2017]218!Config  Key  = ok_flux_surf
219!Config  Desc = forcage ou non par les flux de surface
220!Config  Def  = false
221!Config  Help = forcage ou non par les flux de surface
[2019]222       ok_flux_surf =.false.
[2017]223       CALL getin('ok_flux_surf',ok_flux_surf)
224
[3780]225!Config  Key  = ok_forc_tsurf
226!Config  Desc = forcage ou non par la Ts
227!Config  Def  = false
228!Config  Help = forcage ou non par la Ts
229       ok_forc_tsurf=.false.
230       CALL getin('ok_forc_tsurf',ok_forc_tsurf)
231
[2126]232!Config  Key  = ok_prescr_ust
233!Config  Desc = ustar impose ou non
234!Config  Def  = false
235!Config  Help = ustar impose ou non
236       ok_prescr_ust = .false.
237       CALL getin('ok_prescr_ust',ok_prescr_ust)
238
[3780]239
240!Config  Key  = ok_prescr_beta
241!Config  Desc = betaevap impose ou non
242!Config  Def  = false
243!Config  Help = betaevap impose ou non
244       ok_prescr_beta = .false.
245       CALL getin('ok_prescr_beta',ok_prescr_beta)
246
[2017]247!Config  Key  = ok_old_disvert
248!Config  Desc = utilisation de l ancien programme disvert0 (dans 1DUTILS.h)
249!Config  Def  = false
250!Config  Help = utilisation de l ancien programme disvert0 (dans 1DUTILS.h)
251       ok_old_disvert = .FALSE.
252       CALL getin('ok_old_disvert',ok_old_disvert)
253
254!Config  Key  = time_ini
255!Config  Desc = meaningless in this  case
256!Config  Def  = 0.
[5272]257!Config  Help =
[4650]258       time_ini = 0.
[2017]259       CALL getin('time_ini',time_ini)
260
261!Config  Key  = rlat et rlon
262!Config  Desc = latitude et longitude
263!Config  Def  = 0.0  0.0
264!Config  Help = fixe la position de la colonne
265       xlat = 0.
266       xlon = 0.
267       CALL getin('rlat',xlat)
268       CALL getin('rlon',xlon)
269
270!Config  Key  = airephy
271!Config  Desc = Grid cell area
272!Config  Def  = 1.e11
[5272]273!Config  Help =
[2017]274       airefi = 1.e11
275       CALL getin('airephy',airefi)
276
277!Config  Key  = nat_surf
278!Config  Desc = surface type
279!Config  Def  = 0 (ocean)
280!Config  Help = 0=ocean,1=land,2=glacier,3=banquise
281       nat_surf = 0.
282       CALL getin('nat_surf',nat_surf)
283
284!Config  Key  = tsurf
285!Config  Desc = surface temperature
286!Config  Def  = 290.
[3780]287!Config  Help = surface temperature
[2017]288       tsurf = 290.
289       CALL getin('tsurf',tsurf)
290
291!Config  Key  = psurf
292!Config  Desc = surface pressure
293!Config  Def  = 102400.
[5272]294!Config  Help =
[2017]295       psurf = 102400.
296       CALL getin('psurf',psurf)
297
298!Config  Key  = zsurf
299!Config  Desc = surface altitude
300!Config  Def  = 0.
[5272]301!Config  Help =
[2017]302       zsurf = 0.
303       CALL getin('zsurf',zsurf)
[5272]304! EV pour accord avec format standard
[3780]305       CALL getin('zorog',zsurf)
[2017]306
[3780]307
[2017]308!Config  Key  = rugos
309!Config  Desc = coefficient de frottement
310!Config  Def  = 0.0001
311!Config  Help = calcul du Cdrag
312       rugos = 0.0001
313       CALL getin('rugos',rugos)
[3659]314! FH/2020/04/08/confinement: Pour le nouveau format standard, la rugosite s'appelle z0
315       CALL getin('z0',rugos)
[2017]316
[2672]317!Config  Key  = rugosh
318!Config  Desc = coefficient de frottement
319!Config  Def  = rugos
320!Config  Help = calcul du Cdrag
321       rugosh = rugos
322       CALL getin('rugosh',rugosh)
323
324
325
326!Config  Key  = snowmass
327!Config  Desc = mass de neige de la surface en kg/m2
328!Config  Def  = 0.0000
329!Config  Help = snowmass
330       snowmass = 0.0000
331       CALL getin('snowmass',snowmass)
332
[2017]333!Config  Key  = wtsurf et wqsurf
334!Config  Desc = ???
335!Config  Def  = 0.0 0.0
[5272]336!Config  Help =
[2017]337       wtsurf = 0.0
338       wqsurf = 0.0
339       CALL getin('wtsurf',wtsurf)
340       CALL getin('wqsurf',wqsurf)
341
342!Config  Key  = albedo
343!Config  Desc = albedo
344!Config  Def  = 0.09
[5272]345!Config  Help =
[2017]346       albedo = 0.09
347       CALL getin('albedo',albedo)
348
349!Config  Key  = agesno
350!Config  Desc = age de la neige
351!Config  Def  = 30.0
[5272]352!Config  Help =
[2017]353       xagesno = 30.0
354       CALL getin('agesno',xagesno)
355
356!Config  Key  = restart_runoff
357!Config  Desc = age de la neige
358!Config  Def  = 30.0
[5272]359!Config  Help =
[2017]360       restart_runoff = 0.0
361       CALL getin('restart_runoff',restart_runoff)
362
363!Config  Key  = qsolinp
364!Config  Desc = initial bucket water content (kg/m2) when land (5std)
365!Config  Def  = 30.0
[5272]366!Config  Help =
[2017]367       qsolinp = 1.
368       CALL getin('qsolinp',qsolinp)
369
[3780]370
371
372!Config  Key  = betaevap
373!Config  Desc = beta for actual evaporation when prescribed
374!Config  Def  = 1.0
[5272]375!Config  Help =
[3780]376       betaevap = 1.
[5272]377       CALL getin('betaevap',betaevap)
[3780]378
[2017]379!Config  Key  = zpicinp
380!Config  Desc = denivellation orographie
[2668]381!Config  Def  = 0.
[2017]382!Config  Help =  input brise
[2668]383       zpicinp = 0.
[2017]384       CALL getin('zpicinp',zpicinp)
385!Config key = nudge_tsoil
386!Config  Desc = activation of soil temperature nudging
387!Config  Def  = .FALSE.
388!Config  Help = ...
389
390       nudge_tsoil=.FALSE.
391       CALL getin('nudge_tsoil',nudge_tsoil)
392
393!Config key = isoil_nudge
394!Config  Desc = level number where soil temperature is nudged
395!Config  Def  = 3
396!Config  Help = ...
397
398       isoil_nudge=3
399       CALL getin('isoil_nudge',isoil_nudge)
400
401!Config key = Tsoil_nudge
402!Config  Desc = target temperature for tsoil(isoil_nudge)
403!Config  Def  = 300.
404!Config  Help = ...
405
406       Tsoil_nudge=300.
407       CALL getin('Tsoil_nudge',Tsoil_nudge)
408
409!Config key = tau_soil_nudge
410!Config  Desc = nudging relaxation time for tsoil
411!Config  Def  = 3600.
412!Config  Help = ...
413
414       tau_soil_nudge=3600.
415       CALL getin('tau_soil_nudge',tau_soil_nudge)
416
[2716]417!----------------------------------------------------------
418! Param??tres de for??age pour les forcages communs:
419! Pour les forcages communs: ces entiers valent 0 ou 1
420! tadv= advection tempe, tadvv= adv tempe verticale, tadvh= adv tempe horizontale
421! qadv= advection q, qadvv= adv q verticale, qadvh= adv q horizontale
422! trad= 0 (rayonnement actif) ou 1 (prescrit par tend_rad) ou adv (prescir et contenu dans les tadv)
423! forcages en omega, w, vent geostrophique ou ustar
424! Parametres de nudging en u,v,t,q valent 0 ou 1 ou le temps de nudging
425!----------------------------------------------------------
[2017]426
[2716]427!Config  Key  = tadv
428!Config  Desc = forcage ou non par advection totale de T
429!Config  Def  = false
430!Config  Help = forcage ou non par advection totale de T
431       tadv =0
432       CALL getin('tadv',tadv)
[2017]433
[2716]434!Config  Key  = tadvv
435!Config  Desc = forcage ou non par advection verticale de T
436!Config  Def  = false
437!Config  Help = forcage ou non par advection verticale de T
438       tadvv =0
439       CALL getin('tadvv',tadvv)
[2017]440
[2716]441!Config  Key  = tadvh
442!Config  Desc = forcage ou non par advection horizontale de T
443!Config  Def  = false
444!Config  Help = forcage ou non par advection horizontale de T
445       tadvh =0
446       CALL getin('tadvh',tadvh)
447
448!Config  Key  = thadv
449!Config  Desc = forcage ou non par advection totale de Theta
450!Config  Def  = false
451!Config  Help = forcage ou non par advection totale de Theta
452       thadv =0
453       CALL getin('thadv',thadv)
454
455!Config  Key  = thadvv
456!Config  Desc = forcage ou non par advection verticale de Theta
457!Config  Def  = false
458!Config  Help = forcage ou non par advection verticale de Theta
459       thadvv =0
460       CALL getin('thadvv',thadvv)
461
462!Config  Key  = thadvh
463!Config  Desc = forcage ou non par advection horizontale de Theta
464!Config  Def  = false
465!Config  Help = forcage ou non par advection horizontale de Theta
466       thadvh =0
467       CALL getin('thadvh',thadvh)
468
469!Config  Key  = qadv
470!Config  Desc = forcage ou non par advection totale de Q
471!Config  Def  = false
472!Config  Help = forcage ou non par advection totale de Q
473       qadv =0
474       CALL getin('qadv',qadv)
475
476!Config  Key  = qadvv
477!Config  Desc = forcage ou non par advection verticale de Q
478!Config  Def  = false
479!Config  Help = forcage ou non par advection verticale de Q
480       qadvv =0
481       CALL getin('qadvv',qadvv)
482
483!Config  Key  = qadvh
484!Config  Desc = forcage ou non par advection horizontale de Q
485!Config  Def  = false
486!Config  Help = forcage ou non par advection horizontale de Q
487       qadvh =0
488       CALL getin('qadvh',qadvh)
489
490!Config  Key  = trad
491!Config  Desc = forcage ou non par tendance radiative
492!Config  Def  = false
493!Config  Help = forcage ou non par tendance radiative
494       trad =0
495       CALL getin('trad',trad)
496
497!Config  Key  = forc_omega
498!Config  Desc = forcage ou non par omega
499!Config  Def  = false
500!Config  Help = forcage ou non par omega
501       forc_omega =0
502       CALL getin('forc_omega',forc_omega)
503
[2920]504!Config  Key  = forc_u
505!Config  Desc = forcage ou non par u
506!Config  Def  = false
507!Config  Help = forcage ou non par u
508       forc_u =0
509       CALL getin('forc_u',forc_u)
510
511!Config  Key  = forc_v
512!Config  Desc = forcage ou non par v
513!Config  Def  = false
514!Config  Help = forcage ou non par v
515       forc_v =0
516       CALL getin('forc_v',forc_v)
[2716]517!Config  Key  = forc_w
518!Config  Desc = forcage ou non par w
519!Config  Def  = false
520!Config  Help = forcage ou non par w
521       forc_w =0
522       CALL getin('forc_w',forc_w)
523
524!Config  Key  = forc_geo
525!Config  Desc = forcage ou non par geo
526!Config  Def  = false
527!Config  Help = forcage ou non par geo
528       forc_geo =0
529       CALL getin('forc_geo',forc_geo)
530
531! Meme chose que ok_precr_ust
532!Config  Key  = forc_ustar
533!Config  Desc = forcage ou non par ustar
534!Config  Def  = false
535!Config  Help = forcage ou non par ustar
536       forc_ustar =0
537       CALL getin('forc_ustar',forc_ustar)
538       IF (forc_ustar .EQ. 1) ok_prescr_ust=.true.
539
[3780]540
[2716]541!Config  Key  = nudging_u
542!Config  Desc = forcage ou non par nudging sur u
543!Config  Def  = false
544!Config  Help = forcage ou non par nudging sur u
545       nudging_u =0
546       CALL getin('nudging_u',nudging_u)
547
548!Config  Key  = nudging_v
549!Config  Desc = forcage ou non par nudging sur v
550!Config  Def  = false
551!Config  Help = forcage ou non par nudging sur v
552       nudging_v =0
553       CALL getin('nudging_v',nudging_v)
554
555!Config  Key  = nudging_w
556!Config  Desc = forcage ou non par nudging sur w
557!Config  Def  = false
558!Config  Help = forcage ou non par nudging sur w
559       nudging_w =0
560       CALL getin('nudging_w',nudging_w)
561
[3593]562! RELIQUE ANCIENS FORMAT. ECRASE PAR LE SUIVANT
[2716]563!Config  Key  = nudging_q
564!Config  Desc = forcage ou non par nudging sur q
565!Config  Def  = false
566!Config  Help = forcage ou non par nudging sur q
[3593]567       nudging_qv =0
568       CALL getin('nudging_q',nudging_qv)
569       CALL getin('nudging_qv',nudging_qv)
[2716]570
[3594]571       p_nudging_u=11000.
572       p_nudging_v=11000.
573       p_nudging_t=11000.
574       p_nudging_qv=11000.
575       CALL getin('p_nudging_u',p_nudging_u)
576       CALL getin('p_nudging_v',p_nudging_v)
577       CALL getin('p_nudging_t',p_nudging_t)
578       CALL getin('p_nudging_qv',p_nudging_qv)
[3593]579
[2716]580!Config  Key  = nudging_t
581!Config  Desc = forcage ou non par nudging sur t
582!Config  Def  = false
583!Config  Help = forcage ou non par nudging sur t
584       nudging_t =0
585       CALL getin('nudging_t',nudging_t)
586
587
588
[2017]589      write(lunout,*)' +++++++++++++++++++++++++++++++++++++++'
590      write(lunout,*)' Configuration des parametres du gcm1D: '
591      write(lunout,*)' +++++++++++++++++++++++++++++++++++++++'
592      write(lunout,*)' restart = ', restart
593      write(lunout,*)' forcing_type = ', forcing_type
594      write(lunout,*)' time_ini = ', time_ini
595      write(lunout,*)' rlat = ', xlat
596      write(lunout,*)' rlon = ', xlon
597      write(lunout,*)' airephy = ', airefi
598      write(lunout,*)' nat_surf = ', nat_surf
599      write(lunout,*)' tsurf = ', tsurf
600      write(lunout,*)' psurf = ', psurf
601      write(lunout,*)' zsurf = ', zsurf
602      write(lunout,*)' rugos = ', rugos
[2672]603      write(lunout,*)' snowmass=', snowmass
[2017]604      write(lunout,*)' wtsurf = ', wtsurf
605      write(lunout,*)' wqsurf = ', wqsurf
606      write(lunout,*)' albedo = ', albedo
607      write(lunout,*)' xagesno = ', xagesno
608      write(lunout,*)' restart_runoff = ', restart_runoff
609      write(lunout,*)' qsolinp = ', qsolinp
610      write(lunout,*)' zpicinp = ', zpicinp
611      write(lunout,*)' nudge_tsoil = ', nudge_tsoil
612      write(lunout,*)' isoil_nudge = ', isoil_nudge
613      write(lunout,*)' Tsoil_nudge = ', Tsoil_nudge
614      write(lunout,*)' tau_soil_nudge = ', tau_soil_nudge
[2716]615      write(lunout,*)' tadv =      ', tadv
616      write(lunout,*)' tadvv =     ', tadvv
617      write(lunout,*)' tadvh =     ', tadvh
618      write(lunout,*)' thadv =     ', thadv
619      write(lunout,*)' thadvv =    ', thadvv
620      write(lunout,*)' thadvh =    ', thadvh
621      write(lunout,*)' qadv =      ', qadv
622      write(lunout,*)' qadvv =     ', qadvv
623      write(lunout,*)' qadvh =     ', qadvh
624      write(lunout,*)' trad =      ', trad
625      write(lunout,*)' forc_omega = ', forc_omega
626      write(lunout,*)' forc_w     = ', forc_w
627      write(lunout,*)' forc_geo   = ', forc_geo
628      write(lunout,*)' forc_ustar = ', forc_ustar
629      write(lunout,*)' nudging_u  = ', nudging_u
630      write(lunout,*)' nudging_v  = ', nudging_v
631      write(lunout,*)' nudging_t  = ', nudging_t
[3593]632      write(lunout,*)' nudging_qv  = ', nudging_qv
[2017]633      IF (forcing_type .eq.40) THEN
634        write(lunout,*) '--- Forcing type GCSS Old --- with:'
635        write(lunout,*)'imp_fcg',imp_fcg_gcssold
636        write(lunout,*)'ts_fcg',ts_fcg_gcssold
637        write(lunout,*)'tp_fcg',Tp_fcg_gcssold
638        write(lunout,*)'tp_ini',Tp_ini_gcssold
639        write(lunout,*)'xturb_fcg',xTurb_fcg_gcssold
640      ENDIF
641
642      write(lunout,*)' +++++++++++++++++++++++++++++++++++++++'
643      write(lunout,*)
[2019]644!
[2017]645      RETURN
[5390]646      END SUBROUTINE conf_unicol
[2017]647!
648! $Id: dyn1deta0.F 1279 2010/07/30 A Lahellec$
649!
[2019]650!
651      SUBROUTINE dyn1deta0(fichnom,plev,play,phi,phis,presnivs,                 &
[2017]652     &                          ucov,vcov,temp,q,omega2)
653      USE dimphy
654      USE mod_grid_phy_lmdz
655      USE mod_phys_lmdz_para
656      USE iophy
657      USE phys_state_var_mod
658      USE iostart
659      USE write_field_phy
660      USE infotrac
661      use control_mod
[2597]662      USE comconst_mod, ONLY: im, jm, lllm
[2603]663      USE logic_mod, ONLY: fxyhypb, ysinus
[2601]664      USE temps_mod, ONLY: annee_ref, day_ini, day_ref, itau_dyn
[2017]665
[5271]666      USE dimensions_mod, ONLY: iim, jjm, llm, ndm
667IMPLICIT NONE
[2019]668!=======================================================
669! Ecriture du fichier de redemarrage sous format NetCDF
670!=======================================================
671!   Declarations:
672!   -------------
[2017]673
[5271]674!!INCLUDE "control.h"
675
[2019]676!   Arguments:
677!   ----------
[2017]678      CHARACTER*(*) fichnom
[2019]679!Al1 plev tronque pour .nc mais plev(klev+1):=0
[2139]680      real :: plev(klon,klev+1),play (klon,klev),phi(klon,klev)
[2017]681      real :: presnivs(klon,klev)
682      real :: ucov(klon,klev),vcov(klon,klev),temp(klon,klev)
683      real :: q(klon,klev,nqtot),omega2(klon,klev)
[2019]684!      real :: ug(klev),vg(klev),fcoriolis
[5272]685      real :: phis(klon)
[2017]686
[2019]687!   Variables locales pour NetCDF:
688!   ------------------------------
[2017]689      INTEGER iq
690      INTEGER length
691      PARAMETER (length = 100)
692      REAL tab_cntrl(length) ! tableau des parametres du run
693      character*4 nmq(nqtot)
694      character*12 modname
695      character*80 abort_message
696      LOGICAL found
697
698      modname = 'dyn1deta0 : '
[2933]699!!      nmq(1)="vap"
700!!      nmq(2)="cond"
701!!      do iq=3,nqtot
702!!        write(nmq(iq),'("tra",i1)') iq-2
703!!      enddo
704      DO iq = 1,nqtot
[4046]705        nmq(iq) = trim(tracers(iq)%name)
[2933]706      ENDDO
[2017]707      print*,'in dyn1deta0 ',fichnom,klon,klev,nqtot
708      CALL open_startphy(fichnom)
709      print*,'after open startphy ',fichnom,nmq
710
[2019]711!
712! Lecture des parametres de controle:
713!
[2017]714      CALL get_var("controle",tab_cntrl)
715
[5272]716
[2017]717      im         = tab_cntrl(1)
718      jm         = tab_cntrl(2)
719      lllm       = tab_cntrl(3)
720      day_ref    = tab_cntrl(4)
721      annee_ref  = tab_cntrl(5)
[2019]722!      rad        = tab_cntrl(6)
723!      omeg       = tab_cntrl(7)
724!      g          = tab_cntrl(8)
725!      cpp        = tab_cntrl(9)
726!      kappa      = tab_cntrl(10)
727!      daysec     = tab_cntrl(11)
728!      dtvr       = tab_cntrl(12)
729!      etot0      = tab_cntrl(13)
730!      ptot0      = tab_cntrl(14)
731!      ztot0      = tab_cntrl(15)
732!      stot0      = tab_cntrl(16)
733!      ang0       = tab_cntrl(17)
734!      pa         = tab_cntrl(18)
735!      preff      = tab_cntrl(19)
736!
737!      clon       = tab_cntrl(20)
738!      clat       = tab_cntrl(21)
739!      grossismx  = tab_cntrl(22)
740!      grossismy  = tab_cntrl(23)
741!
[2017]742      IF ( tab_cntrl(24).EQ.1. )  THEN
[2019]743        fxyhypb  =.true.
744!        dzoomx   = tab_cntrl(25)
745!        dzoomy   = tab_cntrl(26)
746!        taux     = tab_cntrl(28)
747!        tauy     = tab_cntrl(29)
[2017]748      ELSE
[2019]749        fxyhypb = .false.
750        ysinus  = .false.
[5272]751        IF( tab_cntrl(27).EQ.1. ) ysinus =.true.
[2017]752      ENDIF
753
754      day_ini = tab_cntrl(30)
755      itau_dyn = tab_cntrl(31)
[2019]756!   .................................................................
757!
758!
759!      PRINT*,'rad,omeg,g,cpp,kappa',rad,omeg,g,cpp,kappa
760!Al1
761       Print*,'day_ref,annee_ref,day_ini,itau_dyn',                         &
[2017]762     &              day_ref,annee_ref,day_ini,itau_dyn
763
[2019]764!  Lecture des champs
765!
[2017]766      CALL get_field("play",play,found)
767      IF (.NOT. found) PRINT*, modname//'Le champ <Play> est absent'
768      CALL get_field("phi",phi,found)
769      IF (.NOT. found) PRINT*, modname//'Le champ <Phi> est absent'
770      CALL get_field("phis",phis,found)
771      IF (.NOT. found) PRINT*, modname//'Le champ <Phis> est absent'
772      CALL get_field("presnivs",presnivs,found)
773      IF (.NOT. found) PRINT*, modname//'Le champ <Presnivs> est absent'
774      CALL get_field("ucov",ucov,found)
775      IF (.NOT. found) PRINT*, modname//'Le champ <ucov> est absent'
776      CALL get_field("vcov",vcov,found)
777      IF (.NOT. found) PRINT*, modname//'Le champ <vcov> est absent'
778      CALL get_field("temp",temp,found)
779      IF (.NOT. found) PRINT*, modname//'Le champ <temp> est absent'
780      CALL get_field("omega2",omega2,found)
781      IF (.NOT. found) PRINT*, modname//'Le champ <omega2> est absent'
[2139]782      plev(1,klev+1)=0.
783      CALL get_field("plev",plev(:,1:klev),found)
784      IF (.NOT. found) PRINT*, modname//'Le champ <Plev> est absent'
[2017]785
786      Do iq=1,nqtot
787        CALL get_field("q"//nmq(iq),q(:,:,iq),found)
[2019]788        IF (.NOT.found)PRINT*, modname//'Le champ <q'//nmq//'> est absent'
[2017]789      EndDo
790
791      CALL close_startphy
[2019]792      print*,' close startphy',fichnom,play(1,1),play(1,klev),temp(1,klev)
793!
[2017]794      RETURN
[5390]795      END SUBROUTINE dyn1deta0
[2017]796!
797! $Id: dyn1dredem.F 1279 2010/07/29 A Lahellec$
798!
[2019]799!
800      SUBROUTINE dyn1dredem(fichnom,plev,play,phi,phis,presnivs,           &
[2017]801     &                          ucov,vcov,temp,q,omega2)
802      USE dimphy
803      USE mod_grid_phy_lmdz
804      USE mod_phys_lmdz_para
805      USE phys_state_var_mod
806      USE iostart
807      USE infotrac
808      use control_mod
[2597]809      USE comconst_mod, ONLY: cpp, daysec, dtvr, g, kappa, omeg, rad
[2603]810      USE logic_mod, ONLY: fxyhypb, ysinus
[2601]811      USE temps_mod, ONLY: annee_ref,day_end,day_ref,itau_dyn,itaufin
[2017]812
[5271]813      USE dimensions_mod, ONLY: iim, jjm, llm, ndm
814IMPLICIT NONE
[2019]815!=======================================================
816! Ecriture du fichier de redemarrage sous format NetCDF
817!=======================================================
818!   Declarations:
819!   -------------
[2017]820
[5271]821!!INCLUDE "control.h"
822
[2019]823!   Arguments:
824!   ----------
[2017]825      CHARACTER*(*) fichnom
[2019]826!Al1 plev tronque pour .nc mais plev(klev+1):=0
[2017]827      real :: plev(klon,klev),play (klon,klev),phi(klon,klev)
828      real :: presnivs(klon,klev)
829      real :: ucov(klon,klev),vcov(klon,klev),temp(klon,klev)
830      real :: q(klon,klev,nqtot)
831      real :: omega2(klon,klev),rho(klon,klev+1)
[2019]832!      real :: ug(klev),vg(klev),fcoriolis
[5272]833      real :: phis(klon)
[2017]834
[2019]835!   Variables locales pour NetCDF:
836!   ------------------------------
[2017]837      INTEGER nid
838      INTEGER ierr
839      INTEGER iq,l
840      INTEGER length
841      PARAMETER (length = 100)
842      REAL tab_cntrl(length) ! tableau des parametres du run
843      character*4 nmq(nqtot)
844      character*20 modname
845      character*80 abort_message
[2019]846!
[3513]847      INTEGER pass
[2017]848
849      CALL open_restartphy(fichnom)
850      print*,'redm1 ',fichnom,klon,klev,nqtot
[2933]851!!      nmq(1)="vap"
852!!      nmq(2)="cond"
853!!      nmq(3)="tra1"
854!!      nmq(4)="tra2"
855      DO iq = 1,nqtot
[4046]856        nmq(iq) = trim(tracers(iq)%name)
[2933]857      ENDDO
[2017]858
[3540]859!     modname = 'dyn1dredem'
[5270]860!     ierr = nf90_open(fichnom, nf90_write, nid)
861!     IF (ierr .NE. nf90_noerr) THEN
[3540]862!        abort_message="Pb. d ouverture "//fichnom
863!        CALL abort_gcm('Modele 1D',abort_message,1)
864!     ENDIF
[2017]865
866      DO l=1,length
867       tab_cntrl(l) = 0.
868      ENDDO
869       tab_cntrl(1)  = FLOAT(iim)
870       tab_cntrl(2)  = FLOAT(jjm)
871       tab_cntrl(3)  = FLOAT(llm)
872       tab_cntrl(4)  = FLOAT(day_ref)
873       tab_cntrl(5)  = FLOAT(annee_ref)
874       tab_cntrl(6)  = rad
875       tab_cntrl(7)  = omeg
876       tab_cntrl(8)  = g
877       tab_cntrl(9)  = cpp
878       tab_cntrl(10) = kappa
879       tab_cntrl(11) = daysec
880       tab_cntrl(12) = dtvr
[2019]881!       tab_cntrl(13) = etot0
882!       tab_cntrl(14) = ptot0
883!       tab_cntrl(15) = ztot0
884!       tab_cntrl(16) = stot0
885!       tab_cntrl(17) = ang0
886!       tab_cntrl(18) = pa
887!       tab_cntrl(19) = preff
888!
[5272]889!    .....    parametres  pour le zoom      ......
[2017]890
[2019]891!       tab_cntrl(20)  = clon
892!       tab_cntrl(21)  = clat
893!       tab_cntrl(22)  = grossismx
894!       tab_cntrl(23)  = grossismy
895!
[2017]896      IF ( fxyhypb )   THEN
897       tab_cntrl(24) = 1.
[2019]898!       tab_cntrl(25) = dzoomx
899!       tab_cntrl(26) = dzoomy
[2017]900       tab_cntrl(27) = 0.
[2019]901!       tab_cntrl(28) = taux
902!       tab_cntrl(29) = tauy
[2017]903      ELSE
904       tab_cntrl(24) = 0.
[2019]905!       tab_cntrl(25) = dzoomx
906!       tab_cntrl(26) = dzoomy
[2017]907       tab_cntrl(27) = 0.
908       tab_cntrl(28) = 0.
909       tab_cntrl(29) = 0.
910       IF( ysinus )  tab_cntrl(27) = 1.
911      ENDIF
[2019]912!Al1 iday_end -> day_end
[2017]913       tab_cntrl(30) = FLOAT(day_end)
914       tab_cntrl(31) = FLOAT(itau_dyn + itaufin)
[2019]915!
[3513]916      DO pass=1,2
917      CALL put_var(pass,"controle","Param. de controle Dyn1D",tab_cntrl)
[2019]918!
[2017]919
[2019]920!  Ecriture/extension de la coordonnee temps
[2017]921
922
[2019]923!  Ecriture des champs
924!
[3513]925      CALL put_field(pass,"plev","p interfaces sauf la nulle",plev)
926      CALL put_field(pass,"play","",play)
927      CALL put_field(pass,"phi","geopotentielle",phi)
928      CALL put_field(pass,"phis","geopotentiell de surface",phis)
929      CALL put_field(pass,"presnivs","",presnivs)
930      CALL put_field(pass,"ucov","",ucov)
931      CALL put_field(pass,"vcov","",vcov)
932      CALL put_field(pass,"temp","",temp)
933      CALL put_field(pass,"omega2","",omega2)
[2017]934
935      Do iq=1,nqtot
[3513]936        CALL put_field(pass,"q"//nmq(iq),"eau vap ou condens et traceurs",           &
[2019]937     &                                                      q(:,:,iq))
[2017]938      EndDo
[3513]939    IF (pass==1) CALL enddef_restartphy
940    IF (pass==2) CALL close_restartphy
[2017]941
[3513]942
943      ENDDO
944
[2019]945!
[2017]946      RETURN
[5390]947      END SUBROUTINE dyn1dredem
948
[2017]949      SUBROUTINE gr_fi_dyn(nfield,ngrid,im,jm,pfi,pdyn)
950      IMPLICIT NONE
951!=======================================================================
952!   passage d'un champ de la grille scalaire a la grille physique
953!=======================================================================
[5272]954
[2017]955!-----------------------------------------------------------------------
956!   declarations:
957!   -------------
[5272]958
[2017]959      INTEGER im,jm,ngrid,nfield
960      REAL pdyn(im,jm,nfield)
961      REAL pfi(ngrid,nfield)
[5272]962
[2017]963      INTEGER i,j,ifield,ig
[5272]964
[2017]965!-----------------------------------------------------------------------
966!   calcul:
967!   -------
[5272]968
[2017]969      DO ifield=1,nfield
970!   traitement des poles
971         DO i=1,im
972            pdyn(i,1,ifield)=pfi(1,ifield)
973            pdyn(i,jm,ifield)=pfi(ngrid,ifield)
974         ENDDO
[5272]975
[2017]976!   traitement des point normaux
977         DO j=2,jm-1
978            ig=2+(j-2)*(im-1)
979            CALL SCOPY(im-1,pfi(ig,ifield),1,pdyn(1,j,ifield),1)
980            pdyn(im,j,ifield)=pdyn(1,j,ifield)
981         ENDDO
982      ENDDO
[5272]983
[2017]984      RETURN
[5392]985      END SUBROUTINE gr_fi_dyn
[2017]986
987      REAL FUNCTION fq_sat(kelvin, millibar)
988!
989      IMPLICIT none
990!======================================================================
991! Autheur(s): Z.X. Li (LMD/CNRS)
992! Objet: calculer la vapeur d'eau saturante (formule Centre Euro.)
993!======================================================================
994! Arguments:
995! kelvin---input-R: temperature en Kelvin
996! millibar--input-R: pression en mb
997!
998! fq_sat----output-R: vapeur d'eau saturante en kg/kg
999!======================================================================
1000!
1001      REAL kelvin, millibar
1002!
1003      REAL r2es
1004      PARAMETER (r2es=611.14 *18.0153/28.9644)
1005!
1006      REAL r3les, r3ies, r3es
1007      PARAMETER (R3LES=17.269)
1008      PARAMETER (R3IES=21.875)
1009!
1010      REAL r4les, r4ies, r4es
1011      PARAMETER (R4LES=35.86)
1012      PARAMETER (R4IES=7.66)
1013!
1014      REAL rtt
1015      PARAMETER (rtt=273.16)
1016!
1017      REAL retv
1018      PARAMETER (retv=28.9644/18.0153 - 1.0)
1019!
1020      REAL zqsat
1021      REAL temp, pres
1022!     ------------------------------------------------------------------
1023!
1024!
1025      temp = kelvin
1026      pres = millibar * 100.0
1027!      write(*,*)'kelvin,millibar=',kelvin,millibar
1028!      write(*,*)'temp,pres=',temp,pres
1029!
1030      IF (temp .LE. rtt) THEN
1031         r3es = r3ies
1032         r4es = r4ies
1033      ELSE
1034         r3es = r3les
1035         r4es = r4les
1036      ENDIF
1037!
1038      zqsat=r2es/pres * EXP ( r3es*(temp-rtt) / (temp-r4es) )
1039      zqsat=MIN(0.5,ZQSAT)
1040      zqsat=zqsat/(1.-retv  *zqsat)
1041!
1042      fq_sat = zqsat
1043!
1044      RETURN
[5392]1045      END FUNCTION fq_sat
[5272]1046
[2017]1047      SUBROUTINE gr_dyn_fi(nfield,im,jm,ngrid,pdyn,pfi)
1048      IMPLICIT NONE
1049!=======================================================================
1050!   passage d'un champ de la grille scalaire a la grille physique
1051!=======================================================================
[5272]1052
[2017]1053!-----------------------------------------------------------------------
1054!   declarations:
1055!   -------------
[5272]1056
[2017]1057      INTEGER im,jm,ngrid,nfield
1058      REAL pdyn(im,jm,nfield)
1059      REAL pfi(ngrid,nfield)
[5272]1060
[2017]1061      INTEGER j,ifield,ig
[5272]1062
[2017]1063!-----------------------------------------------------------------------
1064!   calcul:
1065!   -------
[5272]1066
[2019]1067      IF(ngrid.NE.2+(jm-2)*(im-1).AND.ngrid.NE.1)                          &
1068     &    STOP 'probleme de dim'
[2017]1069!   traitement des poles
1070      CALL SCOPY(nfield,pdyn,im*jm,pfi,ngrid)
1071      CALL SCOPY(nfield,pdyn(1,jm,1),im*jm,pfi(ngrid,1),ngrid)
[5272]1072
[2017]1073!   traitement des point normaux
1074      DO ifield=1,nfield
1075         DO j=2,jm-1
1076            ig=2+(j-2)*(im-1)
1077            CALL SCOPY(im-1,pdyn(1,j,ifield),1,pfi(ig,ifield),1)
1078         ENDDO
1079      ENDDO
[5272]1080
[2017]1081      RETURN
[5390]1082      END SUBROUTINE gr_dyn_fi
[5272]1083
[2017]1084      SUBROUTINE disvert0(pa,preff,ap,bp,dpres,presnivs,nivsigs,nivsig)
[5272]1085
[2017]1086!    Ancienne version disvert dont on a modifie nom pour utiliser
1087!    le disvert de dyn3d (qui permet d'utiliser grille avec ab,bp imposes)
1088!    (MPL 18092012)
1089!
1090!    Auteur :  P. Le Van .
1091!
[5271]1092      USE dimensions_mod, ONLY: iim, jjm, llm, ndm
[5285]1093USE paramet_mod_h
[5271]1094IMPLICIT NONE
1095
1096
[5272]1097
[2017]1098!
1099!=======================================================================
1100!
1101!
1102!    s = sigma ** kappa   :  coordonnee  verticale
1103!    dsig(l)            : epaisseur de la couche l ds la coord.  s
1104!    sig(l)             : sigma a l'interface des couches l et l-1
1105!    ds(l)              : distance entre les couches l et l-1 en coord.s
1106!
1107!=======================================================================
1108!
1109      REAL pa,preff
1110      REAL ap(llmp1),bp(llmp1),dpres(llm),nivsigs(llm),nivsig(llmp1)
1111      REAL presnivs(llm)
1112!
1113!   declarations:
1114!   -------------
1115!
1116      REAL sig(llm+1),dsig(llm)
1117!
1118      INTEGER l
1119      REAL snorm
1120      REAL alpha,beta,gama,delta,deltaz,h
1121      INTEGER np,ierr
1122      REAL pi,x
[5272]1123
[2017]1124!-----------------------------------------------------------------------
1125!
1126      pi=2.*ASIN(1.)
[5272]1127
[2019]1128      OPEN(99,file='sigma.def',status='old',form='formatted',                   &
1129     &   iostat=ierr)
[5272]1130
[2017]1131!-----------------------------------------------------------------------
1132!   cas 1 on lit les options dans sigma.def:
1133!   ----------------------------------------
[5272]1134
[2017]1135      IF (ierr.eq.0) THEN
[5272]1136
[2017]1137      print*,'WARNING!!! on lit les options dans sigma.def'
1138      READ(99,*) deltaz
1139      READ(99,*) h
1140      READ(99,*) beta
1141      READ(99,*) gama
1142      READ(99,*) delta
1143      READ(99,*) np
1144      CLOSE(99)
1145      alpha=deltaz/(llm*h)
1146!
[5272]1147
[2017]1148       DO 1  l = 1, llm
[2019]1149       dsig(l) = (alpha+(1.-alpha)*exp(-beta*(llm-l)))*                    &
1150     &          ( (tanh(gama*l)/tanh(gama*llm))**np +                      &
1151     &            (1.-l/FLOAT(llm))*delta )
[2017]1152   1   CONTINUE
[5272]1153
[2017]1154       sig(1)=1.
1155       DO 101 l=1,llm-1
1156          sig(l+1)=sig(l)*(1.-dsig(l))/(1.+dsig(l))
1157101    CONTINUE
1158       sig(llm+1)=0.
[5272]1159
[2017]1160       DO 2  l = 1, llm
1161       dsig(l) = sig(l)-sig(l+1)
1162   2   CONTINUE
1163!
[5272]1164
[2017]1165      ELSE
1166!-----------------------------------------------------------------------
1167!   cas 2 ancienne discretisation (LMD5...):
1168!   ----------------------------------------
[5272]1169
[2017]1170      PRINT*,'WARNING!!! Ancienne discretisation verticale'
[5272]1171
[2017]1172      h=7.
1173      snorm  = 0.
1174      DO l = 1, llm
1175         x = 2.*asin(1.) * (FLOAT(l)-0.5) / float(llm+1)
1176         dsig(l) = 1.0 + 7.0 * SIN(x)**2
1177         snorm = snorm + dsig(l)
1178      ENDDO
1179      snorm = 1./snorm
1180      DO l = 1, llm
1181         dsig(l) = dsig(l)*snorm
1182      ENDDO
1183      sig(llm+1) = 0.
1184      DO l = llm, 1, -1
1185         sig(l) = sig(l+1) + dsig(l)
1186      ENDDO
[5272]1187
[2017]1188      ENDIF
[5272]1189
1190
[2017]1191      DO l=1,llm
1192        nivsigs(l) = FLOAT(l)
1193      ENDDO
[5272]1194
[2017]1195      DO l=1,llmp1
1196        nivsig(l)= FLOAT(l)
1197      ENDDO
[5272]1198
[2017]1199!
1200!    ....  Calculs  de ap(l) et de bp(l)  ....
1201!    .........................................
1202!
1203!
1204!   .....  pa et preff sont lus  sur les fichiers start par lectba  .....
1205!
[5272]1206
[2017]1207      bp(llmp1) =   0.
[5272]1208
[2017]1209      DO l = 1, llm
1210!c
1211!cc    ap(l) = 0.
1212!cc    bp(l) = sig(l)
[5272]1213
[2017]1214      bp(l) = EXP( 1. -1./( sig(l)*sig(l)) )
1215      ap(l) = pa * ( sig(l) - bp(l) )
1216!
1217      ENDDO
1218      ap(llmp1) = pa * ( sig(llmp1) - bp(llmp1) )
[5272]1219
[2017]1220      PRINT *,' BP '
1221      PRINT *,  bp
1222      PRINT *,' AP '
1223      PRINT *,  ap
[5272]1224
[2096]1225      DO l = 1, llm
1226       dpres(l) = bp(l) - bp(l+1)
1227       presnivs(l) = 0.5 *( ap(l)+bp(l)*preff + ap(l+1)+bp(l+1)*preff )
1228      ENDDO
[5272]1229
[2017]1230      PRINT *,' PRESNIVS '
1231      PRINT *,presnivs
[5272]1232
[2017]1233      RETURN
[5390]1234      END SUBROUTINE disvert0
[2017]1235
[3780]1236!!======================================================================
1237!       SUBROUTINE read_tsurf1d(knon,sst_out)
1238!
1239!! This subroutine specifies the surface temperature to be used in 1D simulations
1240!
1241!      USE dimphy, ONLY : klon
1242!
1243!      INTEGER, INTENT(IN)                  :: knon     ! nomber of points on compressed grid
1244!      REAL, DIMENSION(klon), INTENT(OUT)   :: sst_out  ! tsurf used to force the single-column model
1245!
1246!       INTEGER :: i
1247!! COMMON defined in lmdz1d.F:
1248!       real ts_cur
1249!       common /sst_forcing/ts_cur
[2017]1250
[3780]1251!       DO i = 1, knon
1252!        sst_out(i) = ts_cur
1253!       ENDDO
1254!
1255!      END SUBROUTINE read_tsurf1d
1256!
[2017]1257!===============================================================
1258      subroutine advect_vert(llm,w,dt,q,plev)
1259!===============================================================
1260!   Schema amont pour l'advection verticale en 1D
1261!   w est la vitesse verticale dp/dt en Pa/s
[5272]1262!   Traitement en volumes finis
[2017]1263!   d / dt ( zm q ) = delta_z ( omega q )
1264!   d / dt ( zm ) = delta_z ( omega )
1265!   avec zm = delta_z ( p )
1266!   si * designe la valeur au pas de temps t+dt
1267!   zm*(l) q*(l) - zm(l) q(l) = w(l+1) q(l+1) - w(l) q(l)
1268!   zm*(l) -zm(l) = w(l+1) - w(l)
1269!   avec w=omega * dt
1270!---------------------------------------------------------------
1271      implicit none
1272! arguments
1273      integer llm
1274      real w(llm+1),q(llm),plev(llm+1),dt
1275
1276! local
1277      integer l
1278      real zwq(llm+1),zm(llm+1),zw(llm+1)
1279      real qold
1280
1281!---------------------------------------------------------------
1282
1283      do l=1,llm
1284         zw(l)=dt*w(l)
1285         zm(l)=plev(l)-plev(l+1)
1286         zwq(l)=q(l)*zw(l)
1287      enddo
1288      zwq(llm+1)=0.
1289      zw(llm+1)=0.
[5272]1290
[2017]1291      do l=1,llm
1292         qold=q(l)
1293         q(l)=(q(l)*zm(l)+zwq(l+1)-zwq(l))/(zm(l)+zw(l+1)-zw(l))
1294         print*,'ADV Q ',zm(l),zw(l),zwq(l),qold,q(l)
1295      enddo
1296
[5272]1297
[2017]1298      return
[5390]1299      end subroutine advect_vert
[2017]1300
1301!===============================================================
1302
1303
[2019]1304       SUBROUTINE advect_va(llm,omega,d_t_va,d_q_va,d_u_va,d_v_va,              &
1305     &                q,temp,u,v,play)
[5272]1306!itlmd
[2017]1307!----------------------------------------------------------------------
[5272]1308!   Calcul de l'advection verticale (ascendance et subsidence) de
[2716]1309!   temperature et d'humidite. Hypothese : ce qui rentre de l'exterieur
[5272]1310!   a les memes caracteristiques que l'air de la colonne 1D (WTG) ou
1311!   sans WTG rajouter une advection horizontale
1312!----------------------------------------------------------------------
[5285]1313        USE yomcst_mod_h
[5274]1314implicit none
1315
[2017]1316!        argument
1317        integer llm
1318        real  omega(llm+1),d_t_va(llm), d_q_va(llm,3)
1319        real  d_u_va(llm), d_v_va(llm)
1320        real  q(llm,3),temp(llm)
1321        real  u(llm),v(llm)
1322        real  play(llm)
1323! interne
1324        integer l
1325        real alpha,omgdown,omgup
1326
1327      do l= 1,llm
1328       if(l.eq.1) then
1329!si omgup pour la couche 1, alors tendance nulle
1330        omgdown=max(omega(2),0.0)
[2019]1331        alpha = rkappa*temp(l)*(1.+q(l,1)*rv/rd)/(play(l)*(1.+q(l,1)))
1332        d_t_va(l)= alpha*(omgdown)-omgdown*(temp(l)-temp(l+1))             &
1333     &       /(play(l)-play(l+1))
[2017]1334
[5272]1335        d_q_va(l,:)= -omgdown*(q(l,:)-q(l+1,:))/(play(l)-play(l+1))
[2017]1336
[5272]1337        d_u_va(l)= -omgdown*(u(l)-u(l+1))/(play(l)-play(l+1))
1338        d_v_va(l)= -omgdown*(v(l)-v(l+1))/(play(l)-play(l+1))
[2017]1339
[5272]1340
[2017]1341       elseif(l.eq.llm) then
1342        omgup=min(omega(l),0.0)
[2019]1343        alpha = rkappa*temp(l)*(1.+q(l,1)*rv/rd)/(play(l)*(1.+q(l,1)))
1344        d_t_va(l)= alpha*(omgup)-                                          &
1345
[2017]1346!bug?     &              omgup*(temp(l-1)-temp(l))/(play(l-1)-plev(l))
1347     &              omgup*(temp(l-1)-temp(l))/(play(l-1)-play(l))
1348        d_q_va(l,:)= -omgup*(q(l-1,:)-q(l,:))/(play(l-1)-play(l))
1349        d_u_va(l)= -omgup*(u(l-1)-u(l))/(play(l-1)-play(l))
1350        d_v_va(l)= -omgup*(v(l-1)-v(l))/(play(l-1)-play(l))
[5272]1351
[2017]1352       else
1353        omgup=min(omega(l),0.0)
1354        omgdown=max(omega(l+1),0.0)
[2019]1355        alpha = rkappa*temp(l)*(1.+q(l,1)*rv/rd)/(play(l)*(1.+q(l,1)))
1356        d_t_va(l)= alpha*(omgup+omgdown)-omgdown*(temp(l)-temp(l+1))       &
1357     &              /(play(l)-play(l+1))-                                  &
[2017]1358!bug?     &              omgup*(temp(l-1)-temp(l))/(play(l-1)-plev(l))
1359     &              omgup*(temp(l-1)-temp(l))/(play(l-1)-play(l))
1360!      print*, '  ??? '
1361
[2019]1362        d_q_va(l,:)= -omgdown*(q(l,:)-q(l+1,:))                            &
1363     &              /(play(l)-play(l+1))-                                  &
[5272]1364     &              omgup*(q(l-1,:)-q(l,:))/(play(l-1)-play(l))
[2019]1365        d_u_va(l)= -omgdown*(u(l)-u(l+1))                                  &
1366     &              /(play(l)-play(l+1))-                                  &
[5272]1367     &              omgup*(u(l-1)-u(l))/(play(l-1)-play(l))
[2019]1368        d_v_va(l)= -omgdown*(v(l)-v(l+1))                                  &
1369     &              /(play(l)-play(l+1))-                                  &
[2017]1370     &              omgup*(v(l-1)-v(l))/(play(l-1)-play(l))
[5272]1371
[2017]1372      endif
[5272]1373
[2017]1374      enddo
1375!fin itlmd
1376        return
[5390]1377        END SUBROUTINE advect_va
1378
[2017]1379!       SUBROUTINE lstendH(llm,omega,d_t_va,d_q_va,d_u_va,d_v_va,
[2019]1380       SUBROUTINE lstendH(llm,nqtot,omega,d_t_va,d_q_va,                        &
1381     &                q,temp,u,v,play)
[5272]1382!itlmd
[2017]1383!----------------------------------------------------------------------
[5272]1384!   Calcul de l'advection verticale (ascendance et subsidence) de
[2716]1385!   temperature et d'humidite. Hypothese : ce qui rentre de l'exterieur
[5272]1386!   a les memes caracteristiques que l'air de la colonne 1D (WTG) ou
1387!   sans WTG rajouter une advection horizontale
1388!----------------------------------------------------------------------
[5285]1389        USE yomcst_mod_h
[5274]1390implicit none
1391
[2017]1392!        argument
1393        integer llm,nqtot
1394        real  omega(llm+1),d_t_va(llm), d_q_va(llm,nqtot)
1395!        real  d_u_va(llm), d_v_va(llm)
1396        real  q(llm,nqtot),temp(llm)
1397        real  u(llm),v(llm)
1398        real  play(llm)
1399        real cor(llm)
1400!        real dph(llm),dudp(llm),dvdp(llm),dqdp(llm),dtdp(llm)
1401        real dph(llm),dqdp(llm),dtdp(llm)
1402! interne
1403        integer k
1404        real omdn,omup
1405
1406!        dudp=0.
1407!        dvdp=0.
1408        dqdp=0.
1409        dtdp=0.
1410!        d_u_va=0.
1411!        d_v_va=0.
1412
1413      cor(:) = rkappa*temp*(1.+q(:,1)*rv/rd)/(play*(1.+q(:,1)))
1414
[2933]1415
[2017]1416      do k=2,llm-1
1417
1418       dph  (k-1) = (play()- play(k-1  ))
1419!       dudp (k-1) = (u   ()- u   (k-1  ))/dph(k-1)
1420!       dvdp (k-1) = (v   ()- v   (k-1  ))/dph(k-1)
1421       dqdp (k-1) = (q   (k,1)- q   (k-1,1))/dph(k-1)
1422       dtdp (k-1) = (temp()- temp(k-1  ))/dph(k-1)
1423
1424      enddo
1425
1426!      dudp (  llm  ) = dudp ( llm-1 )
1427!      dvdp (  llm  ) = dvdp ( llm-1 )
1428      dqdp (  llm  ) = dqdp ( llm-1 )
1429      dtdp (  llm  ) = dtdp ( llm-1 )
1430
1431      do k=2,llm-1
1432      omdn=max(0.0,omega(k+1))
1433      omup=min(0.0,omega( k ))
1434
1435!      d_u_va(k)  = -omdn*dudp(k)-omup*dudp(k-1)
1436!      d_v_va(k)  = -omdn*dvdp(k)-omup*dvdp(k-1)
1437      d_q_va(k,1)= -omdn*dqdp(k)-omup*dqdp(k-1)
[2019]1438      d_t_va(k)  = -omdn*dtdp(k)-omup*dtdp(k-1)+(omup+omdn)*cor(k)
[2017]1439      enddo
1440
1441      omdn=max(0.0,omega( 2 ))
1442      omup=min(0.0,omega(llm))
1443!      d_u_va( 1 )   = -omdn*dudp( 1 )
1444!      d_u_va(llm)   = -omup*dudp(llm)
1445!      d_v_va( 1 )   = -omdn*dvdp( 1 )
1446!      d_v_va(llm)   = -omup*dvdp(llm)
1447      d_q_va( 1 ,1) = -omdn*dqdp( 1 )
1448      d_q_va(llm,1) = -omup*dqdp(llm)
1449      d_t_va( 1 )   = -omdn*dtdp( 1 )+omdn*cor( 1 )
1450      d_t_va(llm)   = -omup*dtdp(llm)!+omup*cor(llm)
1451
1452!      if(abs(rlat(1))>10.) then
1453!     Calculate the tendency due agestrophic motions
1454!      du_age = fcoriolis*(v-vg)
1455!      dv_age = fcoriolis*(ug-u)
1456!      endif
1457
1458!       call writefield_phy('d_t_va',d_t_va,llm)
1459
1460          return
[5390]1461         end SUBROUTINE lstendH
[2017]1462
1463!======================================================================
1464
[2181]1465!  Subroutines for nudging
1466
1467      Subroutine Nudge_RHT_init (paprs,pplay,t,q,t_targ,rh_targ)
1468! ========================================================
1469  USE dimphy
1470
[5285]1471  USE yomcst_mod_h
[5284]1472  USE yoethf_mod_h
[5274]1473implicit none
[2181]1474
1475! ========================================================
1476      REAL paprs(klon,klevp1)
1477      REAL pplay(klon,klev)
1478!
1479!      Variables d'etat
1480      REAL t(klon,klev)
1481      REAL q(klon,klev)
1482!
1483!   Profiles cible
1484      REAL t_targ(klon,klev)
1485      REAL rh_targ(klon,klev)
1486!
1487   INTEGER k,i
1488   REAL zx_qs
1489
1490! Declaration des constantes et des fonctions thermodynamiques
1491!
1492!
1493!  ----------------------------------------
1494!  Statement functions
1495include "FCTTRE.h"
1496!  ----------------------------------------
1497!
1498        DO k = 1,klev
1499         DO i = 1,klon
1500           t_targ(i,k) = t(i,k)
1501           IF (t(i,k).LT.RTT) THEN
1502              zx_qs = qsats(t(i,k))/(pplay(i,k))
1503           ELSE
1504              zx_qs = qsatl(t(i,k))/(pplay(i,k))
1505           ENDIF
1506           rh_targ(i,k) = q(i,k)/zx_qs
1507         ENDDO
1508        ENDDO
1509      print *, 't_targ',t_targ
1510      print *, 'rh_targ',rh_targ
1511!
1512!
1513      RETURN
[5390]1514      END Subroutine Nudge_RHT_init
[2181]1515
1516      Subroutine Nudge_UV_init (paprs,pplay,u,v,u_targ,v_targ)
1517! ========================================================
1518  USE dimphy
1519
1520  implicit none
1521
1522! ========================================================
1523      REAL paprs(klon,klevp1)
1524      REAL pplay(klon,klev)
1525!
1526!      Variables d'etat
1527      REAL u(klon,klev)
1528      REAL v(klon,klev)
1529!
1530!   Profiles cible
1531      REAL u_targ(klon,klev)
1532      REAL v_targ(klon,klev)
1533!
1534   INTEGER k,i
1535!
1536        DO k = 1,klev
1537         DO i = 1,klon
1538           u_targ(i,k) = u(i,k)
1539           v_targ(i,k) = v(i,k)
1540         ENDDO
1541        ENDDO
1542      print *, 'u_targ',u_targ
1543      print *, 'v_targ',v_targ
1544!
1545!
1546      RETURN
[5390]1547      END Subroutine Nudge_UV_init
[2181]1548
1549      Subroutine Nudge_RHT (dtime,paprs,pplay,t_targ,rh_targ,t,q,          &
1550     &                      d_t,d_q)
1551! ========================================================
1552  USE dimphy
1553
[5285]1554  USE yomcst_mod_h
[5284]1555  USE yoethf_mod_h
[5274]1556implicit none
[2181]1557
1558! ========================================================
1559      REAL dtime
1560      REAL paprs(klon,klevp1)
1561      REAL pplay(klon,klev)
1562!
1563!      Variables d'etat
1564      REAL t(klon,klev)
1565      REAL q(klon,klev)
1566!
1567! Tendances
1568      REAL d_t(klon,klev)
1569      REAL d_q(klon,klev)
1570!
1571!   Profiles cible
1572      REAL t_targ(klon,klev)
1573      REAL rh_targ(klon,klev)
1574!
1575!   Temps de relaxation
1576      REAL tau
1577!c      DATA tau /3600./
1578!!      DATA tau /5400./
1579      DATA tau /1800./
1580!
1581   INTEGER k,i
[2455]1582   REAL zx_qs, rh, tnew, d_rh, rhnew
[2181]1583
1584! Declaration des constantes et des fonctions thermodynamiques
1585!
[5274]1586
[2181]1587!
1588!  ----------------------------------------
1589!  Statement functions
1590include "FCTTRE.h"
1591!  ----------------------------------------
1592!
1593        print *,'dtime, tau ',dtime,tau
1594        print *, 't_targ',t_targ
1595        print *, 'rh_targ',rh_targ
1596        print *,'temp ',t
1597        print *,'hum ',q
[2455]1598!
[2181]1599        DO k = 1,klev
1600         DO i = 1,klon
[2455]1601           IF (paprs(i,1)-pplay(i,k) .GT. 10000.) THEN
[2181]1602            IF (t(i,k).LT.RTT) THEN
1603               zx_qs = qsats(t(i,k))/(pplay(i,k))
1604            ELSE
1605               zx_qs = qsatl(t(i,k))/(pplay(i,k))
1606            ENDIF
1607            rh = q(i,k)/zx_qs
1608!
1609            d_t(i,k) = d_t(i,k) + 1./tau*(t_targ(i,k)-t(i,k))
1610            d_rh = 1./tau*(rh_targ(i,k)-rh)
1611!
[2455]1612            tnew = t(i,k)+d_t(i,k)*dtime
1613!jyg<
1614!   Formule pour q :
[5272]1615!                         d_q = (1/tau) [rh_targ*qsat(T_new) - q]
[2455]1616!
1617!  Cette formule remplace d_q = (1/tau) [rh_targ - rh] qsat(T_new)
[2716]1618!   qui n'etait pas correcte.
[2455]1619!
[2181]1620            IF (tnew.LT.RTT) THEN
1621               zx_qs = qsats(tnew)/(pplay(i,k))
1622            ELSE
1623               zx_qs = qsatl(tnew)/(pplay(i,k))
1624            ENDIF
[2455]1625!!            d_q(i,k) = d_q(i,k) + d_rh*zx_qs
1626            d_q(i,k) = d_q(i,k) + (1./tau)*(rh_targ(i,k)*zx_qs - q(i,k))
1627            rhnew = (q(i,k)+d_q(i,k)*dtime)/zx_qs
[2181]1628!
[2455]1629            print *,' k,d_t,rh,d_rh,rhnew,d_q ',    &
1630                      k,d_t(i,k),rh,d_rh,rhnew,d_q(i,k)
1631           ENDIF
[2181]1632!
1633         ENDDO
1634        ENDDO
1635!
1636      RETURN
[5390]1637      END Subroutine Nudge_RHT
[2181]1638
1639      Subroutine Nudge_UV (dtime,paprs,pplay,u_targ,v_targ,u,v,          &
1640     &                      d_u,d_v)
1641! ========================================================
1642  USE dimphy
1643
1644  implicit none
1645
1646! ========================================================
1647      REAL dtime
1648      REAL paprs(klon,klevp1)
1649      REAL pplay(klon,klev)
1650!
1651!      Variables d'etat
1652      REAL u(klon,klev)
1653      REAL v(klon,klev)
1654!
1655! Tendances
1656      REAL d_u(klon,klev)
1657      REAL d_v(klon,klev)
1658!
1659!   Profiles cible
1660      REAL u_targ(klon,klev)
1661      REAL v_targ(klon,klev)
1662!
1663!   Temps de relaxation
1664      REAL tau
1665!c      DATA tau /3600./
[2933]1666!      DATA tau /5400./
1667       DATA tau /43200./
[2181]1668!
1669   INTEGER k,i
1670
1671!
[4292]1672        !print *,'dtime, tau ',dtime,tau
1673        !print *, 'u_targ',u_targ
1674        !print *, 'v_targ',v_targ
1675        !print *,'zonal velocity ',u
1676        !print *,'meridional velocity ',v
[2181]1677        DO k = 1,klev
1678         DO i = 1,klon
[2933]1679!CR: nudging everywhere
1680!           IF (paprs(i,1)-pplay(i,k) .GT. 10000.) THEN
[2181]1681!
1682            d_u(i,k) = d_u(i,k) + 1./tau*(u_targ(i,k)-u(i,k))
1683            d_v(i,k) = d_v(i,k) + 1./tau*(v_targ(i,k)-v(i,k))
1684!
[4292]1685!           print *,' k,u,d_u,v,d_v ',    &
1686!                     k,u(i,k),d_u(i,k),v(i,k),d_v(i,k)
[2933]1687!           ENDIF
[2181]1688!
1689         ENDDO
1690        ENDDO
1691!
1692      RETURN
[5390]1693      END Subroutine Nudge_UV
[2181]1694
[2716]1695!=====================================================================
1696       SUBROUTINE interp2_case_vertical(play,nlev_cas,plev_prof_cas                                    &
1697     &         ,t_prof_cas,th_prof_cas,thv_prof_cas,thl_prof_cas                                       &
1698     &         ,qv_prof_cas,ql_prof_cas,qi_prof_cas,u_prof_cas,v_prof_cas                              &
1699     &         ,ug_prof_cas,vg_prof_cas,vitw_prof_cas,omega_prof_cas                                   &
1700     &         ,du_prof_cas,hu_prof_cas,vu_prof_cas,dv_prof_cas,hv_prof_cas,vv_prof_cas                &
1701     &         ,dt_prof_cas,ht_prof_cas,vt_prof_cas,dtrad_prof_cas,dq_prof_cas,hq_prof_cas,vq_prof_cas &
1702     &         ,dth_prof_cas,hth_prof_cas,vth_prof_cas                                                 &
1703!
1704     &         ,t_mod_cas,theta_mod_cas,thv_mod_cas,thl_mod_cas                                        &
1705     &         ,qv_mod_cas,ql_mod_cas,qi_mod_cas,u_mod_cas,v_mod_cas                                   &
1706     &         ,ug_mod_cas,vg_mod_cas,w_mod_cas,omega_mod_cas                                          &
1707     &         ,du_mod_cas,hu_mod_cas,vu_mod_cas,dv_mod_cas,hv_mod_cas,vv_mod_cas                      &
1708     &         ,dt_mod_cas,ht_mod_cas,vt_mod_cas,dtrad_mod_cas,dq_mod_cas,hq_mod_cas,vq_mod_cas        &
1709     &         ,dth_mod_cas,hth_mod_cas,vth_mod_cas,mxcalc)
[5272]1710
[5271]1711       USE dimensions_mod, ONLY: iim, jjm, llm, ndm
[5285]1712USE yomcst_mod_h
[5271]1713implicit none
[2683]1714
[5271]1715
1716
[5274]1717
[2716]1718!-------------------------------------------------------------------------
1719! Vertical interpolation of generic case forcing data onto mod_casel levels
1720!-------------------------------------------------------------------------
1721 
1722       integer nlevmax
1723       parameter (nlevmax=41)
1724       integer nlev_cas,mxcalc
1725!       real play(llm), plev_prof(nlevmax) 
1726!       real t_prof(nlevmax),q_prof(nlevmax)
1727!       real u_prof(nlevmax),v_prof(nlevmax), w_prof(nlevmax)
1728!       real ht_prof(nlevmax),vt_prof(nlevmax)
1729!       real hq_prof(nlevmax),vq_prof(nlevmax)
1730 
1731       real play(llm), plev_prof_cas(nlev_cas) 
1732       real t_prof_cas(nlev_cas),th_prof_cas(nlev_cas),thv_prof_cas(nlev_cas),thl_prof_cas(nlev_cas)
1733       real qv_prof_cas(nlev_cas),ql_prof_cas(nlev_cas),qi_prof_cas(nlev_cas)
1734       real u_prof_cas(nlev_cas),v_prof_cas(nlev_cas)
1735       real ug_prof_cas(nlev_cas),vg_prof_cas(nlev_cas), vitw_prof_cas(nlev_cas),omega_prof_cas(nlev_cas)
1736       real du_prof_cas(nlev_cas),hu_prof_cas(nlev_cas),vu_prof_cas(nlev_cas)
1737       real dv_prof_cas(nlev_cas),hv_prof_cas(nlev_cas),vv_prof_cas(nlev_cas)
1738       real dt_prof_cas(nlev_cas),ht_prof_cas(nlev_cas),vt_prof_cas(nlev_cas),dtrad_prof_cas(nlev_cas)
1739       real dth_prof_cas(nlev_cas),hth_prof_cas(nlev_cas),vth_prof_cas(nlev_cas)
1740       real dq_prof_cas(nlev_cas),hq_prof_cas(nlev_cas),vq_prof_cas(nlev_cas)
1741 
1742       real t_mod_cas(llm),theta_mod_cas(llm),thv_mod_cas(llm),thl_mod_cas(llm)
1743       real qv_mod_cas(llm),ql_mod_cas(llm),qi_mod_cas(llm)
1744       real u_mod_cas(llm),v_mod_cas(llm)
1745       real ug_mod_cas(llm),vg_mod_cas(llm), w_mod_cas(llm),omega_mod_cas(llm)
1746       real du_mod_cas(llm),hu_mod_cas(llm),vu_mod_cas(llm)
1747       real dv_mod_cas(llm),hv_mod_cas(llm),vv_mod_cas(llm)
1748       real dt_mod_cas(llm),ht_mod_cas(llm),vt_mod_cas(llm),dtrad_mod_cas(llm)
1749       real dth_mod_cas(llm),hth_mod_cas(llm),vth_mod_cas(llm)
1750       real dq_mod_cas(llm),hq_mod_cas(llm),vq_mod_cas(llm)
1751 
1752       integer l,k,k1,k2
1753       real frac,frac1,frac2,fact
1754 
[3541]1755!       do l = 1, llm
1756!       print *,'debut interp2, play=',l,play(l)
1757!       enddo
[2716]1758!      do l = 1, nlev_cas
1759!      print *,'debut interp2, plev_prof_cas=',l,play(l),plev_prof_cas(l)
1760!      enddo
1761
1762       do l = 1, llm
1763
1764        if (play(l).ge.plev_prof_cas(nlev_cas)) then
1765 
1766        mxcalc=l
[3541]1767!        print *,'debut interp2, mxcalc=',mxcalc
[2716]1768         k1=0
1769         k2=0
1770
1771         if (play(l).le.plev_prof_cas(1)) then
1772
1773         do k = 1, nlev_cas-1
1774          if (play(l).le.plev_prof_cas(k).and. play(l).gt.plev_prof_cas(k+1)) then
1775            k1=k
1776            k2=k+1
1777          endif
1778         enddo
1779
1780         if (k1.eq.0 .or. k2.eq.0) then
1781          write(*,*) 'PB! k1, k2 = ',k1,k2
1782          write(*,*) 'l,play(l) = ',l,play(l)/100
1783         do k = 1, nlev_cas-1
1784          write(*,*) 'k,plev_prof_cas(k) = ',k,plev_prof_cas(k)/100
1785         enddo
1786         endif
1787
1788         frac = (plev_prof_cas(k2)-play(l))/(plev_prof_cas(k2)-plev_prof_cas(k1))
1789         t_mod_cas(l)= t_prof_cas(k2) - frac*(t_prof_cas(k2)-t_prof_cas(k1))
1790         theta_mod_cas(l)= th_prof_cas(k2) - frac*(th_prof_cas(k2)-th_prof_cas(k1))
[3008]1791         if(theta_mod_cas(l).NE.0) t_mod_cas(l)= theta_mod_cas(l)*(play(l)/100000.)**(RD/RCPD)
[2716]1792         thv_mod_cas(l)= thv_prof_cas(k2) - frac*(thv_prof_cas(k2)-thv_prof_cas(k1))
1793         thl_mod_cas(l)= thl_prof_cas(k2) - frac*(thl_prof_cas(k2)-thl_prof_cas(k1))
1794         qv_mod_cas(l)= qv_prof_cas(k2) - frac*(qv_prof_cas(k2)-qv_prof_cas(k1))
1795         ql_mod_cas(l)= ql_prof_cas(k2) - frac*(ql_prof_cas(k2)-ql_prof_cas(k1))
1796         qi_mod_cas(l)= qi_prof_cas(k2) - frac*(qi_prof_cas(k2)-qi_prof_cas(k1))
1797         u_mod_cas(l)= u_prof_cas(k2) - frac*(u_prof_cas(k2)-u_prof_cas(k1))
1798         v_mod_cas(l)= v_prof_cas(k2) - frac*(v_prof_cas(k2)-v_prof_cas(k1))
1799         ug_mod_cas(l)= ug_prof_cas(k2) - frac*(ug_prof_cas(k2)-ug_prof_cas(k1))
1800         vg_mod_cas(l)= vg_prof_cas(k2) - frac*(vg_prof_cas(k2)-vg_prof_cas(k1))
1801         w_mod_cas(l)= vitw_prof_cas(k2) - frac*(vitw_prof_cas(k2)-vitw_prof_cas(k1))
1802         omega_mod_cas(l)= omega_prof_cas(k2) - frac*(omega_prof_cas(k2)-omega_prof_cas(k1))
1803         du_mod_cas(l)= du_prof_cas(k2) - frac*(du_prof_cas(k2)-du_prof_cas(k1))
1804         hu_mod_cas(l)= hu_prof_cas(k2) - frac*(hu_prof_cas(k2)-hu_prof_cas(k1))
1805         vu_mod_cas(l)= vu_prof_cas(k2) - frac*(vu_prof_cas(k2)-vu_prof_cas(k1))
1806         dv_mod_cas(l)= dv_prof_cas(k2) - frac*(dv_prof_cas(k2)-dv_prof_cas(k1))
1807         hv_mod_cas(l)= hv_prof_cas(k2) - frac*(hv_prof_cas(k2)-hv_prof_cas(k1))
1808         vv_mod_cas(l)= vv_prof_cas(k2) - frac*(vv_prof_cas(k2)-vv_prof_cas(k1))
1809         dt_mod_cas(l)= dt_prof_cas(k2) - frac*(dt_prof_cas(k2)-dt_prof_cas(k1))
1810         ht_mod_cas(l)= ht_prof_cas(k2) - frac*(ht_prof_cas(k2)-ht_prof_cas(k1))
1811         vt_mod_cas(l)= vt_prof_cas(k2) - frac*(vt_prof_cas(k2)-vt_prof_cas(k1))
1812         dth_mod_cas(l)= dth_prof_cas(k2) - frac*(dth_prof_cas(k2)-dth_prof_cas(k1))
1813         hth_mod_cas(l)= hth_prof_cas(k2) - frac*(hth_prof_cas(k2)-hth_prof_cas(k1))
1814         vth_mod_cas(l)= vth_prof_cas(k2) - frac*(vth_prof_cas(k2)-vth_prof_cas(k1))
1815         dq_mod_cas(l)= dq_prof_cas(k2) - frac*(dq_prof_cas(k2)-dq_prof_cas(k1))
1816         hq_mod_cas(l)= hq_prof_cas(k2) - frac*(hq_prof_cas(k2)-hq_prof_cas(k1))
1817         vq_mod_cas(l)= vq_prof_cas(k2) - frac*(vq_prof_cas(k2)-vq_prof_cas(k1))
[2933]1818         dtrad_mod_cas(l)= dtrad_prof_cas(k2) - frac*(dtrad_prof_cas(k2)-dtrad_prof_cas(k1))
[2716]1819     
1820         else !play>plev_prof_cas(1)
1821
1822         k1=1
1823         k2=2
1824         print *,'interp2_vert, k1,k2=',plev_prof_cas(k1),plev_prof_cas(k2)
1825         frac1 = (play(l)-plev_prof_cas(k2))/(plev_prof_cas(k1)-plev_prof_cas(k2))
1826         frac2 = (play(l)-plev_prof_cas(k1))/(plev_prof_cas(k1)-plev_prof_cas(k2))
1827         t_mod_cas(l)= frac1*t_prof_cas(k1) - frac2*t_prof_cas(k2)
1828         theta_mod_cas(l)= frac1*th_prof_cas(k1) - frac2*th_prof_cas(k2)
[3008]1829         if(theta_mod_cas(l).NE.0) t_mod_cas(l)= theta_mod_cas(l)*(play(l)/100000.)**(RD/RCPD)
[2716]1830         thv_mod_cas(l)= frac1*thv_prof_cas(k1) - frac2*thv_prof_cas(k2)
1831         thl_mod_cas(l)= frac1*thl_prof_cas(k1) - frac2*thl_prof_cas(k2)
1832         qv_mod_cas(l)= frac1*qv_prof_cas(k1) - frac2*qv_prof_cas(k2)
1833         ql_mod_cas(l)= frac1*ql_prof_cas(k1) - frac2*ql_prof_cas(k2)
1834         qi_mod_cas(l)= frac1*qi_prof_cas(k1) - frac2*qi_prof_cas(k2)
1835         u_mod_cas(l)= frac1*u_prof_cas(k1) - frac2*u_prof_cas(k2)
1836         v_mod_cas(l)= frac1*v_prof_cas(k1) - frac2*v_prof_cas(k2)
1837         ug_mod_cas(l)= frac1*ug_prof_cas(k1) - frac2*ug_prof_cas(k2)
1838         vg_mod_cas(l)= frac1*vg_prof_cas(k1) - frac2*vg_prof_cas(k2)
1839         w_mod_cas(l)= frac1*vitw_prof_cas(k1) - frac2*vitw_prof_cas(k2)
1840         omega_mod_cas(l)= frac1*omega_prof_cas(k1) - frac2*omega_prof_cas(k2)
1841         du_mod_cas(l)= frac1*du_prof_cas(k1) - frac2*du_prof_cas(k2)
1842         hu_mod_cas(l)= frac1*hu_prof_cas(k1) - frac2*hu_prof_cas(k2)
1843         vu_mod_cas(l)= frac1*vu_prof_cas(k1) - frac2*vu_prof_cas(k2)
1844         dv_mod_cas(l)= frac1*dv_prof_cas(k1) - frac2*dv_prof_cas(k2)
1845         hv_mod_cas(l)= frac1*hv_prof_cas(k1) - frac2*hv_prof_cas(k2)
1846         vv_mod_cas(l)= frac1*vv_prof_cas(k1) - frac2*vv_prof_cas(k2)
1847         dt_mod_cas(l)= frac1*dt_prof_cas(k1) - frac2*dt_prof_cas(k2)
1848         ht_mod_cas(l)= frac1*ht_prof_cas(k1) - frac2*ht_prof_cas(k2)
1849         vt_mod_cas(l)= frac1*vt_prof_cas(k1) - frac2*vt_prof_cas(k2)
1850         dth_mod_cas(l)= frac1*dth_prof_cas(k1) - frac2*dth_prof_cas(k2)
1851         hth_mod_cas(l)= frac1*hth_prof_cas(k1) - frac2*hth_prof_cas(k2)
1852         vth_mod_cas(l)= frac1*vth_prof_cas(k1) - frac2*vth_prof_cas(k2)
1853         dq_mod_cas(l)= frac1*dq_prof_cas(k1) - frac2*dq_prof_cas(k2)
1854         hq_mod_cas(l)= frac1*hq_prof_cas(k1) - frac2*hq_prof_cas(k2)
1855         vq_mod_cas(l)= frac1*vq_prof_cas(k1) - frac2*vq_prof_cas(k2)
[2933]1856         dtrad_mod_cas(l)= frac1*dtrad_prof_cas(k1) - frac2*dtrad_prof_cas(k2)
[2716]1857
1858         endif ! play.le.plev_prof_cas(1)
1859
1860        else ! above max altitude of forcing file
1861 
1862!jyg
1863         fact=20.*(plev_prof_cas(nlev_cas)-play(l))/plev_prof_cas(nlev_cas) !jyg
1864         fact = max(fact,0.)                                           !jyg
1865         fact = exp(-fact)                                             !jyg
1866         t_mod_cas(l)= t_prof_cas(nlev_cas)                            !jyg
1867         theta_mod_cas(l)= th_prof_cas(nlev_cas)                       !jyg
1868         thv_mod_cas(l)= thv_prof_cas(nlev_cas)                        !jyg
1869         thl_mod_cas(l)= thl_prof_cas(nlev_cas)                        !jyg
1870         qv_mod_cas(l)= qv_prof_cas(nlev_cas)*fact                     !jyg
1871         ql_mod_cas(l)= ql_prof_cas(nlev_cas)*fact                     !jyg
1872         qi_mod_cas(l)= qi_prof_cas(nlev_cas)*fact                     !jyg
1873         u_mod_cas(l)= u_prof_cas(nlev_cas)*fact                       !jyg
1874         v_mod_cas(l)= v_prof_cas(nlev_cas)*fact                       !jyg
1875         ug_mod_cas(l)= ug_prof_cas(nlev_cas)*fact                     !jyg
1876         vg_mod_cas(l)= vg_prof_cas(nlev_cas)*fact                     !jyg
1877         w_mod_cas(l)= 0.0                                             !jyg
[2990]1878         omega_mod_cas(l)= 0.0                                         !jyg
[2716]1879         du_mod_cas(l)= du_prof_cas(nlev_cas)*fact
1880         hu_mod_cas(l)= hu_prof_cas(nlev_cas)*fact                     !jyg
1881         vu_mod_cas(l)= vu_prof_cas(nlev_cas)*fact                     !jyg
1882         dv_mod_cas(l)= dv_prof_cas(nlev_cas)*fact
1883         hv_mod_cas(l)= hv_prof_cas(nlev_cas)*fact                     !jyg
1884         vv_mod_cas(l)= vv_prof_cas(nlev_cas)*fact                     !jyg
1885         dt_mod_cas(l)= dt_prof_cas(nlev_cas) 
1886         ht_mod_cas(l)= ht_prof_cas(nlev_cas)                          !jyg
1887         vt_mod_cas(l)= vt_prof_cas(nlev_cas)                          !jyg
1888         dth_mod_cas(l)= dth_prof_cas(nlev_cas) 
1889         hth_mod_cas(l)= hth_prof_cas(nlev_cas)                        !jyg
1890         vth_mod_cas(l)= vth_prof_cas(nlev_cas)                        !jyg
1891         dq_mod_cas(l)= dq_prof_cas(nlev_cas)*fact
1892         hq_mod_cas(l)= hq_prof_cas(nlev_cas)*fact                     !jyg
1893         vq_mod_cas(l)= vq_prof_cas(nlev_cas)*fact                     !jyg
[2933]1894         dtrad_mod_cas(l)= dtrad_prof_cas(nlev_cas)*fact               !jyg
[2716]1895 
1896        endif ! play
1897 
1898       enddo ! l
1899
1900          return
[5390]1901          end SUBROUTINE interp2_case_vertical
[2716]1902!***************************************************************************** 
1903
1904
[3008]1905
1906
Note: See TracBrowser for help on using the repository browser.