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

Last change on this file since 5405 was 5392, checked in by Laurent Fairhead, 7 weeks ago

Wrong place for END SUBROUTINE statement
END FUNCTION statement missing

  • Property svn:keywords set to Id
File size: 60.6 KB
Line 
1
2      SUBROUTINE conf_unicol
3!
4      use IOIPSL
5
6      USE print_control_mod, ONLY: lunout
7      USE tsoilnudge_mod_h
8      USE fcg_gcssold_mod_h
9      USE flux_arp_mod_h
10      USE compar1d_mod_h
11      IMPLICIT NONE
12!-----------------------------------------------------------------------
13!     Auteurs :   A. Lahellec  .
14!
15!   Declarations :
16!   --------------
17
18
19!
20!
21!   local:
22!   ------
23
24!      CHARACTER ch1*72,ch2*72,ch3*72,ch4*12
25
26!
27!  -------------------------------------------------------------------
28!
29!      .........    Initilisation parametres du lmdz1D      ..........
30!
31!---------------------------------------------------------------------
32!   initialisations:
33!   ----------------
34
35!Config  Key  = lunout
36!Config  Desc = unite de fichier pour les impressions
37!Config  Def  = 6
38!Config  Help = unite de fichier pour les impressions
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
47!Config  Desc = niveau d'impressions de debogage
48!Config  Def  = 0
49!Config  Help = Niveau d'impression pour le debogage
50!Config         (0 = minimum d'impression)
51!      prt_level = 0
52!      CALL getin('prt_level',prt_level)
53
54!-----------------------------------------------------------------------
55!  Parametres de controle du run:
56!-----------------------------------------------------------------------
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
62       restart =.false.
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
70!             no forcing by LS convergence ;
71!             surface temperature imposed ;
72!             radiative cooling may be imposed (iflag_radia=0 in physiq.def)
73!         = 1 ==> forcing_radconv = .true.
74!             idem forcing_type = 0, but the imposed radiative cooling
75!             is set to 0 (hence, if iflag_radia=0 in physiq.def,
76!             then there is no radiative cooling at all)
77!         = 2 ==> forcing_toga = .true.
78!             initial profiles from TOGA-COARE IFA files
79!             LS convergence and SST imposed from TOGA-COARE IFA files
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.
84!             initial profiles from TWPICE nc files
85!             LS convergence and SST imposed from TWPICE nc files
86!         = 5 ==> forcing_rico = .true.
87!             initial profiles from RICO idealized
88!             LS convergence imposed from  RICO (cst)
89!         = 6 ==> forcing_amma = .true.
90!         = 10 ==> forcing_case = .true.
91!             initial profiles from case.nc file
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.
101!             initial profiles from file: see prof.inp.001
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.
105!             initial profiles from file: see prof.inp.001
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
108!             use geostrophic wind ug=10m/s vg=0m/s. Duration of the case 53100s
109!             Radiation to be switched off
110!         > 100 ==> forcing_case = .true. or forcing_case2 = .true.
111!             initial profiles from case.nc file
112!
113       forcing_type = 0
114       CALL getin('forcing_type',forcing_type)
115         imp_fcg_gcssold   = .false.
116         ts_fcg_gcssold    = .false.
117         Tp_fcg_gcssold    = .false.
118         Tp_ini_gcssold    = .false.
119         xTurb_fcg_gcssold = .false.
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
128!Parametres de forcage
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
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
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
222       ok_flux_surf =.false.
223       CALL getin('ok_flux_surf',ok_flux_surf)
224
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
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
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
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.
257!Config  Help =
258       time_ini = 0.
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
273!Config  Help =
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.
287!Config  Help = surface temperature
288       tsurf = 290.
289       CALL getin('tsurf',tsurf)
290
291!Config  Key  = psurf
292!Config  Desc = surface pressure
293!Config  Def  = 102400.
294!Config  Help =
295       psurf = 102400.
296       CALL getin('psurf',psurf)
297
298!Config  Key  = zsurf
299!Config  Desc = surface altitude
300!Config  Def  = 0.
301!Config  Help =
302       zsurf = 0.
303       CALL getin('zsurf',zsurf)
304! EV pour accord avec format standard
305       CALL getin('zorog',zsurf)
306
307
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)
314! FH/2020/04/08/confinement: Pour le nouveau format standard, la rugosite s'appelle z0
315       CALL getin('z0',rugos)
316
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
333!Config  Key  = wtsurf et wqsurf
334!Config  Desc = ???
335!Config  Def  = 0.0 0.0
336!Config  Help =
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
345!Config  Help =
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
352!Config  Help =
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
359!Config  Help =
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
366!Config  Help =
367       qsolinp = 1.
368       CALL getin('qsolinp',qsolinp)
369
370
371
372!Config  Key  = betaevap
373!Config  Desc = beta for actual evaporation when prescribed
374!Config  Def  = 1.0
375!Config  Help =
376       betaevap = 1.
377       CALL getin('betaevap',betaevap)
378
379!Config  Key  = zpicinp
380!Config  Desc = denivellation orographie
381!Config  Def  = 0.
382!Config  Help =  input brise
383       zpicinp = 0.
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
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!----------------------------------------------------------
426
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)
433
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)
440
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
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)
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
540
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
562! RELIQUE ANCIENS FORMAT. ECRASE PAR LE SUIVANT
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
567       nudging_qv =0
568       CALL getin('nudging_q',nudging_qv)
569       CALL getin('nudging_qv',nudging_qv)
570
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)
579
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
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
603      write(lunout,*)' snowmass=', snowmass
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
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
632      write(lunout,*)' nudging_qv  = ', nudging_qv
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,*)
644!
645      RETURN
646      END SUBROUTINE conf_unicol
647!
648! $Id: dyn1deta0.F 1279 2010/07/30 A Lahellec$
649!
650!
651      SUBROUTINE dyn1deta0(fichnom,plev,play,phi,phis,presnivs,                 &
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
662      USE comconst_mod, ONLY: im, jm, lllm
663      USE logic_mod, ONLY: fxyhypb, ysinus
664      USE temps_mod, ONLY: annee_ref, day_ini, day_ref, itau_dyn
665
666      USE dimensions_mod, ONLY: iim, jjm, llm, ndm
667IMPLICIT NONE
668!=======================================================
669! Ecriture du fichier de redemarrage sous format NetCDF
670!=======================================================
671!   Declarations:
672!   -------------
673
674!!INCLUDE "control.h"
675
676!   Arguments:
677!   ----------
678      CHARACTER*(*) fichnom
679!Al1 plev tronque pour .nc mais plev(klev+1):=0
680      real :: plev(klon,klev+1),play (klon,klev),phi(klon,klev)
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)
684!      real :: ug(klev),vg(klev),fcoriolis
685      real :: phis(klon)
686
687!   Variables locales pour NetCDF:
688!   ------------------------------
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 : '
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
705        nmq(iq) = trim(tracers(iq)%name)
706      ENDDO
707      print*,'in dyn1deta0 ',fichnom,klon,klev,nqtot
708      CALL open_startphy(fichnom)
709      print*,'after open startphy ',fichnom,nmq
710
711!
712! Lecture des parametres de controle:
713!
714      CALL get_var("controle",tab_cntrl)
715
716
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)
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!
742      IF ( tab_cntrl(24).EQ.1. )  THEN
743        fxyhypb  =.true.
744!        dzoomx   = tab_cntrl(25)
745!        dzoomy   = tab_cntrl(26)
746!        taux     = tab_cntrl(28)
747!        tauy     = tab_cntrl(29)
748      ELSE
749        fxyhypb = .false.
750        ysinus  = .false.
751        IF( tab_cntrl(27).EQ.1. ) ysinus =.true.
752      ENDIF
753
754      day_ini = tab_cntrl(30)
755      itau_dyn = tab_cntrl(31)
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',                         &
762     &              day_ref,annee_ref,day_ini,itau_dyn
763
764!  Lecture des champs
765!
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'
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'
785
786      Do iq=1,nqtot
787        CALL get_field("q"//nmq(iq),q(:,:,iq),found)
788        IF (.NOT.found)PRINT*, modname//'Le champ <q'//nmq//'> est absent'
789      EndDo
790
791      CALL close_startphy
792      print*,' close startphy',fichnom,play(1,1),play(1,klev),temp(1,klev)
793!
794      RETURN
795      END SUBROUTINE dyn1deta0
796!
797! $Id: dyn1dredem.F 1279 2010/07/29 A Lahellec$
798!
799!
800      SUBROUTINE dyn1dredem(fichnom,plev,play,phi,phis,presnivs,           &
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
809      USE comconst_mod, ONLY: cpp, daysec, dtvr, g, kappa, omeg, rad
810      USE logic_mod, ONLY: fxyhypb, ysinus
811      USE temps_mod, ONLY: annee_ref,day_end,day_ref,itau_dyn,itaufin
812
813      USE dimensions_mod, ONLY: iim, jjm, llm, ndm
814IMPLICIT NONE
815!=======================================================
816! Ecriture du fichier de redemarrage sous format NetCDF
817!=======================================================
818!   Declarations:
819!   -------------
820
821!!INCLUDE "control.h"
822
823!   Arguments:
824!   ----------
825      CHARACTER*(*) fichnom
826!Al1 plev tronque pour .nc mais plev(klev+1):=0
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)
832!      real :: ug(klev),vg(klev),fcoriolis
833      real :: phis(klon)
834
835!   Variables locales pour NetCDF:
836!   ------------------------------
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
846!
847      INTEGER pass
848
849      CALL open_restartphy(fichnom)
850      print*,'redm1 ',fichnom,klon,klev,nqtot
851!!      nmq(1)="vap"
852!!      nmq(2)="cond"
853!!      nmq(3)="tra1"
854!!      nmq(4)="tra2"
855      DO iq = 1,nqtot
856        nmq(iq) = trim(tracers(iq)%name)
857      ENDDO
858
859!     modname = 'dyn1dredem'
860!     ierr = nf90_open(fichnom, nf90_write, nid)
861!     IF (ierr .NE. nf90_noerr) THEN
862!        abort_message="Pb. d ouverture "//fichnom
863!        CALL abort_gcm('Modele 1D',abort_message,1)
864!     ENDIF
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
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!
889!    .....    parametres  pour le zoom      ......
890
891!       tab_cntrl(20)  = clon
892!       tab_cntrl(21)  = clat
893!       tab_cntrl(22)  = grossismx
894!       tab_cntrl(23)  = grossismy
895!
896      IF ( fxyhypb )   THEN
897       tab_cntrl(24) = 1.
898!       tab_cntrl(25) = dzoomx
899!       tab_cntrl(26) = dzoomy
900       tab_cntrl(27) = 0.
901!       tab_cntrl(28) = taux
902!       tab_cntrl(29) = tauy
903      ELSE
904       tab_cntrl(24) = 0.
905!       tab_cntrl(25) = dzoomx
906!       tab_cntrl(26) = dzoomy
907       tab_cntrl(27) = 0.
908       tab_cntrl(28) = 0.
909       tab_cntrl(29) = 0.
910       IF( ysinus )  tab_cntrl(27) = 1.
911      ENDIF
912!Al1 iday_end -> day_end
913       tab_cntrl(30) = FLOAT(day_end)
914       tab_cntrl(31) = FLOAT(itau_dyn + itaufin)
915!
916      DO pass=1,2
917      CALL put_var(pass,"controle","Param. de controle Dyn1D",tab_cntrl)
918!
919
920!  Ecriture/extension de la coordonnee temps
921
922
923!  Ecriture des champs
924!
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)
934
935      Do iq=1,nqtot
936        CALL put_field(pass,"q"//nmq(iq),"eau vap ou condens et traceurs",           &
937     &                                                      q(:,:,iq))
938      EndDo
939    IF (pass==1) CALL enddef_restartphy
940    IF (pass==2) CALL close_restartphy
941
942
943      ENDDO
944
945!
946      RETURN
947      END SUBROUTINE dyn1dredem
948
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!=======================================================================
954
955!-----------------------------------------------------------------------
956!   declarations:
957!   -------------
958
959      INTEGER im,jm,ngrid,nfield
960      REAL pdyn(im,jm,nfield)
961      REAL pfi(ngrid,nfield)
962
963      INTEGER i,j,ifield,ig
964
965!-----------------------------------------------------------------------
966!   calcul:
967!   -------
968
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
975
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
983
984      RETURN
985      END SUBROUTINE gr_fi_dyn
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
1045      END FUNCTION fq_sat
1046
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!=======================================================================
1052
1053!-----------------------------------------------------------------------
1054!   declarations:
1055!   -------------
1056
1057      INTEGER im,jm,ngrid,nfield
1058      REAL pdyn(im,jm,nfield)
1059      REAL pfi(ngrid,nfield)
1060
1061      INTEGER j,ifield,ig
1062
1063!-----------------------------------------------------------------------
1064!   calcul:
1065!   -------
1066
1067      IF(ngrid.NE.2+(jm-2)*(im-1).AND.ngrid.NE.1)                          &
1068     &    STOP 'probleme de dim'
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)
1072
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
1080
1081      RETURN
1082      END SUBROUTINE gr_dyn_fi
1083
1084      SUBROUTINE disvert0(pa,preff,ap,bp,dpres,presnivs,nivsigs,nivsig)
1085
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!
1092      USE dimensions_mod, ONLY: iim, jjm, llm, ndm
1093USE paramet_mod_h
1094IMPLICIT NONE
1095
1096
1097
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
1123
1124!-----------------------------------------------------------------------
1125!
1126      pi=2.*ASIN(1.)
1127
1128      OPEN(99,file='sigma.def',status='old',form='formatted',                   &
1129     &   iostat=ierr)
1130
1131!-----------------------------------------------------------------------
1132!   cas 1 on lit les options dans sigma.def:
1133!   ----------------------------------------
1134
1135      IF (ierr.eq.0) THEN
1136
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!
1147
1148       DO 1  l = 1, llm
1149       dsig(l) = (alpha+(1.-alpha)*exp(-beta*(llm-l)))*                    &
1150     &          ( (tanh(gama*l)/tanh(gama*llm))**np +                      &
1151     &            (1.-l/FLOAT(llm))*delta )
1152   1   CONTINUE
1153
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.
1159
1160       DO 2  l = 1, llm
1161       dsig(l) = sig(l)-sig(l+1)
1162   2   CONTINUE
1163!
1164
1165      ELSE
1166!-----------------------------------------------------------------------
1167!   cas 2 ancienne discretisation (LMD5...):
1168!   ----------------------------------------
1169
1170      PRINT*,'WARNING!!! Ancienne discretisation verticale'
1171
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
1187
1188      ENDIF
1189
1190
1191      DO l=1,llm
1192        nivsigs(l) = FLOAT(l)
1193      ENDDO
1194
1195      DO l=1,llmp1
1196        nivsig(l)= FLOAT(l)
1197      ENDDO
1198
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!
1206
1207      bp(llmp1) =   0.
1208
1209      DO l = 1, llm
1210!c
1211!cc    ap(l) = 0.
1212!cc    bp(l) = sig(l)
1213
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) )
1219
1220      PRINT *,' BP '
1221      PRINT *,  bp
1222      PRINT *,' AP '
1223      PRINT *,  ap
1224
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
1229
1230      PRINT *,' PRESNIVS '
1231      PRINT *,presnivs
1232
1233      RETURN
1234      END SUBROUTINE disvert0
1235
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
1250
1251!       DO i = 1, knon
1252!        sst_out(i) = ts_cur
1253!       ENDDO
1254!
1255!      END SUBROUTINE read_tsurf1d
1256!
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
1262!   Traitement en volumes finis
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.
1290
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
1297
1298      return
1299      end subroutine advect_vert
1300
1301!===============================================================
1302
1303
1304       SUBROUTINE advect_va(llm,omega,d_t_va,d_q_va,d_u_va,d_v_va,              &
1305     &                q,temp,u,v,play)
1306!itlmd
1307!----------------------------------------------------------------------
1308!   Calcul de l'advection verticale (ascendance et subsidence) de
1309!   temperature et d'humidite. Hypothese : ce qui rentre de l'exterieur
1310!   a les memes caracteristiques que l'air de la colonne 1D (WTG) ou
1311!   sans WTG rajouter une advection horizontale
1312!----------------------------------------------------------------------
1313        USE yomcst_mod_h
1314implicit none
1315
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)
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))
1334
1335        d_q_va(l,:)= -omgdown*(q(l,:)-q(l+1,:))/(play(l)-play(l+1))
1336
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))
1339
1340
1341       elseif(l.eq.llm) then
1342        omgup=min(omega(l),0.0)
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
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))
1351
1352       else
1353        omgup=min(omega(l),0.0)
1354        omgdown=max(omega(l+1),0.0)
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))-                                  &
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
1362        d_q_va(l,:)= -omgdown*(q(l,:)-q(l+1,:))                            &
1363     &              /(play(l)-play(l+1))-                                  &
1364     &              omgup*(q(l-1,:)-q(l,:))/(play(l-1)-play(l))
1365        d_u_va(l)= -omgdown*(u(l)-u(l+1))                                  &
1366     &              /(play(l)-play(l+1))-                                  &
1367     &              omgup*(u(l-1)-u(l))/(play(l-1)-play(l))
1368        d_v_va(l)= -omgdown*(v(l)-v(l+1))                                  &
1369     &              /(play(l)-play(l+1))-                                  &
1370     &              omgup*(v(l-1)-v(l))/(play(l-1)-play(l))
1371
1372      endif
1373
1374      enddo
1375!fin itlmd
1376        return
1377        END SUBROUTINE advect_va
1378
1379!       SUBROUTINE lstendH(llm,omega,d_t_va,d_q_va,d_u_va,d_v_va,
1380       SUBROUTINE lstendH(llm,nqtot,omega,d_t_va,d_q_va,                        &
1381     &                q,temp,u,v,play)
1382!itlmd
1383!----------------------------------------------------------------------
1384!   Calcul de l'advection verticale (ascendance et subsidence) de
1385!   temperature et d'humidite. Hypothese : ce qui rentre de l'exterieur
1386!   a les memes caracteristiques que l'air de la colonne 1D (WTG) ou
1387!   sans WTG rajouter une advection horizontale
1388!----------------------------------------------------------------------
1389        USE yomcst_mod_h
1390implicit none
1391
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
1415
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)
1438      d_t_va(k)  = -omdn*dtdp(k)-omup*dtdp(k-1)+(omup+omdn)*cor(k)
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
1461         end SUBROUTINE lstendH
1462
1463!======================================================================
1464
1465!  Subroutines for nudging
1466
1467      Subroutine Nudge_RHT_init (paprs,pplay,t,q,t_targ,rh_targ)
1468! ========================================================
1469  USE dimphy
1470
1471  USE yomcst_mod_h
1472  USE yoethf_mod_h
1473implicit none
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
1514      END Subroutine Nudge_RHT_init
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
1547      END Subroutine Nudge_UV_init
1548
1549      Subroutine Nudge_RHT (dtime,paprs,pplay,t_targ,rh_targ,t,q,          &
1550     &                      d_t,d_q)
1551! ========================================================
1552  USE dimphy
1553
1554  USE yomcst_mod_h
1555  USE yoethf_mod_h
1556implicit none
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
1582   REAL zx_qs, rh, tnew, d_rh, rhnew
1583
1584! Declaration des constantes et des fonctions thermodynamiques
1585!
1586
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
1598!
1599        DO k = 1,klev
1600         DO i = 1,klon
1601           IF (paprs(i,1)-pplay(i,k) .GT. 10000.) THEN
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!
1612            tnew = t(i,k)+d_t(i,k)*dtime
1613!jyg<
1614!   Formule pour q :
1615!                         d_q = (1/tau) [rh_targ*qsat(T_new) - q]
1616!
1617!  Cette formule remplace d_q = (1/tau) [rh_targ - rh] qsat(T_new)
1618!   qui n'etait pas correcte.
1619!
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
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
1628!
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
1632!
1633         ENDDO
1634        ENDDO
1635!
1636      RETURN
1637      END Subroutine Nudge_RHT
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./
1666!      DATA tau /5400./
1667       DATA tau /43200./
1668!
1669   INTEGER k,i
1670
1671!
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
1677        DO k = 1,klev
1678         DO i = 1,klon
1679!CR: nudging everywhere
1680!           IF (paprs(i,1)-pplay(i,k) .GT. 10000.) THEN
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!
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)
1687!           ENDIF
1688!
1689         ENDDO
1690        ENDDO
1691!
1692      RETURN
1693      END Subroutine Nudge_UV
1694
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)
1710
1711       USE dimensions_mod, ONLY: iim, jjm, llm, ndm
1712USE yomcst_mod_h
1713implicit none
1714
1715
1716
1717
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 
1755!       do l = 1, llm
1756!       print *,'debut interp2, play=',l,play(l)
1757!       enddo
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
1767!        print *,'debut interp2, mxcalc=',mxcalc
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))
1791         if(theta_mod_cas(l).NE.0) t_mod_cas(l)= theta_mod_cas(l)*(play(l)/100000.)**(RD/RCPD)
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))
1818         dtrad_mod_cas(l)= dtrad_prof_cas(k2) - frac*(dtrad_prof_cas(k2)-dtrad_prof_cas(k1))
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)
1829         if(theta_mod_cas(l).NE.0) t_mod_cas(l)= theta_mod_cas(l)*(play(l)/100000.)**(RD/RCPD)
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)
1856         dtrad_mod_cas(l)= frac1*dtrad_prof_cas(k1) - frac2*dtrad_prof_cas(k2)
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
1878         omega_mod_cas(l)= 0.0                                         !jyg
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
1894         dtrad_mod_cas(l)= dtrad_prof_cas(nlev_cas)*fact               !jyg
1895 
1896        endif ! play
1897 
1898       enddo ! l
1899
1900          return
1901          end SUBROUTINE interp2_case_vertical
1902!***************************************************************************** 
1903
1904
1905
1906
Note: See TracBrowser for help on using the repository browser.