source: LMDZ5/trunk/libf/phylmd/dyn1d/1D_decl_cases.h @ 2592

Last change on this file since 2592 was 2373, checked in by jyg, 9 years ago

From MPL:
Correction of some missing initializations in
dyn1D and of two 1D case bugs.

File size: 10.6 KB
RevLine 
[2117]1#include "netcdf.inc"
2
[2017]3! Declarations specifiques au cas Toga
4        character*80 :: fich_toga
5!        integer nlev_prof
6!        parameter (nlev_prof = 41)
7        integer nlev_toga, nt_toga
8        parameter (nlev_toga=41, nt_toga=480)
9        integer year_ini_toga, day_ini_toga, mth_ini_toga
10        real day_ju_ini_toga   ! Julian day of toga coare first day
11        parameter (year_ini_toga=1992) 
12        parameter (mth_ini_toga=11)
13        parameter (day_ini_toga=1)  !  1erNov1992
14        real dt_toga
15        parameter (dt_toga=6.*3600.)
16!!
17        integer year_print, month_print, day_print
18        real    sec_print
19!!
20        real ts_toga(nt_toga)
21        real plev_toga(nlev_toga,nt_toga),w_toga(nlev_toga,nt_toga)
22        real t_toga(nlev_toga,nt_toga),q_toga(nlev_toga,nt_toga)
23        real u_toga(nlev_toga,nt_toga),v_toga(nlev_toga,nt_toga)
24        real ht_toga(nlev_toga,nt_toga),vt_toga(nlev_toga,nt_toga)
25        real hq_toga(nlev_toga,nt_toga),vq_toga(nlev_toga,nt_toga)
26
27        real ts_prof
28        real plev_prof(nlev_toga),w_prof(nlev_toga)
29        real t_prof(nlev_toga),q_prof(nlev_toga)
30        real u_prof(nlev_toga),v_prof(nlev_toga)
31        real ht_prof(nlev_toga),vt_prof(nlev_toga)
32        real hq_prof(nlev_toga),vq_prof(nlev_toga)
33
34        real w_mod(llm), t_mod(llm),q_mod(llm)
35        real u_mod(llm),v_mod(llm), ht_mod(llm),vt_mod(llm)
36        real hq_mod(llm),vq_mod(llm),qv_mod(llm),ql_mod(llm),qt_mod(llm)
[2126]37        real th_mod(llm)
[2017]38
39        real ts_cur
40        common /sst_forcing/ts_cur ! also in read_tsurf1d.F
41!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
42! Declarations specifiques au cas RICO
43        character*80 :: fich_rico
44        integer nlev_rico
45
46        parameter (nlev_rico=81)
47        real ts_rico,ps_rico
48        real w_rico(llm)
49        real t_rico(llm),q_rico(llm)
50        real u_rico(llm),v_rico(llm)
51        real dth_rico(llm)
52        real dqh_rico(llm)
53!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
54! Declarations specifiques au cas TWPice
55        character*80 :: fich_twpice
56        integer nlev_twpi, nt_twpi
57        parameter (nlev_twpi=40, nt_twpi=215)
58        integer year_ini_twpi, day_ini_twpi, mth_ini_twpi
59        real heure_ini_twpi
60        real day_ju_ini_twpi   ! Julian day of twpice first day
61        parameter (year_ini_twpi=2006) 
62        parameter (mth_ini_twpi=1)
63        parameter (day_ini_twpi=17)  ! 17 = 17Jan2006
64        parameter (heure_ini_twpi=10800.) !3h en secondes
65        real dt_twpi
66        parameter (dt_twpi=3.*3600.)
67
68        real ts_twpi(nt_twpi)
69        real plev_twpi(nlev_twpi,nt_twpi),w_twpi(nlev_twpi,nt_twpi)
70        real t_twpi(nlev_twpi,nt_twpi),q_twpi(nlev_twpi,nt_twpi)
71        real u_twpi(nlev_twpi,nt_twpi),v_twpi(nlev_twpi,nt_twpi)
72        real ht_twpi(nlev_twpi,nt_twpi),vt_twpi(nlev_twpi,nt_twpi)
73        real hq_twpi(nlev_twpi,nt_twpi),vq_twpi(nlev_twpi,nt_twpi)
74
75        real ts_proftwp
76        real plev_proftwp(nlev_twpi),w_proftwp(nlev_twpi)
77        real t_proftwp(nlev_twpi),q_proftwp(nlev_twpi)
78        real u_proftwp(nlev_twpi),v_proftwp(nlev_twpi)
79        real ht_proftwp(nlev_twpi),vt_proftwp(nlev_twpi)
80        real hq_proftwp(nlev_twpi),vq_proftwp(nlev_twpi)
81
82
83
84!Declarations specifiques au cas FIRE
85        character*80 :: fich_fire
86        integer nlev_fire, nt_fire
87        parameter (nlev_fire=120, nt_fire=1) 
88        integer year_ini_fire, day_ini_fire, mth_ini_fire
89        real heure_ini_fire
90        parameter (year_ini_fire=1987) 
91        parameter (mth_ini_fire=7)
92        parameter (day_ini_fire=14)  ! 14 = 14Juil1987
93        parameter (heure_ini_fire=0.) !0h en secondes
94
95!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
[2126]96!Declarations specifiques au cas DICE     (MPL 02072013)
97        character*80 :: fich_dice
98        integer nlev_dice, nt_dice
99        parameter (nlev_dice=70, nt_dice=145) 
100        integer year_ini_dice, day_ini_dice, mth_ini_dice
101        real heure_ini_dice
102        real day_ju_ini_dice   ! Julian day of dice first day
103        parameter (year_ini_dice=1999) 
104        parameter (mth_ini_dice=10)
105        parameter (day_ini_dice=23)  ! 23 = 23 october 1999
106        parameter (heure_ini_dice=68400.) !19UTC en secondes
107        real dt_dice
108        parameter (dt_dice=0.5*3600.) ! 1 forcage ttes les demi-heures
109
110!profils initiaux:
111        real plev_dice(nlev_dice)
112       
113        real zz_dice(nlev_dice)
114        real th_dice(nlev_dice),qv_dice(nlev_dice)
115        real u_dice(nlev_dice), v_dice(nlev_dice),o3_dice(nlev_dice)
116        real ht_dice(nlev_dice,nt_dice)
117        real hq_dice(nlev_dice,nt_dice), hu_dice(nlev_dice,nt_dice)
118        real hv_dice(nlev_dice,nt_dice)
119        real w_dice(nlev_dice,nt_dice),omega_dice(nlev_dice,nt_dice)
120        real o3_mod(llm),hu_mod(llm),hv_mod(llm)
121        real th_dicei(nlev_dice),qv_dicei(nlev_dice)
122        real u_dicei(nlev_dice), v_dicei(nlev_dice),o3_dicei(nlev_dice)
123        real ht_dicei(nlev_dice)
124        real hq_dicei(nlev_dice), hu_dicei(nlev_dice)
125        real hv_dicei(nlev_dice)
126        real w_dicei(nlev_dice),omega_dicei(nlev_dice)
127
128       
129!forcings
130        real shf_dice(nt_dice),lhf_dice(nt_dice)
131        real lwup_dice(nt_dice),swup_dice(nt_dice)
132        real tg_dice(nt_dice),ustar_dice(nt_dice),psurf_dice(nt_dice)
133        real ug_dice(nt_dice),vg_dice(nt_dice)
134
135        real shf_prof,lhf_prof,lwup_prof,swup_prof,tg_prof
136        real ustar_prof,psurf_prof,cdrag
137        real ht_profd(nlev_dice),hq_profd(nlev_dice),hu_profd(nlev_dice)
138        real hv_profd(nlev_dice),w_profd(nlev_dice)
139        real omega_profd(nlev_dice),ug_profd,vg_profd
140
141!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
[2017]142! Declarations specifiques au cas GCSSold
143        character*80 :: fich_gcssold_ctl
144        character*80 :: fich_gcssold_dat
145        real  ht_gcssold(llm),hq_gcssold(llm),hw_gcssold(llm)
146        real  hu_gcssold(llm)
147        real  hv_gcssold(llm)
148        real  hthturb_gcssold(llm)
149        real  hqturb_gcssold(llm)
150        real  Ts_gcssold
151        real  dtime_frcg
152        logical :: Turb_fcg_gcssold
153
[2019]154        common /turb_forcing/                                                   &
155     &  dtime_frcg,hthturb_gcssold, hqturb_gcssold,Turb_fcg_gcssold
[2017]156!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
157! Declarations specifiques au cas Arm_cu
158        character*80 :: fich_armcu
159
160
161        integer nlev_armcu, nt_armcu
162        parameter (nlev_armcu=40, nt_armcu=31)
163        integer year_ini_armcu, day_ini_armcu, mth_ini_armcu
164        real  heure_ini_armcu
165        real day_ju_ini_armcu                                ! Julian day of armcu case first day
166        parameter (year_ini_armcu=1997) 
167        parameter (mth_ini_armcu=6)
168        parameter (day_ini_armcu=21)  ! 172 = 21 juin 1997
169        parameter (heure_ini_armcu=41400)   ! 11:30 en secondes
170        real dt_armcu
171        parameter (dt_armcu=1.*1800.)   ! forcages donnes ttes les demi-heures par ifa_armcu.txt
172        real sens_armcu(nt_armcu),flat_armcu(nt_armcu)
173        real adv_theta_armcu(nt_armcu),rad_theta_armcu(nt_armcu)
174        real adv_qt_armcu(nt_armcu)
175        real theta_mod(llm),rv_mod(llm),play_mod(llm)
176! profc comme "profil armcu"
177       
178! forcages interpoles dans le temps
179        real adv_theta_prof,rad_theta_prof,adv_qt_prof
180        real sens_prof,flat_prof,fact
181!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
182! declarations specifiques au cas Sandu
183        character*80 :: fich_sandu
184!        integer nlev_prof
185!        parameter (nlev_prof = 41)
186        integer nlev_sandu, nt_sandu
187        parameter (nlev_sandu=87, nt_sandu=13)
188        integer year_ini_sandu, day_ini_sandu, mth_ini_sandu
189        real day_ju_ini_sandu                                ! Julian day of sandu case first day
190        parameter (year_ini_sandu=2006)
191        parameter (mth_ini_sandu=7)
192        parameter (day_ini_sandu=15)  ! 196 = 15 juillet 2006
193        real dt_sandu, tau_sandu
194        logical  :: trouve_700=.true.
195        parameter (dt_sandu=6.*3600.)   ! forcages donnes ttes les 6 heures par ifa_sandu.txt
196        parameter (tau_sandu=3600.)  ! temps de relaxation u,v,thetal,qt vers profil init et au dessus 700hPa
197!!
198        real ts_sandu(nt_sandu)
199! profs comme "profil sandu"
200        real plev_profs(nlev_sandu)
201        real t_profs(nlev_sandu),thl_profs(nlev_sandu)
202        real q_profs(nlev_sandu)
203        real u_profs(nlev_sandu),v_profs(nlev_sandu),w_profs(nlev_sandu)
204        real omega_profs(nlev_sandu),o3mmr_profs(nlev_sandu)
205
206        real, dimension(llm) :: relax_u,relax_v,relax_thl
207        real, dimension(llm,2) :: relax_q
208
209        real thl_mod(llm),omega_mod(llm),o3mmr_mod(llm),tke_mod(llm)
210!vertical advection computation
211        real d_t_z(llm), d_q_z(llm)
212        real d_t_dyn_z(llm), d_q_dyn_z(llm)
[2126]213        real d_u_z(llm),d_v_z(llm)
214        real d_u_dyn(llm),d_v_dyn(llm)
215        real d_u_dyn_z(llm),d_v_dyn_z(llm)
216        real d_u_adv(llm),d_v_adv(llm)
[2017]217        real zz(llm)
218        real zfact
219!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
220! Declarations specifiques au cas Astex
221        character*80 :: fich_astex
222        integer nlev_astex, nt_astex
223        parameter (nlev_astex=34, nt_astex=49)
224        integer year_ini_astex, day_ini_astex, mth_ini_astex
225        real day_ju_ini_astex                                ! Julian day of astex case first day
226        parameter (year_ini_astex=1992)
227        parameter (mth_ini_astex=6)
228        parameter (day_ini_astex=13)  ! 165 = 13 juin 1992
229        real dt_astex
230        parameter (dt_astex=3600.)    ! forcages donnes ttes les heures par ifa_astex.txt
231        real ts_astex(nt_astex),div_astex(nt_astex),ug_astex(nt_astex)
232        real vg_astex(nt_astex),ufa_astex(nt_astex),vfa_astex(nt_astex)
233        real div_prof,ug_prof,vg_prof,ufa_prof,vfa_prof
234! profa comme "profil astex"
235        real plev_profa(nlev_astex)
236        real t_profa(nlev_astex),thl_profa(nlev_astex)
237        real qv_profa(nlev_astex),ql_profa(nlev_astex)
238        real qt_profa(nlev_astex),o3mmr_profa(nlev_astex)
239        real u_profa(nlev_astex),v_profa(nlev_astex),w_profa(nlev_astex)
240        real tke_profa(nlev_astex)
[2191]241
242!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
243!Declarations specifiques au cas standard
244
245        real w_mod_cas(llm), t_mod_cas(llm),q_mod_cas(llm)
246        real ug_mod_cas(llm),vg_mod_cas(llm)
247        real u_mod_cas(llm),v_mod_cas(llm)
248        real ht_mod_cas(llm),vt_mod_cas(llm),dt_mod_cas(llm),dtrad_mod_cas(llm)
249        real hq_mod_cas(llm),vq_mod_cas(llm),dq_mod_cas(llm)
250        real hu_mod_cas(llm),vu_mod_cas(llm),du_mod_cas(llm)
251        real hv_mod_cas(llm),vv_mod_cas(llm),dv_mod_cas(llm)
[2332]252        integer day_ini_cas
[2017]253!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
254
Note: See TracBrowser for help on using the repository browser.