source: codes/icosagcm/trunk/param_sets/make_rundefs.sh @ 194

Last change on this file since 194 was 194, checked in by dubos, 10 years ago

Added param_sets/make_rundefs.sh

  • Property svn:executable set to *
File size: 8.1 KB
Line 
1#!/bin/bash
2
3function print()
4{
5    # prints one comment line followed by any number of "key = value" lines
6    echo "# $1 : $2 (default=$3)"
7    shift; shift; shift;
8    while (($# > 0)) ; do
9        echo "$1 = $2"
10        shift; shift;
11    done
12    echo
13}
14
15################################### Planet #######################################
16 
17function radius { print 'Planetary radius' real 37122E6 radius $1 
18}
19function g      { print Gravity real 9.80616 g $1 
20}
21function omega { print 'Planetary rotation rate' real 7.292E-5 omega $1 
22}
23function kappa { print 'kappa=Rd/cpp' real 0.2857143 kappa $1 
24}
25function cpp     { print 'Heat capacity at constant pressure' real 1004.70885 cpp $1
26}
27function preff { print 'Reference pressure' real 101325 preff $1 
28}
29function scale_factor { print 'Scale factor for small planet experiment' real 1. scale_factor $1 
30}
31
32##################################### Mesh #####################################
33
34function nbp   { print 'Number of subdivisions on a main triangle' integer 40 nbp $1 
35}
36function split { print 'Sub splitting of main rhombus' integer 1 nsplit_i $1 nsplit_j $2 
37}
38function llm   { print 'Number of vertical layers' integer 19 llm $1 
39}
40function disvert { print 'Vertical grid' '[std|ncar|ncar30l]' std disvert $1 
41}
42function ncar_dz { print 'Model layer thickness in m, used if disvert=ncar' real 300 ncar_dz $1
43}
44function optim_it { print 'Mesh optimisation : number of iterations' integer 0 optim_it $1 
45}
46
47################################# Numerics ###################################
48
49function scheme { print 'Time-stepping scheme' '[euler|leapfrog_matsuno|runge_kutta]' runge_kutta scheme $1 
50}
51function time_step { print 'Time step in s' real 480 dt $1 
52}
53function matsuno { print 'Matsuno period' integer 5 matsuno_period $1 
54}
55function itau_adv { print 'Advection called every itau_adv time steps' integer 2 itau_adv $1 
56}
57function nqtot { print 'Number of tracers' integer 1 nqtot $1 
58}
59function caldyn { print 'Equations solved' '[gcm|adv]' gcm caldyn $1 
60}
61function caldyn_conserv { print 'Discretization of Coriolis term' '[energy|enstophy]' enstrophy caldyn_conserv $1 
62}
63function caldyn_eta { print 'Vertical coordinate' '[eta_mass|eta_lag]' mass caldyn_eta $1 
64}
65function boussinesq { print 'Boussinesq approximation, requires eta_lag' '[.FALSE.|.TRUE.]' .FALSE. boussinesq $1
66}
67############################### Time and output ###############################
68
69function time_style() { print 'Time style' '[none|lmd]' lmd time_style $1 
70}
71function ndays() { print 'Number of days' integer ?? ndays $1 
72}
73function run_length() { print 'Run length in s' real ?? run_length $1 
74}
75function day_step { print 'Number of time steps per day' integer ?? day_step $1 
76}
77function write_period { print 'Interval in s between two outputs' integer ?? write_period $1 
78}
79function out_pressure_level { print 'Pressure level to which interpolate T' real 0 out_pression_level $1
80}
81
82################################ Physics ######################################
83
84function etat0 { 
85    OPTS=$(printf '\n#   [jablonowsky06|academic|dcmip[1-4]|heldsz|dcmip2_schaer_noshear|dcmip3]')
86    print 'Initial state' "$OPTS" jablonowsky06 etat0 $1 
87}
88function dissip
89{
90    print 'Dissipation time for grad(div)' real 5000 tau_graddiv $1
91    print 'Exponent of grad(div) disspation' integer 1 nitergdiv $2
92    print 'Dissipation time for curl(curl)' real 5000 tau_gradrot $3
93    print 'Exponent of curl(curl) disspation' integer 1 nitergrot $2
94    print 'Dissipation time for div(grad)' real 5000 tau_divgrad $3
95    print 'Exponent of div(grad) disspation' integer 1 niterdivgrad $2
96}
97function guided_type { print 'Type of guiding terms' '[none|dcmip1]' none guided_type $1 
98}
99
100function physics { print 'Physics package' '[automatic|dcmip]' automatic physics $1
101}
102
103#################################### DCMIP #################################
104function dcmip1_def()
105{
106    OPTS=$(printf '\n#    [const|slotted_cyl|cos_bell|dbl_cos_bell_q1|dbl_cos_bell_q2|complement|hadley|dcmip11]')
107    print 'DCMIP 1.1 advection test, initial tracer field' "$OPTS" cos_bell dcmip1_shape $1
108    print 'DCMIP 1.1 advection test, wind field' '[solid|deform|hadley]' deform dcmip1_shape $2
109}
110function dcmip_refs()
111{
112    print 'Reference temperature T0 for DCMIP test cases' real 300 ncar_T0 $1
113    print 'Reference pressure p0 for DCMIP test cases, used by disvert if disver=ncar' real 1e5 ncar_p0 $2
114    print 'Exponent for B(eta), used by disvert if disvert=ncar' integer 1 ncar_disvert_c $3
115}
116function dcmip_physics()
117{
118    physics dcmip
119    print 'DCMIP physics' '[0|1]' 1 dcmip_physics $1
120}
121function dcmip4_testcase { print 'DCMIP 4 Test case' '[1|2]' 1 dcmip4_testcase $1 
122}
123
124####################### Functions generating parameter files ####################
125
126function params {
127    # executes any number of "command arg" commands
128    while (($# > 0)) ; do
129        $1 $2
130        shift; shift;
131    done
132}
133
134function group { 
135    # prints one separation line then executes any number of "command arg" commands
136    echo
137    echo "#---------------- $1 ----------------"
138    echo
139    shift
140    params $*
141}
142
143function williamson91()
144{
145    group 'Mesh' nbp 40 llm 1 optim_it 100 ; split 2 2
146    group 'Numerics' caldyn gcm scheme runge_kutta time_step 480 caldyn_conserv energy
147    group 'Time and output' out_pressure_level 85000 write_period 21600 run_length 864000
148    group 'Physical parameters' radius 6.37122e6 g 9.80616 caldyn_eta eta_lag boussinesq .TRUE. etat0 williamson91.6
149    dissip 5000 2 5000 2 5000 2   
150}
151
152function held_suarez()
153{
154    group 'Mesh' nbp 40 llm 19 disvert std optim_it 1000 ; split 2 2
155    group 'Numerics' scheme runge_kutta itau_adv 1 day_step 180 caldyn_conserv energy
156    group 'Time' time_style lmd ndays 1200 write_period 86400
157    group 'Planet' scale_factor 1 radius 6.371e6 g 9.8 omega 7.292e-5 kappa 0.2857143 cpp 1004 preff 1e5
158    group 'Physical parameters' etat0 held_suarez nqtot 1
159    dissip 50000 2 50000 2 50000 2
160}
161
162function const_dcmip
163{
164    group 'Planet' radius 6.37122e6 g 9.80616 kappa 0.2857143 cpp 1004.5 preff 1e5 omega $1 
165    group 'Constants' ; dcmip_refs 300 1e5 1
166}
167
168function dcmip11
169{
170    echo 'INCLUDEDEF = const.def'
171    group 'Mesh' nbp 80 llm 60 disvert ncar ncar_dz 200 optim_it 100 ; split 2 2
172    group 'Numerics' caldyn adv time_step 180 caldyn_conserv energy
173    group 'Time' run_length 1036800 write_period 86400
174    group 'Physical parameters' guided_type dcmip1 ; dcmip1_def dcmip11 deform
175}
176
177function dcmip21
178{
179    echo 'INCLUDEDEF = const.def'
180    group 'Mesh' nbp 64 llm 60 disvert ncar ncar_dz 500 optim_it 100 ; split 2 2
181    group 'Numerics' time_step 300 caldyn_conserv energy
182    dissip 1800 1 1800 2 1800 2
183    group 'Time' run_length 3.6e6 write_period 50000
184    group 'Physical parameters' scale_factor 500 guided_type dcmip1 nqtot 1 etat0 dcmip2_schaer_noshear
185}
186
187function dcmip3
188{
189    const_dcmip 0
190    group 'Mesh' nbp 80 llm 10 disvert ncar ncar_dz 1000 optim_it 100 ; split 2 2
191    group 'Numerics' caldyn gcm scheme runge_kutta time_step 240
192    dissip 1800 1 1800 2 1800 2
193    group 'Time' run_length 4.5e5 write_period 12500
194    group 'Physical parameters' omega 0 scale_factor 125 nqtot 1 etat0 dcmip3
195}
196
197function dcmip42
198{
199    echo 'INCLUDEDEF = const.def'
200    group 'Mesh' nbp 80 llm 30 disvert ncar30l optim_it 100 ; split 2 2
201    group 'Numerics' caldyn gcm scheme runge_kutta time_step 240
202    dissip 1800 1 1800 2 1800 2
203    group 'Time' run_length 3.6e6 write_period 21600
204    group 'Physical parameters' scale_factor 1 nqtot 2 etat0 dcmip4 dcmip4_testcase 2 dcmip_physics 1
205}
206
207function dcmip5
208{
209    echo 'INCLUDEDEF = const.def'
210    group 'Mesh' nbp 64 llm 30 disvert ncar30l optim_it 1000 ; split 2 2
211    group 'Numerics' caldyn gcm scheme runge_kutta time_step 300
212    dissip 10800 1 10800 2 10800 2
213    group 'Time' run_length 864000 write_period 7200
214    group 'Physical parameters' scale_factor 1 nqtot 1 etat0 dcmip5 dcmip_physics 0
215}
216   
217########## Main program : generate all *.def files in param_sets ##############
218
219function mkcd { cd $ROOT ; mkdir -p $1 ; cd $1
220}
221
222set -o errexit
223ROOT=$PWD
224
225mkcd climate/Held_Suarez
226held_suarez > run.def
227
228mkcd shallow_water/williamson91
229williamson91 > run6.def
230
231mkcd dcmip2012
232const_dcmip 7.292e-5 > const.def
233dcmip11 > run11.def
234dcmip21 > run21.def
235dcmip3 > run3.def
236dcmip42 > run42.def
237dcmip5 > run5.def
Note: See TracBrowser for help on using the repository browser.