source: trunk/LMDZ.VENUS/libf/phyvenus/conf_phys.F90 @ 2008

Last change on this file since 2008 was 1981, checked in by emillour, 7 years ago

Venus physics:
Follow-up of longer tracer names in the dynamics and addition of
init_print_control module variables in conf_phys.
EM

File size: 12.2 KB
Line 
1!
2! $Header: /home/cvsroot/LMDZ4/libf/phylmd/conf_phys.F90,v 1.3 2005/02/07 15:15:31 fairhead Exp $
3!
4!
5!
6
7  subroutine conf_phys(ok_journe, ok_mensuel, ok_instan, &
8 &                     if_ebil)
9   use init_print_control_mod, only: init_print_control
10   use print_control_mod, only: lunout
11   use IOIPSL, only: getin
12
13   implicit none
14
15   include "YOMCST.h"
16   include "clesphys.h"
17   include "compbl.h"
18
19! ok_journe:  sorties journalieres
20! ok_mensuel: sorties mensuelles
21! ok_instan:  sorties instantanees
22
23
24! Sortie:
25  logical,intent(out)  :: ok_journe, ok_mensuel, ok_instan       
26  integer,intent(out)  :: if_ebil
27
28
29
30!
31! Configuration de la "physique" de LMDZ a l'aide de la fonction
32! GETIN de IOIPSL
33!
34! LF 05/2001
35!
36!--- Ca lit le physiq.def ---
37
38       ! initialize print_control module variables
39       call init_print_control
40
41!******************* parametres anciennement lus dans gcm.def
42
43       ! do we read a startphy.nc file? (default: .true.)
44       startphy_file=.true.
45       CALL getin("startphy_file",startphy_file)
46
47!Config  Key  = cycle_diurne
48!Config  Desc = Cycle diurne
49!Config  Def  = y
50!Config  Help = Cette option permet d'eteidre le cycle diurne.
51!Config         Peut etre util pour accelerer le code !
52       cycle_diurne = .TRUE.       
53       call getin('cycle_diurne',cycle_diurne)
54
55!Config  Key  = soil_model
56!Config  Desc = Modele de sol
57!Config  Def  = y
58!Config  Help = Choix du modele de sol (Thermique ?)
59!Config         Option qui pourait un string afin de pouvoir
60!Config         plus de choix ! Ou meme une liste d'options !
61       soil_model = .true.
62       call getin('soil_model',soil_model)
63
64!Config  Key  = ok_orodr
65!Config  Desc = Oro drag
66!Config  Def  = y
67!Config  Help = GW drag orographie
68!Config         
69       ok_orodr = .false.
70       call getin('ok_orodr',ok_orodr)
71
72!Config  Key  =  ok_orolf
73!Config  Desc = Oro lift
74!Config  Def  = n
75!Config  Help = GW lift orographie (pas utilise)
76       ok_orolf = .false.
77       call getin('ok_orolf', ok_orolf)
78
79!Config  Key  = ok_gw_nonoro
80!Config  Desc = Gravity waves parameterization
81!Config  Def  = n
82!Config  Help = GW drag non-orographique
83       ok_gw_nonoro = .false.
84       call getin('ok_gw_nonoro',ok_gw_nonoro)
85
86!Config  Key  = nbapp_rad
87!Config  Desc = Frequence d'appel au rayonnement
88!Config  Def  = 12
89!Config  Help = Nombre  d'appels des routines de rayonnements
90!Config         par jour.
91       nbapp_rad = 12
92       call getin('nbapp_rad',nbapp_rad)
93       print*,"nbapp_rad",nbapp_rad
94!Config  Key  = nbapp_chim
95!Config  Desc = Frequence d'appel a la chimie
96!Config  Def  = 1
97!Config  Help = Nombre  d'appels des routines de chimie
98!Config         par jour.
99       nbapp_chim = 1
100       call getin('nbapp_chim',nbapp_chim)
101
102!Config  Key  = iflag_con
103!Config  Desc = Flag de convection
104!Config  Def  = 0
105!Config  Help = Flag  pour la convection les options suivantes existent :
106!Config         0 : ajsec simple (VENUS, TITAN)
107!Config         1 pour LMD,
108!Config         2 pour Tiedtke,
109!Config         3 pour CCM(NCAR) 
110       iflag_con = 0
111       call getin('iflag_con',iflag_con)
112
113!******************* fin parametres anciennement lus dans gcm.def
114
115!Config Key  = OK_journe
116!Config Desc = Pour des sorties journalieres
117!Config Def  = .false.
118!Config Help = Pour creer le fichier histday contenant les sorties
119!              journalieres
120!
121  ok_journe = .false.
122  call getin('OK_journe', ok_journe)
123!
124!Config Key  = OK_mensuel
125!Config Desc = Pour des sorties mensuelles
126!Config Def  = .false.
127!Config Help = Pour creer le fichier histmth contenant les sorties
128!              mensuelles
129!
130  ok_mensuel = .false.
131  call getin('OK_mensuel', ok_mensuel)
132!
133!Config Key  = OK_instan
134!Config Desc = Pour des sorties instantanees
135!Config Def  = .false.
136!Config Help = Pour creer le fichier histins contenant les sorties
137!              instantanees
138!
139  ok_instan = .false.
140  call getin('OK_instan', ok_instan)
141!
142!Config  Key  = ecritphy
143!Config  Desc = Frequence d'ecriture dans histmth et histins
144!Config  Def  = 1
145!Config  Help = frequence de l'ecriture du fichier histmth et histins
146!Config         en jours.
147!
148       ecriphy = 1.
149       call getin('ecritphy', ecriphy)
150!
151!
152!Config Key  = if_ebil
153!Config Desc = Niveau de sortie pour les diags bilan d'energie
154!Config Def  = 0
155!Config Help =
156!               
157!
158  if_ebil = 0
159  call getin('if_ebil', if_ebil)
160!!
161!! Constante solaire & Parametres orbitaux & taux gaz effet de serre BEG
162!!
163!Config Key  = R_ecc
164!Config Desc = Excentricite
165!Config Def  = 0.006787
166!Config Help =
167!               
168! VENUS
169! R_ecc = 0.006787
170  R_ecc   = 0.0
171  call getin('R_ecc', R_ecc)
172!!
173!Config Key  = R_peri
174!Config Desc = Equinoxe
175!Config Def  =
176!Config Help =
177!               
178! VENUS
179  R_peri = 0.
180  call getin('R_peri', R_peri)
181!!
182!Config Key  = R_incl
183!Config Desc = Inclinaison
184!Config Def  =
185!Config Help =
186!               
187! VENUS
188  R_incl = 0.0
189  call getin('R_incl', R_incl)
190!
191!Config Key  = solaire
192!Config Desc = Constante solaire en W/m2
193! VENUS
194!Config Def  = 2620.
195!Config Help =
196!
197  solaire = 2620.
198    call getin('solaire', solaire)
199!
200!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
201! PARAMETER FOR THE PLANETARY BOUNDARY LAYER AND SOIL
202!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
203!
204!Config Key  = iflag_pbl
205!Config Desc =
206!Config Def  = 1
207!Config Help =
208!
209! 2   = calculs Cd et K simples pour VENUS :
210!       parametres = z0, lmixmin, ksta (en dur: umin2,ric,cepdu2,karman)
211! 1   = calculs Cd et K issus LMDZ Terre
212!       parametres = ksta, ok_kzmin (et plein d'autres en dur...)
213! 6-9 = schema des thermiques Fred
214  iflag_pbl = 1
215  call getin('iflag_pbl',iflag_pbl)
216
217!
218!Config Key  = ksta
219!Config Desc =
220!Config Def  = 1.0e-7
221!Config Help =
222!
223  ksta = 1.0e-7
224  call getin('ksta',ksta)
225
226!
227!Config Key  = z0
228!Config Desc =
229!Config Def  = 1.0e-2
230!Config Help =
231!
232  z0 = 1.0e-2
233  call getin('z0',z0)
234
235!
236!Config Key  = lmixmin
237!Config Desc =
238!Config Def  = 35.
239!Config Help =
240!
241  lmixmin = 35.
242  call getin('lmixmin',lmixmin)
243
244!
245!Config Key  = ok_kzmin
246!Config Desc =
247!Config Def  = .false.
248!Config Help =
249!
250  ok_kzmin = .false.
251  call getin('ok_kzmin',ok_kzmin)
252
253  cclmain = .true.
254  call getin('clmain',cclmain)
255
256!Config Key  = iflag_ajs
257!Config Desc =
258!Config Def  = 0
259!Config Help =
260!
261  iflag_ajs = 0
262  call getin('iflag_ajs',iflag_ajs)
263
264!
265!Config Key  = inertie
266!Config Desc =
267!Config Def  = 2000.
268!Config Help =
269!
270  inertie = 2000.
271  call getin('inertie',inertie)
272!
273!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
274! PARAMETER FOR THE OUTPUT LEVELS
275!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
276!
277!Config Key  = lev_histins
278!Config Desc =
279!Config Def  = 0
280!Config Help =
281!
282  lev_histins = 0
283  call getin('lev_histins',lev_histins)
284
285!
286!Config Key  = lev_histday
287!Config Desc =
288!Config Def  = 1
289!Config Help =
290!
291  lev_histday = 1
292  call getin('lev_histday',lev_histday)
293
294!
295!Config Key  = lev_histmth
296!Config Desc =
297!Config Def  = 2
298!Config Help =
299!
300  lev_histmth = 2
301  call getin('lev_histmth',lev_histmth)
302
303
304!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
305! PARAMETER FOR THE TRACERS
306!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
307!
308!Config Key  = tr_scheme
309!Config Desc =
310!Config Def  = 0
311!Config Help =
312!
313! 0   = Nothing is done (passive tracers)
314! 1   = pseudo-chemistry with relaxation toward fixed profile
315!       See Marcq&Lebonnois 2013
316! 2   = surface emission
317!       For the moment, inspired from Mars version
318!       However, the variable 'source' could be used in physiq
319!       so the call to phytrac_emiss could be to initialise it.
320! 3   = Full chemistry and/or clouds => phytrac_chimie
321!       Need ok_chem or ok_cloud
322  tr_scheme = 0
323  call getin('tr_scheme',tr_scheme)
324
325!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
326!   PARAMETRES DE LA CHIMIE/NUAGE dans physiq.def
327!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
328
329!
330!Config Key  = reinit_trac
331!Config Desc = 
332!Config Def  = .FALSE.
333!Config Help =
334!
335  reinit_trac = .FALSE.
336  call getin('reinit_trac',reinit_trac)
337 
338!
339!Config Key  = ok_cloud
340!Config Desc = 
341!Config Def  = .FALSE.
342!Config Help =
343!
344  ok_cloud = .false.
345  call getin('ok_cloud',ok_cloud)
346
347!
348!Config Key  = cl_scheme
349!Config Desc =
350!Config Def  = 2
351!Config Help =
352!
353! 1   = Simple microphysics (Aurelien Stolzenbach's PhD)
354! 2   = Full microphysics (momentum scheme, Sabrina Guilbon's PhD)
355
356  cl_scheme = 2
357  call getin('cl_scheme',cl_scheme)
358
359!
360!Config Key  = ok_chem
361!Config Desc = 
362!Config Def  = .FALSE.
363!Config Help =
364!
365  ok_chem = .false.
366  call getin('ok_chem',ok_chem)
367
368  if (((tr_scheme.ne.3).and.(ok_chem.or.ok_cloud)).or. &
369      ((tr_scheme.eq.3).and.(.not.ok_chem.and..not.ok_cloud))) then
370    write(*,*) "Attention, incoherence :"
371    write(*,*) "tr_scheme=",tr_scheme," / ok_chem=",ok_chem, &
372                                     " / ok_cloud=",ok_cloud
373    write(*,*) "Verifier votre physiq.def"
374    stop
375  endif
376
377!
378!Config Key  = ok_sedim
379!Config Desc = 
380!Config Def  = .FALSE.
381!Config Help =
382!
383  ok_sedim = .false.
384  call getin('ok_sedim',ok_sedim)
385
386!
387!Config Key  = nb_mode
388!Config Desc = 
389!Config Def  = 0
390!Config Help =
391!
392  nb_mode = 0
393  call getin('nb_mode',nb_mode)
394 
395!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
396! PARAMETER FOR NLTE PHYSICS
397!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
398
399!
400!Config Key  = callnlte
401!Config Desc =
402!Config Def  = .false.
403!Config Help =
404!
405  callnlte = .false.
406  call getin('callnlte',callnlte)
407
408!
409!Config Key  = callnirco2
410!Config Desc =
411!Config Def  = .false.
412!
413  callnirco2 = .false.
414  call getin('callnirco2',callnirco2)
415
416!
417!Config Key  = nircorr
418!Config Desc =
419!Config Def  = 0
420!Config Help =
421!
422  nircorr = 0
423  call getin('nircorr',nircorr)
424
425!
426!Config Key  = callthermos
427!Config Desc =
428!Config Def  = .false.
429!Config Help =
430!
431  callthermos = .false.
432  call getin('callthermos',callthermos)
433
434!
435!Config Key  = nltemodel
436!Config Desc =
437!Config Def  = 0
438!Config Help =
439!
440  nltemodel = 0
441  call getin('nltemodel',nltemodel)
442
443!
444!Config Key  = solvarmod
445!Config Desc =
446!Config Def  = 1
447!Config Help =
448!
449  solvarmod = 1
450  call getin('solvarmod',solvarmod)
451
452!
453!Config Key  = solarcondate
454!Config Desc =
455!Config Def  = 1993.4  ## Average solar cycle condition
456!Config Help =
457!
458  solarcondate = 1993.4
459  call getin('solarcondate',solarcondate)
460
461!
462!Config Key  = euveff
463!Config Desc =
464!Config Def  = 0.21
465!Config Help =
466!
467  euveff = 0.21
468  call getin('euveff',euveff)
469
470!
471!
472!Config Key  =
473!Config Desc = 
474!Config Def  =
475!Config Help =
476!
477!   =
478!  call getin('',)
479!
480!
481!
482!
483
484  write(lunout,*)' ##############################################'
485  write(lunout,*)' Configuration des parametres de la physique: '
486  write(lunout,*)' cycle_diurne = ', cycle_diurne
487  write(lunout,*)' soil_model = ', soil_model
488  write(lunout,*)' ok_orodr = ', ok_orodr
489  write(lunout,*)' ok_orolf = ', ok_orolf
490  write(lunout,*)' ok_gw_nonoro = ', ok_gw_nonoro
491  write(lunout,*)' nbapp_rad = ', nbapp_rad
492  write(lunout,*)' nbapp_chim = ', nbapp_chim
493  write(lunout,*)' iflag_con = ', iflag_con
494  write(lunout,*)' Sortie journaliere = ', ok_journe
495  write(lunout,*)' Sortie mensuelle = ', ok_mensuel
496  write(lunout,*)' Sortie instantanee = ', ok_instan
497  write(lunout,*)' frequence sorties = ', ecriphy 
498  write(lunout,*)' Sortie bilan d''energie, if_ebil =', if_ebil
499  write(lunout,*)' Excentricite = ',R_ecc
500  write(lunout,*)' Equinoxe = ',R_peri
501  write(lunout,*)' Inclinaison =',R_incl
502  write(lunout,*)' tr_scheme = ', tr_scheme
503  write(lunout,*)' iflag_pbl = ', iflag_pbl
504  write(lunout,*)' z0 = ',z0
505  write(lunout,*)' lmixmin = ',lmixmin
506  write(lunout,*)' ksta = ',ksta
507  write(lunout,*)' ok_kzmin = ',ok_kzmin
508  write(lunout,*)' inertie = ', inertie
509  write(lunout,*)' clmain = ',cclmain
510  write(lunout,*)' iflag_ajs = ', iflag_ajs
511  write(lunout,*)' lev_histins = ',lev_histins
512  write(lunout,*)' lev_histday = ',lev_histday
513  write(lunout,*)' lev_histmth = ',lev_histmth
514  write(lunout,*)' reinit_trac = ',reinit_trac
515  write(lunout,*)' ok_cloud = ',ok_cloud
516  write(lunout,*)' cl_scheme = ',cl_scheme
517  write(lunout,*)' ok_chem = ',ok_chem
518  write(lunout,*)' ok_sedim = ',ok_sedim
519  write(lunout,*)' nb_mode = ',nb_mode
520  write(lunout,*)' callnlte = ',callnlte
521  write(lunout,*)' nltemodel = ',nltemodel
522  write(lunout,*)' callnirco2 = ',callnirco2
523  write(lunout,*)' nircorr = ',nircorr
524  write(lunout,*)' callthermos = ',callthermos
525  write(lunout,*)' solvarmod = ',solvarmod
526  write(lunout,*)' solarcondate = ',solarcondate
527  write(lunout,*)' euveff = ',euveff
528
529  end subroutine conf_phys
530
Note: See TracBrowser for help on using the repository browser.