123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803 |
- #!/usr/bin/env bash
- set -ue
- . ${start_dir}/librunscript.sh
- config="ifs nemo:elpin lim3 rnfmapper xios:detached oasis"
- exp_name=[[[MOD:GENERAL:EXP_NAME]]]
- run_start_date="[[[MOD:GENERAL:RUN_START_DATE]]]"
- run_end_date="[[[MOD:GENERAL:RUN_END_DATE]]]"
- force_run_from_scratch=[[[MOD:GENERAL:FORCE_RUN_FROM_SCRATCH]]]
- special_restart=false
- special_restart_from=ECE3
- special_restart_date="1995-01-01"
- ifs_grid=[[[MOD:IFS:GRID]]]
- nem_grid=[[[MOD:NEM:GRID]]]
- rst_freq="[[[MOD:GENERAL:RST_FREQ]]]"
- run_num_legs=[[[MOD:GENERAL:RUN_NUM_LEGS]]]
- cpl_freq_atm_oce_sec=[[[MOD:OASIS:CPL_FREQ_ATM_OCE_SEC]]]
- ctrl_file_dir=${start_dir}/ctrl
- build_arch=[[[PLT:ACTIVE:BUILD_ARCH]]]
- ece_info_file="ece.info"
- . ${start_dir}/ecconf.cfg
- configure
- ifs_version=36r4
- ifs_time_step_sec=[[[MOD:IFS:TIME_STEP_SEC]]]
- ifs_output_freq_h="6 3"
- for hfreq in $ifs_output_freq_h
- do
- sfreq=$(( hfreq * 3600 ))
- if (( $(( sfreq % ifs_time_step_sec )) ))
- then
- error "Output frequency $hfreq [hrs] is not a multiple of IFS timestep $ifs_time_step_sec [s]"
- fi
- done
- ifs_output_freq=$(( ${ifs_output_freq_h##* } * 3600 / ifs_time_step_sec ))
- ifs_di_freq=$(( 24 * 3600 / ifs_time_step_sec ))
- ifs_ddh_freq=$(( 120 * 3600 / ifs_time_step_sec ))
- ifs_res_hor=$(echo ${ifs_grid} | sed 's:T\([0-9]\+\)L\([0-9]\+\):\1:')
- ifs_res_ver=$(echo ${ifs_grid} | sed 's:T\([0-9]\+\)L\([0-9]\+\):\2:')
- ifs_numproc=[[[MOD:IFS:NUMPROC]]]
- ifs_exe_file=${ecearth_src_dir}/ifs-${ifs_version}/bin/ifsmaster-${build_arch}
- ifs_lastout=false
- ifs_cmip5=[[[MOD:IFS:CMIP5]]]
- ifs_cmip5_rcp=[[[MOD:IFS:CMIP5_RCP]]]
- ifs_cmip_fixyear=[[[MOD:IFS:CMIP_FIXYEAR]]]
- ifs_cmip6=[[[MOD:IFS:CMIP6]]]
- ifs_mac2sp=[[[MOD:IFS:CMIP6]]]
- ifs_cmip6piaer=[[[MOD:IFS:CMIP6]]]
- ifs_cmip6_scenario=[[[MOD:IFS:CMIP6_SCENARIO]]]
- lcmip6_strat_simp=[[[MOD:IFS:CMIP6]]]
- ifs_A4xCO2=[[[MOD:IFS:CMIP6_A4xCO2]]]
- ifs_1PCTCO2=[[[MOD:IFS:CMIP6_1PCTCO2]]]
- ifs_orb_switch=FALSE
- ifs_orb_mode="variable_year"
- ifs_orb_iyear=$(date -u -d "${run_start_date}" +%Y)
-
- RPRCON=1.38E-3
- RVICE=0.13
- RLCRITSNOW=5.0E-5
- RSNOWLIN2=0.035
- ENTRORG=1.58E-4
- DETRPEN=0.66E-4
- ENTRDD=3.2E-4
- RMFDEPS=0.29
- RCLDIFF=3.8E-6
- RCLDIFFC=5.0
- nem_time_step_sec=[[[MOD:NEM:NEM_TIME_STEP_SEC]]]
- lim_time_step_sec=[[[MOD:NEM:LIM_TIME_STEP_SEC]]]
- nem_restart_file_path=${start_dir}/nemo-rst
- nem_restart_offset=0
- nem_res_hor=$(echo ${nem_grid} | sed 's:ORCA\([0-9]\+\)L[0-9]\+:\1:')
- nem_exe_file=${ecearth_src_dir}/nemo-3.6/CONFIG/${nem_grid}_LIM3/BLD/bin/nemo.exe
- nem_numproc=[[[MOD:NEM:NUMPROC]]]
- rnf_exe_file=${ecearth_src_dir}/runoff-mapper/bin/runoff-mapper.exe
- rnf_numproc=1
- oas_rst_files="rstas.nc rstos.nc"
- oas_link_weights=true
- oas_mb_fluxcorr=1.07945
- xio_exe_file=${ecearth_src_dir}/xios-2/bin/xios_server.exe
- xio_numproc=[[[MOD:XIO:NUMPROC]]]
- if [ ! -d ${run_dir} ]
- then
- mkdir -p ${run_dir}
- if $special_restart
- then
- force_run_from_scratch=false
- rsync -av --delete ${run_dir}/../${special_restart_from}/ --exclude log --exclude output --exclude restart --exclude="${special_restart_from}_*" --exclude="srf*" --exclude="restart_*" --exclude="debug.*" --exclude="output.*" ${run_dir}
- cp -f ${nem_exe_file} ${run_dir}
- cp -f ${ifs_exe_file} ${run_dir}
- cp -f ${rnf_exe_file} ${run_dir}
- cp -f ${xio_exe_file} ${run_dir}
- special_year=${special_restart_date:0:4}
- sed -i "/$special_year/q" ${run_dir}/ece.info
- . ${run_dir}/ece.info
- special_restart_leg=$(printf %03d $((leg_number+1)))
-
- rsync -av ${run_dir}/../${special_restart_from}/restart/ifs/${special_restart_leg}/ ${run_dir}
- rsync -av ${run_dir}/../${special_restart_from}/restart/oasis/${special_restart_leg}/ ${run_dir}
- cd ${run_dir}/../${special_restart_from}/restart/nemo/${special_restart_leg}
- for f in *.nc; do
- nf=${exp_name}${f:4}
- cp $f ${run_dir}/$nf
- done
- cd -
- cd ${run_dir}
- for f in ${exp_name}_????????_restart_???_????.nc; do
- nf=${f:14}
- ln -s $f $nf
- done
- cd -
- rm -f ${run_dir}/ICMCL${special_restart_from}INIT
- mv ${run_dir}/ICMGG${special_restart_from}INIUA ${run_dir}/ICMGG${exp_name}INIUA
- mv ${run_dir}/ICMGG${special_restart_from}INIT ${run_dir}/ICMGG${exp_name}INIT
- mv ${run_dir}/ICMSH${special_restart_from}INIT ${run_dir}/ICMSH${exp_name}INIT
- fi
- else
- force_run_from_scratch=false
- special_restart=false
- fi
- cd ${run_dir}
- run_start_date=$(date -uR -d "${run_start_date}")
- run_end_date=$(date -uR -d "${run_end_date}")
- for (( ; run_num_legs>0 ; run_num_legs-- ))
- do
-
-
- if ${force_run_from_scratch} || ! [ -r ${ece_info_file} ]
- then
- leg_is_restart=false
- leg_start_date=${run_start_date}
- leg_number=1
- else
- leg_is_restart=true
- . ./${ece_info_file}
- leg_start_date=${leg_end_date}
- leg_number=$((leg_number+1))
- fi
-
- if [ -n "${rst_freq}" ]
- then
- leg_end_date=$(date -uR -d "${leg_start_date} + ${rst_freq}")
- else
- leg_end_date=${run_end_date}
- fi
- if [ $(date -d "${leg_end_date}" +%s) -gt $(date -d "${run_end_date}" +%s) ]
- then
- leg_end_date=${run_end_date}
- fi
-
- leg_length_sec=$(( $(date -d "${leg_end_date}" +%s) - $(date -d "${leg_start_date}" +%s) ))
- leg_start_sec=$(( $(date -d "${leg_start_date}" +%s) - $(date -d "${run_start_date}" +%s) ))
- leg_end_sec=$(( $(date -d "${leg_end_date}" +%s) - $(date -d "${run_start_date}" +%s) ))
- leg_start_date_yyyymmdd=$(date -u -d "${leg_start_date}" +%Y%m%d)
- leg_start_date_yyyy=$(date -u -d "${leg_start_date}" +%Y)
- leg_end_date_yyyy=$(date -u -d "${leg_end_date}" +%Y)
-
- if [ ${leg_length_sec} -le 0 ]
- then
- info "Leg start date equal to or after end of simulation."
- info "Nothing left to do. Exiting."
- exit 0
- fi
-
-
-
- if ! $leg_is_restart
- then
-
-
-
-
- if $(ls * >& /dev/null)
- then
- if ${force_run_from_scratch}
- then
- rm -fr ${run_dir}/*
- else
- error "Run directory not empty and \$force_run_from_scratch not set."
- fi
- fi
-
-
-
-
- cp ${ifs_exe_file} .
- ln -s ${ifs_exe_file} $(basename ${ifs_exe_file}).lnk
- cp ${nem_exe_file} .
- ln -s ${nem_exe_file} $(basename ${nem_exe_file}).lnk
- cp ${rnf_exe_file} .
- ln -s ${rnf_exe_file} $(basename ${rnf_exe_file}).lnk
- cp ${xio_exe_file} .
- ln -s ${xio_exe_file} $(basename ${xio_exe_file}).lnk
-
-
-
-
- ln -s \
- ${ini_data_dir}/ifs/${ifs_grid}/${leg_start_date_yyyymmdd}/ICMGGECE3INIUA \
- ICMGG${exp_name}INIUA
- ln -s \
- ${ini_data_dir}/ifs/${ifs_grid}/${leg_start_date_yyyymmdd}/ICMGGECE3INIT \
- ICMGG${exp_name}INIT
- ln -s \
- ${ini_data_dir}/ifs/${ifs_grid}/${leg_start_date_yyyymmdd}/ICMSHECE3INIT \
- ICMSH${exp_name}INIT
-
- ln -s ${ini_data_dir}/ifs/rtables/* .
-
- mkdir postins
- rm -f postins/*
- cp ${ctrl_file_dir}/ppt0000000000 postins/
-
- for freq in $ifs_output_freq_h ; do
- hhmm_freq=$(printf %02d00 $freq)
- if [ ! -f ${ctrl_file_dir}/pptdddddd${hhmm_freq} ] ; then
- echo "warning: output requested at $freq h. but ppt file postins/pptdddddd${hhmm_freq} does not exist."
- continue
- else
- cp ${ctrl_file_dir}/pptdddddd${hhmm_freq} postins/
- fi
- for t in `seq 0 $freq 23`
- do
- hhmm_t=$(printf %02d00 $t)
- if [ ! -f postins/pptdddddd${hhmm_t} ]
- then
- ln -s pptdddddd${hhmm_freq} postins/pptdddddd${hhmm_t}
- fi
- done
- done
-
- /bin/ls -1 postins/* > dirlist
-
-
-
-
-
- for f in \
- bathy_meter.nc coordinates.nc \
- ahmcoef.nc \
- K1rowdrg.nc M2rowdrg.nc mask_itf.nc \
- decay_scale_bot.nc decay_scale_cri.nc \
- mixing_power_bot.nc mixing_power_cri.nc mixing_power_pyc.nc \
- runoff_depth.nc subbasins.nc
- do
- [ -f ${ini_data_dir}/nemo/initial/${nem_grid}/$f ] && ln -s ${ini_data_dir}/nemo/initial/${nem_grid}/$f
- done
-
- ln -s ${ini_data_dir}/nemo/initial/Goutorbe_ghflux.nc
- ln -s ${ini_data_dir}/nemo/initial/weights_Goutorbe1_2_orca${nem_res_hor}_bilinear.nc
-
- if $(has_config nemo:start_from_restart)
- then
-
-
-
-
-
-
-
-
-
-
-
-
-
- if ls -U ${nem_restart_file_path}/restart_[oi]ce.nc > /dev/null 2>&1
- then
- ln -s ${nem_restart_file_path}/restart_[oi]ce.nc ./
- elif ls -U ${nem_restart_file_path}/restart_[oi]ce_????.nc > /dev/null 2>&1
- then
- ln -s ${nem_restart_file_path}/restart_[oi]ce_????.nc ./
- else
- for f in ${nem_restart_file_path}/????_????????_restart_[oi]ce_????.nc
- do
- ln -s $f $(echo $f | sed 's/.*_\(restart_[oi]ce_....\.nc\)/\1/')
- done
- fi
- else
-
- ln -s ${ini_data_dir}/nemo/climatology/absolute_salinity_WOA13_decav_Reg1L75_clim.nc
- ln -s ${ini_data_dir}/nemo/climatology/conservative_temperature_WOA13_decav_Reg1L75_clim.nc
- ln -s ${ini_data_dir}/nemo/climatology/weights_WOA13d1_2_orca${nem_res_hor}_bilinear.nc
-
- case ${nem_grid} in
- ORCA1*) ln -s ${ini_data_dir}/nemo/climatology/runoff-icb_DaiTrenberth_Depoorter_ORCA1_JD.nc ;;
- ORCA025*) ln -s ${ini_data_dir}/nemo/climatology/ORCA_R025_runoff_v1.1.nc ;;
- esac
- fi
-
- . ${ctrl_file_dir}/iodef.xml.sh > iodef.xml
- ln -s ${ctrl_file_dir}/context_nemo.xml
- ln -s ${ctrl_file_dir}/domain_def_nemo.xml
- ln -s ${ctrl_file_dir}/field_def_nemo-lim.xml
- ln -s ${ctrl_file_dir}/field_def_nemo-opa.xml
- ln -s ${ctrl_file_dir}/field_def_nemo-pisces.xml
- ln -s ${ctrl_file_dir}/file_def_nemo-lim3.xml file_def_nemo-lim.xml
- ln -s ${ctrl_file_dir}/file_def_nemo-opa.xml
- ln -s ${ctrl_file_dir}/file_def_nemo-pisces.xml
-
-
-
- ln -s ${ini_data_dir}/runoff-mapper/runoff_maps.nc
-
-
-
- oas_grid_dir=${ini_data_dir}/oasis/T${ifs_res_hor}-ORCA${nem_res_hor}
-
- ln -s ${ini_data_dir}/oasis/cf_name_table.txt
-
- ln -s ${oas_grid_dir}/areas.nc
- ln -s ${oas_grid_dir}/grids.nc
- ln -s ${oas_grid_dir}/masks.nc
-
- case ${ifs_res_hor} in
- 159) oas_agrd=080
- ;;
- 255) oas_agrd=128
- ;;
- 511) oas_agrd=256
- ;;
- 799) oas_agrd=400
- ;;
- *) error "Unsupported horizontal resolution (IFS): ${ifs_res_hor}"
- ;;
- esac
- case ${nem_res_hor} in
- 1) oas_ogrd=O1t0
- ;;
- 025) oas_ogrd=Ot25
- ;;
- *) error "Unsupported horizontal resolution (NEMO): ${nem_res_hor}"
- ;;
- esac
- if ${oas_link_weights}
- then
- for f in ${oas_grid_dir}/rmp_????_to_????_GAUSWGT.nc
- do
- ln -s $f
- done
- fi
- for f in ${oas_rst_files}
- do
- cp ${oas_grid_dir}/rst/$f .
- done
- else
-
-
-
-
- rm -f ICM{SH,GG}${exp_name}+??????
-
- rm -f ${exp_name}_??_????????_????????_{grid_U,grid_V,grid_W,grid_T,icemod,SBC,scalar,SBC_scalar}.nc
- fi
-
-
-
- if $(has_config nemo:elpin)
- then
- jpns=($(${ecearth_src_dir}/util/ELPiN/ELPiNv2.cmd ${nem_numproc}))
- info "nemo domain decompostion from ELpIN: ${jpns[@]}"
- nem_numproc=${jpns[0]}
- nem_jpni=${jpns[1]}
- nem_jpnj=${jpns[2]}
- else
- info "nemo original domain decomposition (not using ELPiN)"
- fi
-
-
-
-
- . ${ctrl_file_dir}/namelist.ifs.sh > fort.4
- . ${ctrl_file_dir}/namelist.nemo.ref.sh > namelist_ref
- . ${ctrl_file_dir}/namelist.nemo-${nem_grid}-coupled.cfg.sh > namelist_cfg
- . ${ctrl_file_dir}/namelist.lim3.ref.sh > namelist_ice_ref
- . ${ctrl_file_dir}/namelist.lim3-${nem_grid}.cfg.sh > namelist_ice_cfg
- . ${ctrl_file_dir}/namelist.runoffmapper.sh > namelist.runoffmapper
- . ${ctrl_file_dir}/namcouple.sh > namcouple
-
-
-
- icmclfile=${ini_data_dir}/ifs/${ifs_grid}/climate/ICMCL
- tempfile=tmp.$$
- grib_set=${GRIB_BIN_PATH}${GRIB_BIN_PATH:+/}grib_set
-
- ${grib_set} \
- -s dataDate=$(printf "%04d" $((leg_start_date_yyyy-1)))1215 ${icmclfile}-12 \
- ICMCL${exp_name}INIT
-
- for (( y=${leg_start_date_yyyy} ; y<=${leg_end_date_yyyy} ; y++ ))
- do
- yy=$(printf "%04d" $y)
- for m in {1..12}
- do
- mm=$(printf "%02d" $m)
- ${grib_set} -s dataDate=${yy}${mm}15 ${icmclfile}-${mm} ${tempfile}
- cat ${tempfile} >> ICMCL${exp_name}INIT
- done
- done
-
- ${grib_set} -s dataDate=$(printf "%04d" $((leg_end_date_yyyy+1)))0115 ${icmclfile}-01 \
- ${tempfile}
- cat ${tempfile} >> ICMCL${exp_name}INIT
-
- rm -f ${tempfile}
-
-
-
- if $leg_is_restart
- then
- ns=$(printf %08d $(( leg_start_sec / nem_time_step_sec - nem_restart_offset )))
- for (( n=0 ; n<nem_numproc ; n++ ))
- do
- np=$(printf %04d ${n})
- ln -fs ${exp_name}_${ns}_restart_oce_${np}.nc restart_oce_${np}.nc
- ln -fs ${exp_name}_${ns}_restart_ice_${np}.nc restart_ice_${np}.nc
- done
-
-
-
-
- [ -h restart_oce.nc ] && rm restart_oce.nc
- [ -h restart_ice.nc ] && rm restart_ice.nc
- fi
-
-
-
- if $leg_is_restart
- then
- rm -f anaisout_*
- fi
-
-
-
- export DR_HOOK_IGNORE_SIGNALS='-1'
- export CPLNG='active'
-
- t1=$(date +%s)
- launch \
- ${xio_numproc} ${xio_exe_file} -- \
- ${nem_numproc} ${nem_exe_file} -- \
- ${rnf_numproc} ${rnf_exe_file} -- \
- ${ifs_numproc} ${ifs_exe_file} -v ecmwf -e ${exp_name}
- t2=$(date +%s)
- tr=$(date -d "0 -$t1 sec + $t2 sec" +%T)
-
-
-
-
-
-
-
- if [ -f ifs.stat ]
- then
- if [ "$(awk 'END{print $3}' ifs.stat)" == "CNT0" ]
- then
- info "Leg successfully completed according to IFS log file 'ifs.stat'."
- else
- error "Leg not completed according to IFS log file 'ifs.stat'."
- fi
- else
- error "IFS log file 'ifs.stat' not found after run."
- fi
-
- if [ -f ocean.output ]
- then
- if [ "$(awk '/New day/{d=$10}END{print d}' ocean.output)" == "$(date -d "${leg_end_date} - 1 day" +%Y/%m/%d)" ]
- then
- info "Leg successfully completed according to NEMO log file 'ocean.output'."
- else
- error "Leg not completed according to NEMO log file 'ocean.output'."
- fi
- else
- error "NEMO log file 'ocean.output' not found after run."
- fi
-
-
-
- outdir="output/ifs/$(printf %03d $((leg_number)))"
- mkdir -p ${outdir}
- prv_leg=$(printf %03d $((leg_number-1)))
-
-
-
-
-
- for f in ICMSH${exp_name}+?????? ICMGG${exp_name}+??????
- do
- if [ -f output/ifs/${prv_leg}/${f} ]
- then
- cat ${f} >> output/ifs/${prv_leg}/${f}
- rm -f ${f}
- else
- mv ${f} ${outdir}
- fi
- done
-
-
-
- outdir="output/nemo/$(printf %03d $((leg_number)))"
- mkdir -p ${outdir}
- for f in ${exp_name}_??_????????_????????_*.nc ; do mv $f $outdir/ ; done
-
-
-
- if $leg_is_restart
- then
- outdir="restart/ifs/$(printf %03d $((leg_number)))"
- mkdir -p ${outdir}
-
-
- nd="$(printf %06d $((leg_start_sec/(24*3600))))0000"
- mv srf${nd}.???? ${outdir}
- fi
-
-
-
- if $leg_is_restart
- then
- outdir="restart/nemo/$(printf %03d $((leg_number)))"
- mkdir -p ${outdir}
- ns=$(printf %08d $(( leg_start_sec / nem_time_step_sec - nem_restart_offset )))
- for f in oce ice
- do
- mv ${exp_name}_${ns}_restart_${f}_????.nc ${outdir}
- done
- fi
-
-
-
-
-
-
-
- outdir="restart/oasis/$(printf %03d $((leg_number+1)))"
- mkdir -p ${outdir}
- for f in ${oas_rst_files}
- do
- test -f ${f} && cp ${f} ${outdir}
- done
-
-
-
- outdir="restart/ifs/$(printf %03d $((leg_number+1)))"
- mkdir -p ${outdir}
- for f in rcf
- do
- test -f ${f} && cp ${f} ${outdir}
- done
-
-
-
- outdir="log/$(printf %03d $((leg_number)))"
- mkdir -p ${outdir}
- for f in \
- ifs.log ifs.stat fort.4 ocean.output \
- time.step solver.stat \
- nout.000000 debug.??.?????? A*_??.nc O*_??.nc
- do
- test -f ${f} && mv ${f} ${outdir}
- done
-
-
-
-
- sypd="$(cpmip_sypd $leg_length_sec $(($t2 - $t1)))"
- chpsy="$(cpmip_chpsy $leg_length_sec $(($t2 - $t1)) $(($ifs_numproc + $nem_numproc + $rnf_numproc + $xio_numproc)))"
- echo "#" | tee -a ${ece_info_file}
- echo "# Finished leg at `date '+%F %T'` after ${tr} (hh:mm:ss)" \
- | tee -a ${ece_info_file}
- echo "# CPMIP performance: $sypd SYPD $chpsy CHPSY"| tee -a ${ece_info_file}
- echo "leg_number=${leg_number}" | tee -a ${ece_info_file}
- echo "leg_start_date=\"${leg_start_date}\"" | tee -a ${ece_info_file}
- echo "leg_end_date=\"${leg_end_date}\"" | tee -a ${ece_info_file}
-
- force_run_from_scratch=false
- special_restart=false
- done
- finalise
- exit 0
|