forked from NOAA-PSL/da_scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconfig.C192.hyb4denvar2
executable file
·519 lines (483 loc) · 17.2 KB
/
config.C192.hyb4denvar2
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
echo "running on $machine using $NODES nodes"
export ndates_job=1 # number of DA cycles to run in one job submission
# resolution of control and ensmemble.
export RES=192
export RES_CTL=384
# Penney 2014 Hybrid Gain algorithm with beta_1=1.0
# beta_2=alpha and beta_3=0 in eqn 6
# (https://journals.ametsoc.org/doi/10.1175/MWR-D-13-00131.1)
export alpha=250 # percentage of 3dvar increment (beta_2*1000)
export beta=1000 # percentage of enkf increment (*10)
export hybgain='true' # set to true for hybrid gain 3DVar/EnKF
export exptname="C${RES}_hyb4denvar2"
# for 'passive' or 'replay' cycling of control fcst
# control forecast files have 'control2' suffix, instead of 'control'
# GSI observer will be run on 'control2' forecast
# this is for diagnostic purposes (to get GSI diagnostic files)
#export replay_controlfcst='true'
# for dual-res hybrid, set hybgain=false, replay_controlfcst=false
export hybgain='false' # set to true for hybrid gain 3DVar/EnKF
export replay_controlfcst='false'
# determine if writing or calculating increment
export DO_CALC_INCREMENT="NO" # always YES if hybgain="true"
export cores=`expr $NODES \* $corespernode`
## check that value of NODES is consistent with PBS_NP on theia.
#if [ "$machine" == 'theia' ]; then
# if [ $PBS_NP -ne $cores ]; then
# echo "NODES = ${NODES} PBS_NP = ${PBS_NP} cores = ${cores}"
# echo "NODES set incorrectly in preamble"
# exit 1
# fi
#fi
#export KMP_AFFINITY=disabled
export fg_gfs="run_ens_fv3.sh"
export ensda="enkf_run.sh"
export rungsi='run_gsi_4densvar.sh'
export rungfs='run_fv3.sh' # ensemble forecast
export recenter_anal="true" # recenter enkf analysis around GSI hybrid 4DEnVar analysis
export do_cleanup='true' # if true, create tar files, delete *mem* files.
export controlanal='true' # use gsi hybrid (if false, pure enkf is used)
export controlfcst='true' # if true, run dual-res setup with single high-res control
export cleanup_fg='true'
export cleanup_ensmean='true'
export cleanup_anal='true'
export cleanup_controlanl='true'
export cleanup_observer='true'
export resubmit='true'
export replay_run_observer='true' # run observer on replay forecast
# python script checkdate.py used to check
# YYYYMMDDHH analysis date string to see if
# full ensemble should be saved to HPSS (returns 0 if
# HPSS save should be done)
if [ $machine == "orion" ]; then
export save_hpss_subset="false" # save a subset of data each analysis time to HPSS
export save_hpss="false"
else
export save_hpss_subset="true" # save a subset of data each analysis time to HPSS
export save_hpss="true"
fi
export run_long_fcst="false" # spawn a longer control forecast at 00 UTC
export ensmean_restart='false'
#export copy_history_files=1 # save pressure level history files (and compute ens mean)
export skip_to_fcst="false" # skip to forecast step
# override values from above for debugging.
#export cleanup_ensmean='false'
#export cleanup_observer='false'
#export cleanup_controlanl='false'
#export cleanup_anal='false'
#export recenter_anal="false"
#export cleanup_fg='false'
#export resubmit='false'
#export do_cleanup='false'
#export save_hpss_subset="false" # save a subset of data each analysis time to HPSS
#export skip_to_fcst="true" # skip to forecast step
source $MODULESHOME/init/sh
if [ "$machine" == 'hera' ]; then
export basedir=/scratch2/BMC/gsienkf/${USER}
export datadir=$basedir
export hsidir="/ESRL/BMC/gsienkf/2year/whitaker/${exptname}"
#export obs_datapath=/scratch2/BMC/gsienkf/whitaker/gdas1bufr
export obs_datapath=/scratch1/NCEPDEV/global/glopara/dump
module purge
module load intel/18.0.5.274
module load impi/2018.0.4
#module use -a /scratch1/NCEPDEV/nems/emc.nemspara/soft/modulefiles
#module load netcdf_parallel/4.7.4
#module load hdf5_parallel/1.10.6.release
module use -a /scratch1/NCEPDEV/global/gwv/lp/lib/modulefiles
module load netcdfp/4.7.4
#module load esmflocal/8.0.1.08bs
module use -a /scratch1/NCEPDEV/nems/emc.nemspara/soft/modulefiles
module load hdf5_parallel/1.10.6
#module load netcdf_parallel/4.7.4
elif [ "$machine" == 'orion' ]; then
export basedir=/work/noaa/gsienkf/${USER}
export datadir=$basedir
export hsidir="/ESRL/BMC/gsienkf/2year/whitaker/${exptname}"
#export obs_datapath=/scratch2/BMC/gsienkf/whitaker/gdas1bufr
export obs_datapath=${basedir}/dumps
ulimit -s unlimited
source $MODULESHOME/init/sh
module purge
module load intel/2018.4
module load impi/2018.4
module load mkl/2018.4
module load netcdf/4.7.2-parallel
module load hdf5/1.10.5-parallel
module load python
export PYTHONPATH=/home/jwhitake/.local/lib/python3.7/site-packages
export HDF5_DISABLE_VERSION_CHECK=1
elif [ "$machine" == 'gaea' ]; then
export basedir=/lustre/f2/dev/${USER}
export datadir=/lustre/f2/scratch/${USER}
export hsidir="/ESRL/BMC/gsienkf/2year/whitaker/${exptname}"
#export hsidir="/3year/NCEPDEV/GEFSRR/${exptname}"
export obs_datapath=/lustre/f2/dev/Jeffrey.S.Whitaker/dumps
else
echo "machine must be 'hera', 'orion' or 'gaea' got $machine"
exit 1
fi
export datapath="${datadir}/${exptname}"
export logdir="${datadir}/logs/${exptname}"
export corrlengthnh=1250
export corrlengthtr=1250
export corrlengthsh=1250
export lnsigcutoffnh=1.5
export lnsigcutofftr=1.5
export lnsigcutoffsh=1.5
export lnsigcutoffpsnh=1.5
export lnsigcutoffpstr=1.5
export lnsigcutoffpssh=1.5
export lnsigcutoffsatnh=1.5
export lnsigcutoffsattr=1.5
export lnsigcutoffsatsh=1.5
export obtimelnh=1.e30
export obtimeltr=1.e30
export obtimelsh=1.e30
# model physics parameters.
export psautco="0.0008,0.0005"
export prautco="0.00015,0.00015"
#export imp_physics=99 # zhao-carr
export imp_physics=11 # GFDL MP
export NOSAT="NO" # if yes, no radiances assimilated
export NOCONV="NO"
# model NSST parameters contained within nstf_name in FV3 namelist
# (comment out to get default - no NSST)
# nstf_name(1) : NST_MODEL (NSST Model) : 0 = OFF, 1 = ON but uncoupled, 2 = ON and coupled
export DONST="YES"
export NST_MODEL=2
# nstf_name(2) : NST_SPINUP : 0 = OFF, 1 = ON,
export NST_SPINUP=0 # (will be set to 1 if fg_only=='true')
# nstf_name(3) : NST_RESV (Reserved, NSST Analysis) : 0 = OFF, 1 = ON
export NST_RESV=0
# nstf_name(4,5) : ZSEA1, ZSEA2 the two depths to apply vertical average (bias correction)
export ZSEA1=0
export ZSEA2=0
export NSTINFO=0 # number of elements added in obs. data array (default = 0)
export NST_GSI=3 # default 0: No NST info at all;
# 1: Input NST info but not used in GSI;
# 2: Input NST info, used in CRTM simulation, no Tr analysis
# 3: Input NST info, used in both CRTM simulation and Tr analysis
#export NST_GSI=0 # No NST
if [ $NST_GSI -gt 0 ]; then export NSTINFO=4; fi
if [ $NOSAT == "YES" ]; then export NST_GSI=0; fi # don't try to do NST in GSI without satellite data
if [ $imp_physics == "11" ]; then
export ncld=5
export nwat=6
export cal_pre=F
export dnats=1
export do_sat_adj=".true."
export random_clds=".false."
export cnvcld=".false."
export lgfdlmprad=".true."
export effr_in=".true."
else
export ncld=1
export nwat=2
export cal_pre=T
export dnats=0
fi
export fv3exec='fv3-nonhydro.exe'
export hord_mt=5
export hord_vt=5
export hord_tm=5
export hord_dp=-5
export consv_te=1
export nord=2
export dddmp=0.1
export d4_bg=0.12
export vtdm4=0.02
export fv_sg_adj=450
#gfsv15
#export satmedmf=F
#export hybedmf=T
#export lheatstrg=F
#export IAER=111
#export iovr_lw=1
#export iovr_sw=1
#export icliq_sw=1
#export do_tofd=F
#export reiflag=1
#export adjust_dry_mass=F
#export nord=3
#export vtdm4=0.06
#export tau=10.0
#export rf_cutoff=750.0
#export d2_bg_k1=0.15
#export d2_bg_k2=0.02
#gfsv16 (defaults in run_fv3.sh)
export satmedmf=T
export hybedmf=F
export lheatstrg=T
export IAER=5111
export iovr_lw=3
export iovr_sw=3
export icliq_sw=2
export do_tofd=T
export reiflag=2
export adjust_dry_mass=T
export tau=5.0
export rf_cutoff=1.e3
export d2_bg_k1=0.20
export d2_bg_k2=0.0
# stochastic physics parameters.
export DO_SPPT=.true.
export SPPT=0.5
export SPPT_TSCALE=21600
export SPPT_LSCALE=500000
export DO_SHUM=.true.
export SHUM=0.005
export SHUM_TSCALE=21600
export SHUM_LSCALE=500000
export DO_SKEB=.true.
export SKEB=0.3
export SKEB_TSCALE=21600
export SKEB_LSCALE=250000
export SKEBINT=1800
export SKEBNORM=0
export SKEB_NPASS=30
export SKEB_VDOF=5
# resolution dependent model parameters
if [ $RES -eq 384 ]; then
export JCAP=766
export LONB=1536
export LATB=768
export dt_atmos=225 # for n_split=6
export cdmbgwd="1.1,0.72,1.0,1.0"
elif [ $RES -eq 192 ]; then
export JCAP=382
export LONB=768
export LATB=384
export dt_atmos=450
export cdmbgwd="0.23,1.5,1.0,1.0"
elif [ $RES -eq 128 ]; then
export JCAP=254
export LONB=512
export LATB=256
export dt_atmos=720
export cdmbgwd="0.19,1.6,1.0,1.0"
elif [ $RES -eq 96 ]; then
export JCAP=188
export LONB=384
export LATB=190
export dt_atmos=900
export cdmbgwd="0.14,1.8,1.0,1.0" # mountain blocking, ogwd, cgwd, cgwd src scaling
elif [ $RES -eq 48 ]; then
export JCAP=94
export LONB=192
export LATB=96
export dt_atmos=1800
export cdmbgwd="0.071,2.1,1.0,1.0"
else
echo "model parameters for ensemble resolution C$RES not set"
exit 1
fi
if [ $RES_CTL -eq 768 ]; then
export cdmbgwd_ctl="4.0,0.15,1.0,1.0"
export JCAP_CTL=1534
export LONB_CTL=3072
export LATB_CTL=1536
export k_split_ctl=2
export n_split_ctl=6
export dt_atmos_ctl=150
elif [ $RES_CTL -eq 384 ]; then
export dt_atmos_ctl=225
export cdmbgwd_ctl="1.1,0.72,1.0,1.0"
export JCAP_CTL=766
export LONB_CTL=1536
export LATB_CTL=768
elif [ $RES_CTL -eq 192 ]; then
export dt_atmos_ctl=450
export cdmbgwd_ctl="0.23,1.5,1.0,1.0"
export JCAP_CTL=382
export LONB_CTL=768
export LATB_CTL=384
elif [ $RES_CTL -eq 96 ]; then
export dt_atmos_ctl=900
export cdmbgwd="0.14,1.8,1.0,1.0" # mountain blocking, ogwd, cgwd, cgwd src scaling
export JCAP_CTL=188
export LONB_CTL=384
export LATB_CTL=192
else
echo "model parameters for control resolution C$RES_CTL not set"
exit 1
fi
export FHCYC=0 # run global_cycle instead of gcycle inside model
# analysis is done at ensemble resolution
export LONA=$LONB
export LATA=$LATB
export ANALINC=6
export LEVS=127
export FHMIN=3
export FHMAX=9
export FHMAX_LONG=120 # control forecast every 00UTC in run_long_fcst=true
export FHOUT=3
FHMAXP1=`expr $FHMAX + 1`
export enkfstatefhrs=`python -c "from __future__ import print_function; print(list(range(${FHMIN},${FHMAXP1},${FHOUT})))" | cut -f2 -d"[" | cut -f1 -d"]"`
export iaufhrs="3,6,9"
export iau_delthrs="6" # iau_delthrs < 0 turns IAU off
# dump increment in one time step (for debugging)
#export iaufhrs="6"
#export iau_delthrs=0.25
# to turn off iau, use iau_delthrs=-1
#export iau_delthrs=-1
# other model variables set in ${rungfs}
# other gsi variables set in ${rungsi}
export SMOOTHINF=35
export npts=`expr \( $LONA \) \* \( $LATA \)`
export RUN=gdas # use gdas obs
export reducedgrid=.false.
export univaroz=.false.
export iassim_order=0
export covinflatemax=1.e2
export covinflatemin=1.0
export analpertwtnh=0.85
export analpertwtsh=0.85
export analpertwttr=0.85
export analpertwtnh_rtpp=0.0
export analpertwtsh_rtpp=0.0
export analpertwttr_rtpp=0.0
export pseudo_rh=.true.
export use_correlated_oberrs=".true."
if [ $hybgain == "true" ]; then
# DO_CALC_INCREMENT should always be true for hybgain
export DO_CALC_INCREMENT="YES"
fi
# Analysis increments to zero out
export INCREMENTS_TO_ZERO="'liq_wat_inc','icmr_inc'"
# Stratospheric increments to zero
export INCVARS_ZERO_STRAT="'sphum_inc','liq_wat_inc','icmr_inc'"
export INCVARS_EFOLD="5"
if [ $DO_CALC_INCREMENT = "YES" ]; then
export write_fv3_increment=".false."
export analfileprefix='sanl'
else
export analfileprefix='incr'
export write_fv3_increment=".true."
fi
export WRITE_INCR_ZERO="incvars_to_zero= $INCREMENTS_TO_ZERO,"
export WRITE_ZERO_STRAT="incvars_zero_strat= $INCVARS_ZERO_STRAT,"
export WRITE_STRAT_EFOLD="incvars_efold= $INCVARS_EFOLD,"
export write_ensmean=.true. # write out ens analysis (or anal incr) in EnKF
export letkf_flag=.true.
export letkf_bruteforce_search=.false.
export denkf=.true.
export getkf=.true.
export getkf_inflation=.false.
export modelspace_vloc=.true.
export letkf_novlocal=.true.
export nobsl_max=10000
export sprd_tol=1.e30
export varqc=.false.
export huber=.false.
export zhuberleft=1.e10
export zhuberright=1.e10
export biasvar=-500
if [ $controlanal == 'false' ] && [ $NOSAT == "NO" ]; then
export lupd_satbiasc=.true.
export numiter=4
else
export lupd_satbiasc=.false.
export numiter=0
fi
# iterate enkf in obspace for varqc
if [ $varqc == ".true." ]; then
export numiter=5
fi
# use pre-generated bias files.
#export lupd_satbiasc=.false.
#export numiter=0
#export biascorrdir=${datadir}/C192C192_skeb2
# turn on enkf analog of VarQC
#export sprd_tol=10.
#export varqc=.true.
#export huber=.true.
#export zhuberleft=1.1
#export zhuberright=1.1
export nanals=80
export paoverpb_thresh=0.998 # set to 1.0 to use all the obs in serial EnKF
export saterrfact=1.0
export deterministic=.true.
export sortinc=.true.
export nitermax=2
export enkfscripts="${basedir}/scripts/${exptname}"
export homedir=$enkfscripts
export incdate="${enkfscripts}/incdate.sh"
if [ "$machine" == 'hera' ]; then
export python=/contrib/anaconda/2.3.0/bin/python
export fv3gfspath=/scratch1/NCEPDEV/global/glopara
export FIXFV3=${fv3gfspath}/fix/fix_fv3_gmted2010
export FIXGLOBAL=${fv3gfspath}/fix/fix_am
export gsipath=/scratch1/NCEPDEV/global/glopara/git/global-workflow/gfsv16b/sorc/gsi.fd
export fixgsi=${gsipath}/fix
#export fixcrtm=/scratch1/NCEPDEV/global/glopara/crtm/v2.2.6/fix
export fixcrtm=/scratch2/NCEPDEV/nwprod/NCEPLIBS/fix/crtm_v2.3.0
export execdir=${enkfscripts}/exec_${machine}
export enkfbin=${execdir}/global_enkf
export FCSTEXEC=${execdir}/${fv3exec}
export gsiexec=${execdir}/global_gsi
export CHGRESEXEC=${execdir}/chgres_recenter_ncio.exe
elif [ "$machine" == 'orion' ]; then
export python=`which python`
export fv3gfspath=${basedir}
export FIXFV3=${fv3gfspath}/fix/fix_fv3_gmted2010
export FIXGLOBAL=${fv3gfspath}/fix/fix_am
export gsipath=${basedir}/ProdGSI
export fixgsi=${gsipath}/fix
export fixcrtm=${basedir}/fix/crtm/v2.2.6/fix
export execdir=${enkfscripts}/exec_${machine}
export enkfbin=${execdir}/global_enkf
export FCSTEXEC=${execdir}/${fv3exec}
export gsiexec=${execdir}/global_gsi
export CHGRESEXEC=${execdir}/chgres_recenter_ncio.exe
elif [ "$machine" == 'gaea' ]; then
export python=/ncrc/sw/gaea/PythonEnv-noaa/1.4.0/.spack/opt/spack/linux-sles12-x86_64/gcc-4.8/python-2.7.14-zyx34h36bfp2c6ftp5bhdsdduqjxbvp6/bin/python
#export PYTHONPATH=/ncrc/home2/Jeffrey.S.Whitaker/anaconda2/lib/python2.7/site-packages
#export fv3gfspath=/lustre/f1/pdata/ncep_shared/fv3/fix-fv3gfs/
export fv3gfspath=/lustre/f2/dev/Jeffrey.S.Whitaker/fv3_reanl/fv3gfs/global_shared.v15.0.0
export FIXFV3=${fv3gfspath}/fix/fix_fv3_gmted2010
export FIXGLOBAL=${fv3gfspath}/fix/fix_am
export gsipath=/lustre/f2/dev/Jeffrey.S.Whitaker/ProdGSI
export fixgsi=${gsipath}/fix
export fixcrtm=/lustre/f2/pdata/ncep_shared/NCEPLIBS/lib/crtm/v2.2.5/fix
#export fixcrtm=${fixgsi}/crtm_v2.2.3
export execdir=${enkfscripts}/exec_${machine}
export enkfbin=${execdir}/global_enkf
export FCSTEXEC=${execdir}/${fv3exec}
export gsiexec=${execdir}/global_gsi
export CHGRESEXEC=${execdir}/chgres_recenter_ncio.exe
else
echo "${machine} unsupported machine"
exit 1
fi
#export ANAVINFO=${enkfscripts}/global_anavinfo.l${LEVS}.txt
export ANAVINFO=${fixgsi}/global_anavinfo.l${LEVS}.txt
export ANAVINFO_ENKF=${ANAVINFO}
export HYBENSINFO=${fixgsi}/global_hybens_info.l${LEVS}.txt
# comment out next line to disable smoothing of ensemble perturbations
# in stratosphere/mesosphere
#export HYBENSMOOTHINFO=${fixgsi}/global_hybens_smoothinfo.l${LEVS}.txt
export OZINFO=${fixgsi}/global_ozinfo.txt
export CONVINFO=${fixgsi}/global_convinfo.txt
export SATINFO=${fixgsi}/global_satinfo.txt
export REALTIME=YES # if NO, use historical files set in main.sh
# parameters for hybrid gain
if [ $hybgain == "true" ]; then
export beta1_inv=1.000
export readin_beta=.false.
else
export beta1_inv=0.125 # 0 means all ensemble, 1 means all 3DVar.
export readin_beta=.true.
fi
# change the next line to .true. to read in from hybens_info file.
export readin_localization=.true.
# if above is .false., these values are used in GSI (not used at all for hybgain)
export s_ens_h=343. # 1250 km
#export s_ens_h=485 # produces similar increments to 1250KM LETKF R localization
export s_ens_v=-0.58 # 1.5 scale heights
# NOTE: most other GSI namelist variables are in ${rungsi}
export aircraft_bc=.true.
export use_prepb_satwnd=.false.
cd $enkfscripts
echo "run main driver script"
sh ./main.sh