New URL for NEMO forge!   http://forge.nemo-ocean.eu

Since March 2022 along with NEMO 4.2 release, the code development moved to a self-hosted GitLab.
This present forge is now archived and remained online for history.
sette.sh in branches/2016/dev_r6409_SIMPLIF_2_usrdef/NEMOGCM/SETTE – NEMO

source: branches/2016/dev_r6409_SIMPLIF_2_usrdef/NEMOGCM/SETTE/sette.sh @ 7133

Last change on this file since 7133 was 7133, checked in by flavoni, 8 years ago

Ãupadte sette

  • Property svn:executable set to *
File size: 55.2 KB
Line 
1#!/bin/bash
2############################################################
3# Author : Simona Flavoni for NEMO
4# Contact: sflod@locean-ipsl.upmc.fr
5# 2013   : A.C. Coward added options for testing with XIOS in dettached mode
6#
7# sette.sh   : principal script of SET TEsts for NEMO (SETTE)
8# ----------------------------------------------------------------------
9# NEMO/SETTE , NEMO Consortium (2010)
10# Software governed by the CeCILL licence     (NEMOGCM/NEMO_CeCILL.txt)
11# ----------------------------------------------------------------------
12#
13#############################################################
14#set -x
15set -o posix
16#set -u
17#set -e
18# ===========
19# DESCRIPTION
20# ===========
21#
22# Variables to be checked by user:
23#
24# COMPILER          : name of compiler as defined in NEMOGCM/ARCH directory
25# BATCH_COMMAND_PAR :  name of the command for submitting parallel batch jobs
26# BATCH_COMMAND_SEQ :  name of the command for submitting sequential batch jobs 
27# INTERACT_FLAG     : flag to run in interactive mode "yes"
28#                           to run in batch mode "no"
29# MPIRUN_FLAG       : flag to run in parallel (MPI) "yes"
30#                           to run in sequential mode (NB_PROC = 1) "no"
31# USING_XIOS        : flag to control the activation of key_iomput
32#                      "yes" to compile using key_iomput and link to the external XIOS library
33#                      "no"  to compile without key_iomput and link to the old IOIPSL library
34# USING_MPMD        : flag to control the use of stand-alone IO servers
35#                     requires USING_XIOS="yes"
36#                      "yes" to run in MPMD (detached) mode with stand-alone IO servers
37#                      "no"  to run in SPMD (attached) mode without separate IO servers
38# NUM_XIOSERVERS    : number of stand-alone IO servers to employ
39#                     set to zero if USING_MPMD="no"
40#
41# Principal script is sette.sh, that calls
42#
43#  makenemo  : to create successive exectuables in ${CONFIG_NAME}/BLD/bin/nemo.exe
44#              and links to opa in ${CONFIG_NAME}/EXP00)
45#
46#  param.cfg : sets and loads following directories:
47#
48#   FORCING_DIR         : is the directory for forcing files (tarfile)
49#   INPUT_DIR           : is the directory for input files storing
50#   TMPDIR              : is the temporary directory (if needed)
51#   NEMO_VALIDATION_DIR : is the validation directory
52#
53#   (NOTE: this file is the same for all configrations to be tested with sette)
54#
55#   all_functions.sh : loads functions used by sette (note: new functions can be added here)
56#   set_namelist     : function declared in all_functions that sets namelist parameters
57#   post_test_tidyup : creates validation storage directory and copies required output files
58#                      (solver.stat and ocean.output) in it after execution of test.
59#
60#  VALIDATION tree is:
61#
62#   NEMO_VALIDATION_DIR/WCONFIG_NAME/WCOMPILER_NAME/TEST_NAME/REVISION_NUMBER(or DATE)
63#
64#  prepare_exe_dir.sh : defines and creates directory where the test is executed
65#                       execution directory takes name of TEST_NAME defined for every test
66#                       in sette.sh. (each test in executed in its own directory)
67#
68#  prepare_job.sh     : to generate the script run_job.sh
69#
70#  fcm_job.sh         : run in batch (INTERACT_FLAG="no") or interactive (INTERACT_FLAG="yes")
71#                        see sette.sh and BATCH_TEMPLATE directory
72#
73#  NOTE: jobs requiring initial or forcing data need to have an input_CONFIG.cfg in which
74#        can be found paths to the input tar file)
75#  NOTE: if job is not launched for any reason you have the executable ready in ${EXE_DIR}
76#        directory
77#  NOTE: the changed namelists are left in ${EXE_DIR} directory whereas original namelists
78#        remain in ${NEW_CONF}/EXP00
79#
80#  NOTE: a log file, output.sette, is created in ${SETTE_DIR} with the echoes of
81#        executed commands
82#
83#  NOTE: if sette.sh is stopped in output.sette there is written the last command
84#        executed by sette.sh
85#
86# example use: ./sette.sh
87#########################################################################################
88#
89# Compiler among those in NEMOGCM/ARCH
90COMPILER=X64_ADA
91export BATCH_COMMAND_PAR="llsubmit"
92export BATCH_COMMAND_SEQ=$BATCH_COMMAND_PAR
93export INTERACT_FLAG="no"
94export MPIRUN_FLAG="yes"
95export USING_XIOS="yes"
96#
97export DEL_KEYS="key_iomput"
98if [ ${USING_XIOS} == "yes" ] 
99 then
100   export DEL_KEYS=""
101fi
102#
103# Settings which control the use of stand alone servers (only relevant if using xios)
104#
105export USING_MPMD="no"
106export NUM_XIOSERVERS=4
107export JOB_PREFIX=batch-mpmd
108#
109if [ ${USING_MPMD} == "no" ] 
110 then
111   export NUM_XIOSERVERS=0
112   export JOB_PREFIX=batch
113fi
114#
115#
116if [ ${USING_MPMD} == "yes" ] && [ ${USING_XIOS} == "no"]
117 then
118   echo "Incompatible choices. MPMD mode requires the XIOS server"
119   exit
120fi
121#
122
123# Directory to run the tests
124SETTE_DIR=$(cd $(dirname "$0"); pwd)
125MAIN_DIR=${SETTE_DIR%/SETTE}
126CONFIG_DIR=${MAIN_DIR}/CONFIG
127TOOLS_DIR=${MAIN_DIR}/TOOLS
128COMPIL_DIR=${TOOLS_DIR}/COMPILE
129
130CMP_NAM=${1:-$COMPILER}
131# Copy job_batch_COMPILER file for specific compiler into job_batch_template
132cd ${SETTE_DIR}
133cp BATCH_TEMPLATE/${JOB_PREFIX}-${COMPILER} job_batch_template || exit
134# Description of configuration tested:
135# GYRE             :  1 &  2
136# ORCA2_LIM_PISCES :  3 &  4
137# ORCA2_OFF_PISCES :  5 &  6
138# ORCA2_LIM3       :  7 &  8
139# AMM12            :  9 & 10
140# SAS              : 11      fos SAS there is no solver so is usefull to test REPRO
141# ISOMIP           : 13 & 14
142# ORCA2_LIM_OBS    : 15
143# ORCA2_AGRIF_LIM  : 16 & 17
144#                    18 & 19
145
146for config in 1 2 3 4 5 6 7 8 9 10 11 12 13 14
147
148do
149
150# TESTS FOR GYRE CONFIGURATION
151if [ ${config} -eq 1 ] ;  then
152    ## Restartability tests for GYRE
153    export TEST_NAME="LONG"
154    cd ${CONFIG_DIR}
155    . ./makenemo -m ${CMP_NAM} -n GYRE_LONG -r GYRE -j 8 del_key ${DEL_KEYS}
156    cd ${SETTE_DIR}
157    . ./param.cfg
158    . ./all_functions.sh
159    . ./prepare_exe_dir.sh
160    JOB_FILE=${EXE_DIR}/run_job.sh
161    NPROC=4
162    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
163    cd ${EXE_DIR} 
164    set_namelist namelist_cfg cn_exp \"GYRE_LONG\"
165    set_namelist namelist_cfg nn_it000 1
166    set_namelist namelist_cfg nn_itend 120
167    set_namelist namelist_cfg nn_stock 60
168    set_namelist namelist_cfg ln_clobber .true.
169    set_namelist namelist_cfg ln_linssh .true.
170    set_namelist namelist_cfg ln_read_cfg .false.
171    set_namelist namelist_cfg nn_fwb 0
172    set_namelist namelist_cfg jpni 2
173    set_namelist namelist_cfg jpnj 2
174    set_namelist namelist_cfg jpnij 4
175    if [ ${USING_MPMD} == "yes" ] ; then
176       set_xio_using_server iodef.xml true
177    else
178       set_xio_using_server iodef.xml false
179    fi
180    cd ${SETTE_DIR}
181    . ./prepare_job.sh input_GYRE.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
182
183    cd ${SETTE_DIR}
184    export TEST_NAME="SHORT"
185    . ./prepare_exe_dir.sh
186    cd ${EXE_DIR}
187    set_namelist namelist_cfg cn_exp \"GYRE_SHORT\"
188    set_namelist namelist_cfg nn_it000 61
189    set_namelist namelist_cfg nn_itend 120
190    set_namelist namelist_cfg nn_stock 60
191    set_namelist namelist_cfg ln_rstart .true.
192    set_namelist namelist_cfg nn_rstctl 2
193    set_namelist namelist_cfg ln_clobber .true.
194    set_namelist namelist_cfg ln_linssh .true.
195    set_namelist namelist_cfg ln_read_cfg .false.
196    set_namelist namelist_cfg nn_fwb 0
197    set_namelist namelist_cfg jpni 2
198    set_namelist namelist_cfg jpnj 2
199    set_namelist namelist_cfg jpnij 4
200    set_namelist namelist_cfg cn_ocerst_in \"GYRE_LONG_00000060_restart\"
201    if [ ${USING_MPMD} == "yes" ] ; then
202       set_xio_using_server iodef.xml true
203    else
204       set_xio_using_server iodef.xml false
205    fi
206    for (( i=1; i<=$NPROC; i++)) ; do
207        L_NPROC=$(( $i - 1 ))
208        L_NPROC=`printf "%04d\n" ${L_NPROC}`
209        ln -sf ../LONG/GYRE_LONG_00000060_restart_${L_NPROC}.nc .
210    done
211    if [ ${USING_MPMD} == "yes" ] ; then
212       set_xio_using_server iodef.xml true
213    else
214       set_xio_using_server iodef.xml false
215    fi
216    cd ${SETTE_DIR}
217    . ./prepare_job.sh input_GYRE.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
218    cd ${SETTE_DIR}
219    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
220fi
221
222if [ ${config} -eq 2 ] ;  then
223    ## Reproducibility tests for GYRE
224    export TEST_NAME="REPRO_1_4"
225    cd ${CONFIG_DIR}
226    . ./makenemo -m ${CMP_NAM} -n GYRE_4 -r GYRE -j 8 add_key "key_mpp_rep" del_key ${DEL_KEYS}
227    cd ${SETTE_DIR}
228    . ./param.cfg
229    . ./all_functions.sh
230    . ./prepare_exe_dir.sh
231    JOB_FILE=${EXE_DIR}/run_job.sh
232    NPROC=4
233    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
234    cd ${EXE_DIR}
235    set_namelist namelist_cfg cn_exp \"GYRE_14\"
236    set_namelist namelist_cfg nn_it000 1
237    set_namelist namelist_cfg nn_itend 60
238    set_namelist namelist_cfg nn_fwb 0
239    set_namelist namelist_cfg ln_ctl .false.
240    set_namelist namelist_cfg ln_clobber .true.
241    set_namelist namelist_cfg ln_linssh .true.
242    set_namelist namelist_cfg ln_read_cfg .false.
243    set_namelist namelist_cfg jpni 1
244    set_namelist namelist_cfg jpnj 4
245    set_namelist namelist_cfg jpnij 4
246    if [ ${USING_MPMD} == "yes" ] ; then
247       set_xio_using_server iodef.xml true
248    else
249       set_xio_using_server iodef.xml false
250    fi
251    cd ${SETTE_DIR}
252    . ./prepare_job.sh input_GYRE.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
253    cd ${SETTE_DIR}
254    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
255
256    cd ${SETTE_DIR}
257    export TEST_NAME="REPRO_2_2"
258    . ./prepare_exe_dir.sh
259    JOB_FILE=${EXE_DIR}/run_job.sh
260    NPROC=4
261    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
262    cd ${EXE_DIR}
263    set_namelist namelist_cfg cn_exp \"GYRE_22\"
264    set_namelist namelist_cfg nn_it000 1
265    set_namelist namelist_cfg nn_itend 60
266    set_namelist namelist_cfg nn_fwb 0
267    set_namelist namelist_cfg ln_ctl .false.
268    set_namelist namelist_cfg ln_clobber .true.
269    set_namelist namelist_cfg ln_linssh .true.
270    set_namelist namelist_cfg ln_read_cfg .false.
271    set_namelist namelist_cfg jpni 2
272    set_namelist namelist_cfg jpnj 2
273    set_namelist namelist_cfg jpnij 4
274    if [ ${USING_MPMD} == "yes" ] ; then
275       set_xio_using_server iodef.xml true
276    else
277       set_xio_using_server iodef.xml false
278    fi
279    cd ${SETTE_DIR}
280    . ./prepare_job.sh input_GYRE.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
281    cd ${SETTE_DIR}
282    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
283
284fi
285
286# TESTS FOR ORCA2_LIM_PISCES CONFIGURATION
287if [ ${config} -eq 3 ] ;  then
288    ## Restartability tests for ORCA2_LIM_PISCES
289    export TEST_NAME="LONG"
290    cd ${CONFIG_DIR}
291    . ./makenemo -m ${CMP_NAM} -n ORCA2LIMPIS_LONG -r ORCA2_LIM_PISCES -j 8 del_key ${DEL_KEYS}
292    cd ${SETTE_DIR}
293    . ./param.cfg
294    . ./all_functions.sh
295    . ./prepare_exe_dir.sh
296    JOB_FILE=${EXE_DIR}/run_job.sh
297    NPROC=8
298    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
299    cd ${EXE_DIR}
300    set_namelist namelist_cfg cn_exp \"O2LP_LONG\"
301    set_namelist namelist_cfg nn_it000 1
302    set_namelist namelist_cfg nn_itend 150
303    set_namelist namelist_cfg nn_stock 75
304    set_namelist namelist_cfg ln_clobber .true.
305    set_namelist namelist_cfg ln_read_cfg .true.
306    set_namelist namelist_cfg ln_linssh .false.
307    set_namelist namelist_cfg nn_fwb 0
308    set_namelist namelist_cfg jpni 2
309    set_namelist namelist_cfg jpnj 4
310    set_namelist namelist_cfg jpnij 8
311    set_namelist namelist_top_cfg ln_trcdta .false.
312    set_namelist namelist_top_cfg ln_diatrc .false.
313    # put ln_ironsed, ln_river, ln_ndepo, ln_dust to false
314    # if not you need input files, and for tests is not necessary
315    set_namelist namelist_pisces_cfg ln_presatm .false.
316    set_namelist namelist_pisces_cfg ln_varpar .false.
317    set_namelist namelist_pisces_cfg ln_dust .false.
318    set_namelist namelist_pisces_cfg ln_solub .false.
319    set_namelist namelist_pisces_cfg ln_river .false.
320    set_namelist namelist_pisces_cfg ln_ndepo .false.
321    set_namelist namelist_pisces_cfg ln_ironsed .false.
322    set_namelist namelist_pisces_cfg ln_hydrofe .false.
323    if [ ${USING_MPMD} == "yes" ] ; then
324       set_xio_using_server iodef.xml true
325    else
326       set_xio_using_server iodef.xml false
327    fi
328    cd ${SETTE_DIR}
329    . ./prepare_job.sh input_ORCA2_LIM_PISCES.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
330   
331    cd ${SETTE_DIR}
332    export TEST_NAME="SHORT"
333    . ./prepare_exe_dir.sh
334    cd ${EXE_DIR}
335    set_namelist namelist_cfg cn_exp \"O2LP_SHORT\"
336    set_namelist namelist_cfg nn_it000 76
337    set_namelist namelist_cfg nn_itend 150
338    set_namelist namelist_cfg nn_stock 75
339    set_namelist namelist_cfg ln_rstart .true.
340    set_namelist namelist_cfg nn_rstctl 2
341    set_namelist namelist_cfg ln_clobber .true.
342    set_namelist namelist_cfg ln_read_cfg .true.
343    set_namelist namelist_cfg ln_linssh .false.
344    set_namelist namelist_cfg nn_fwb 0
345    set_namelist namelist_cfg jpni 2
346    set_namelist namelist_cfg jpnj 4
347    set_namelist namelist_cfg jpnij 8
348    set_namelist namelist_top_cfg ln_diatrc .false.
349    set_namelist namelist_top_cfg ln_rsttr .true.
350    set_namelist namelist_top_cfg nn_rsttr 2
351    set_namelist namelist_cfg cn_ocerst_in \"O2LP_LONG_00000075_restart\"
352    set_namelist namelist_ice_cfg cn_icerst_in \"O2LP_LONG_00000075_restart_ice\"
353    set_namelist namelist_top_cfg cn_trcrst_in \"O2LP_LONG_00000075_restart_trc\"
354    # put ln_ironsed, ln_river, ln_ndepo, ln_dust
355    # if not you need input files, and for tests is not necessary
356    set_namelist namelist_pisces_cfg ln_presatm .false.
357    set_namelist namelist_pisces_cfg ln_varpar .false.
358    set_namelist namelist_pisces_cfg ln_dust .false.
359    set_namelist namelist_pisces_cfg ln_solub .false.
360    set_namelist namelist_pisces_cfg ln_river .false.
361    set_namelist namelist_pisces_cfg ln_ndepo .false.
362    set_namelist namelist_pisces_cfg ln_ironsed .false.
363    set_namelist namelist_pisces_cfg ln_hydrofe .false.
364    # put ln_pisdmp to false : no restoring to global mean value
365    set_namelist namelist_pisces_cfg ln_pisdmp .false.
366    for (( i=1; i<=$NPROC; i++)) ; do
367        L_NPROC=$(( $i - 1 ))
368        L_NPROC=`printf "%04d\n" ${L_NPROC}`
369        ln -sf ../LONG/O2LP_LONG_00000075_restart_${L_NPROC}.nc .
370        ln -sf ../LONG/O2LP_LONG_00000075_restart_trc_${L_NPROC}.nc .
371        ln -sf ../LONG/O2LP_LONG_00000075_restart_ice_${L_NPROC}.nc .
372    done
373    if [ ${USING_MPMD} == "yes" ] ; then
374       set_xio_using_server iodef.xml true
375    else
376       set_xio_using_server iodef.xml false
377    fi
378    cd ${SETTE_DIR}
379    . ./prepare_job.sh input_ORCA2_LIM_PISCES.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
380    cd ${SETTE_DIR}
381    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
382fi
383
384if [ ${config} -eq 4 ] ;  then
385    ## Reproducibility tests for ORCA2_LIM_PISCES
386    export TEST_NAME="REPRO_4_4"
387    cd ${CONFIG_DIR}
388    . ./makenemo -m ${CMP_NAM} -n ORCA2LIMPIS_16 -r ORCA2_LIM_PISCES -j 8 add_key "key_mpp_rep" del_key ${DEL_KEYS}
389    cd ${SETTE_DIR}
390    . ./param.cfg
391    . ./all_functions.sh
392    . ./prepare_exe_dir.sh
393    JOB_FILE=${EXE_DIR}/run_job.sh
394    NPROC=16
395    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
396    cd ${EXE_DIR}
397    set_namelist namelist_cfg nn_it000 1
398    set_namelist namelist_cfg nn_itend 75
399    set_namelist namelist_cfg nn_fwb 0
400    set_namelist namelist_cfg ln_ctl .false.
401    set_namelist namelist_cfg ln_clobber .true.
402    set_namelist namelist_cfg ln_read_cfg .true.
403    set_namelist namelist_cfg ln_linssh .false.
404    set_namelist namelist_cfg jpni 4
405    set_namelist namelist_cfg jpnj 4
406    set_namelist namelist_cfg jpnij 16
407    set_namelist namelist_top_cfg ln_trcdta .false.
408    set_namelist namelist_top_cfg ln_diatrc .false.
409    # put ln_ironsed, ln_river, ln_ndepo, ln_dust to false
410    # if not you need input files, and for tests is not necessary
411    set_namelist namelist_pisces_cfg ln_presatm .false.
412    set_namelist namelist_pisces_cfg ln_varpar .false.
413    set_namelist namelist_pisces_cfg ln_dust .false.
414    set_namelist namelist_pisces_cfg ln_solub .false.
415    set_namelist namelist_pisces_cfg ln_river .false.
416    set_namelist namelist_pisces_cfg ln_ndepo .false.
417    set_namelist namelist_pisces_cfg ln_ironsed .false.
418    set_namelist namelist_pisces_cfg ln_hydrofe .false.
419    # put ln_pisdmp to false : no restoring to global mean value
420    set_namelist namelist_pisces_cfg ln_pisdmp .false.
421    if [ ${USING_MPMD} == "yes" ] ; then
422       set_xio_using_server iodef.xml true
423    else
424       set_xio_using_server iodef.xml false
425    fi
426    cd ${SETTE_DIR}
427    . ./prepare_job.sh input_ORCA2_LIM_PISCES.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
428    cd ${SETTE_DIR}
429    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
430
431    cd ${SETTE_DIR}
432    export TEST_NAME="REPRO_2_8"
433    . ./prepare_exe_dir.sh
434    JOB_FILE=${EXE_DIR}/run_job.sh
435    NPROC=16
436    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
437    cd ${EXE_DIR}
438    set_namelist namelist_cfg nn_it000 1
439    set_namelist namelist_cfg nn_itend 75
440    set_namelist namelist_cfg ln_clobber .true.
441    set_namelist namelist_cfg nn_fwb 0
442    set_namelist namelist_cfg jpni 2
443    set_namelist namelist_cfg jpnj 8
444    set_namelist namelist_cfg jpnij 16
445#   set_namelist namelist_cfg nn_solv 2
446    set_namelist namelist_top_cfg ln_trcdta .false.
447    set_namelist namelist_top_cfg ln_diatrc .false.
448    # put ln_ironsed, ln_river, ln_ndepo, ln_dust to false
449    # if not you need input files, and for tests is not necessary
450    set_namelist namelist_pisces_cfg ln_presatm .false.
451    set_namelist namelist_pisces_cfg ln_varpar .false.
452    set_namelist namelist_pisces_cfg ln_dust .false.
453    set_namelist namelist_pisces_cfg ln_solub .false.
454    set_namelist namelist_pisces_cfg ln_river .false.
455    set_namelist namelist_pisces_cfg ln_ndepo .false.
456    set_namelist namelist_pisces_cfg ln_ironsed .false.
457    set_namelist namelist_pisces_cfg ln_hydrofe .false.
458    # put ln_pisdmp to false : no restoring to global mean value
459    set_namelist namelist_pisces_cfg ln_pisdmp .false.
460    if [ ${USING_MPMD} == "yes" ] ; then
461       set_xio_using_server iodef.xml true
462    else
463       set_xio_using_server iodef.xml false
464    fi
465    cd ${SETTE_DIR}
466    . ./prepare_job.sh input_ORCA2_LIM_PISCES.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
467    cd ${SETTE_DIR}
468    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
469fi
470
471# TESTS FOR ORCA2_OFF_PISCES CONFIGURATION
472if [ ${config} -eq 5 ] ;  then
473    ## Restartability tests for ORCA2_OFF_PISCES
474    export TEST_NAME="LONG"
475    cd ${CONFIG_DIR}
476    . ./makenemo -m ${CMP_NAM} -n ORCA2OFFPIS_LONG -r ORCA2_OFF_PISCES -j 8 add_key "key_mpp_rep" del_key ${DEL_KEYS}
477    cd ${SETTE_DIR}
478    . ./param.cfg
479    . ./all_functions.sh
480    . ./prepare_exe_dir.sh
481    JOB_FILE=${EXE_DIR}/run_job.sh
482    NPROC=8
483    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
484    cd ${EXE_DIR}
485    set_namelist namelist_cfg cn_exp \"OFFP_LONG\"
486    set_namelist namelist_cfg nn_it000 1
487    set_namelist namelist_cfg nn_itend 40
488    set_namelist namelist_cfg nn_stock 20
489    set_namelist namelist_cfg ln_clobber .true.
490    set_namelist namelist_cfg jpni 2
491    set_namelist namelist_cfg jpnj 4
492    set_namelist namelist_cfg jpnij 8
493    set_namelist namelist_top_cfg ln_trcdta .false.
494    set_namelist namelist_top_cfg ln_diatrc .false.
495    # put ln_ironsed, ln_river, ln_ndepo, ln_dust to false
496    # if not you need input files, and for tests is not necessary
497    set_namelist namelist_pisces_cfg ln_presatm .false.
498    set_namelist namelist_pisces_cfg ln_varpar .false.
499    set_namelist namelist_pisces_cfg ln_dust .false.
500    set_namelist namelist_pisces_cfg ln_solub .false.
501    set_namelist namelist_pisces_cfg ln_river .false.
502    set_namelist namelist_pisces_cfg ln_ndepo .false.
503    set_namelist namelist_pisces_cfg ln_ironsed .false.
504    set_namelist namelist_pisces_cfg ln_hydrofe .false.
505    # put ln_pisdmp to false : no restoring to global mean value
506    set_namelist namelist_pisces_cfg ln_pisdmp .false.
507    if [ ${USING_MPMD} == "yes" ] ; then
508       set_xio_using_server iodef.xml true
509    else
510       set_xio_using_server iodef.xml false
511    fi
512    cd ${SETTE_DIR}
513    . ./prepare_job.sh input_ORCA2_OFF_PISCES.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
514   
515    cd ${SETTE_DIR}
516    export TEST_NAME="SHORT"
517    . ./prepare_exe_dir.sh
518    cd ${EXE_DIR}
519    set_namelist namelist_cfg cn_exp \"OFFP_SHORT\"
520    set_namelist namelist_cfg nn_it000 21
521    set_namelist namelist_cfg nn_itend 40
522    set_namelist namelist_cfg nn_stock 20
523    set_namelist namelist_cfg ln_clobber .true.
524    set_namelist namelist_cfg jpni 2
525    set_namelist namelist_cfg jpnj 4
526    set_namelist namelist_cfg jpnij 8
527    set_namelist namelist_top_cfg ln_diatrc .false.
528    set_namelist namelist_top_cfg ln_rsttr .true.
529    set_namelist namelist_top_cfg nn_rsttr 2
530    set_namelist namelist_top_cfg cn_trcrst_in \"OFFP_LONG_00000020_restart_trc\"
531    for (( i=1; i<=$NPROC; i++)) ; do
532        L_NPROC=$(( $i - 1 ))
533        L_NPROC=`printf "%04d\n" ${L_NPROC}`
534        ln -sf ../LONG/OFFP_LONG_00000020_restart_trc_${L_NPROC}.nc .
535    done
536    # put ln_ironsed, ln_river, ln_ndepo, ln_dust
537    # if not you need input files, and for tests is not necessary
538    set_namelist namelist_pisces_cfg ln_presatm .false.
539    set_namelist namelist_pisces_cfg ln_varpar .false.
540    set_namelist namelist_pisces_cfg ln_dust .false.
541    set_namelist namelist_pisces_cfg ln_solub .false.
542    set_namelist namelist_pisces_cfg ln_river .false.
543    set_namelist namelist_pisces_cfg ln_ndepo .false.
544    set_namelist namelist_pisces_cfg ln_ironsed .false.
545    set_namelist namelist_pisces_cfg ln_hydrofe .false.
546    # put ln_pisdmp to false : no restoring to global mean value
547    set_namelist namelist_pisces_cfg ln_pisdmp .false.
548    if [ ${USING_MPMD} == "yes" ] ; then
549       set_xio_using_server iodef.xml true
550    else
551       set_xio_using_server iodef.xml false
552    fi
553    cd ${SETTE_DIR}
554    . ./prepare_job.sh input_ORCA2_OFF_PISCES.cfg $NPROC ${TEST_NAME}  ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
555    cd ${SETTE_DIR}
556    . ./fcm_job.sh $NPROC  ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
557fi
558
559if [ ${config} -eq 6 ] ;  then
560    ## Reproducibility tests for ORCA2_OFF_PISCES
561    export TEST_NAME="REPRO_4_4"
562    cd ${CONFIG_DIR}
563    . ./makenemo -m ${CMP_NAM} -n ORCA2OFFPIS_16 -r ORCA2_OFF_PISCES -j 8 add_key "key_mpp_rep" del_key ${DEL_KEYS}
564    cd ${SETTE_DIR}
565    . ./param.cfg
566    . ./all_functions.sh
567    . ./prepare_exe_dir.sh
568    JOB_FILE=${EXE_DIR}/run_job.sh
569    NPROC=16
570    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
571    cd ${EXE_DIR}
572    set_namelist namelist_cfg nn_it000 1
573    set_namelist namelist_cfg nn_itend 40
574    set_namelist namelist_cfg ln_ctl .false.
575    set_namelist namelist_cfg ln_clobber .true.
576    set_namelist namelist_cfg jpni 4
577    set_namelist namelist_cfg jpnj 4
578    set_namelist namelist_cfg jpnij 16
579    set_namelist namelist_top_cfg ln_trcdta .false.
580    set_namelist namelist_top_cfg ln_diatrc .false.
581    # put ln_ironsed, ln_river, ln_ndepo, ln_dust to false
582    # if not you need input files, and for tests is not necessary
583    set_namelist namelist_pisces_cfg ln_presatm .false.
584    set_namelist namelist_pisces_cfg ln_varpar .false.
585    set_namelist namelist_pisces_cfg ln_dust .false.
586    set_namelist namelist_pisces_cfg ln_solub .false.
587    set_namelist namelist_pisces_cfg ln_river .false.
588    set_namelist namelist_pisces_cfg ln_ndepo .false.
589    set_namelist namelist_pisces_cfg ln_ironsed .false.
590    set_namelist namelist_pisces_cfg ln_hydrofe .false.
591    # put ln_pisdmp to false : no restoring to global mean value
592    set_namelist namelist_pisces_cfg ln_pisdmp .false.
593    if [ ${USING_MPMD} == "yes" ] ; then
594       set_xio_using_server iodef.xml true
595    else
596       set_xio_using_server iodef.xml false
597    fi
598    cd ${SETTE_DIR}
599    . ./prepare_job.sh input_ORCA2_OFF_PISCES.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
600    cd ${SETTE_DIR}
601    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
602
603    cd ${SETTE_DIR}
604    export TEST_NAME="REPRO_2_8"
605    . ./prepare_exe_dir.sh
606    JOB_FILE=${EXE_DIR}/run_job.sh
607    NPROC=16
608    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
609    cd ${EXE_DIR}
610    set_namelist namelist_cfg nn_it000 1
611    set_namelist namelist_cfg nn_itend 40
612    set_namelist namelist_cfg ln_ctl .false.
613    set_namelist namelist_cfg ln_clobber .true.
614    set_namelist namelist_cfg jpni 2
615    set_namelist namelist_cfg jpnj 8
616    set_namelist namelist_cfg jpnij 16
617    set_namelist namelist_top_cfg ln_trcdta .false.
618    set_namelist namelist_top_cfg ln_diatrc .false.
619    # put ln_ironsed, ln_river, ln_ndepo, ln_dust to false
620    # if not you need input files, and for tests is not necessary
621    set_namelist namelist_pisces_cfg ln_presatm .false.
622    set_namelist namelist_pisces_cfg ln_varpar .false.
623    set_namelist namelist_pisces_cfg ln_dust .false.
624    set_namelist namelist_pisces_cfg ln_solub .false.
625    set_namelist namelist_pisces_cfg ln_river .false.
626    set_namelist namelist_pisces_cfg ln_ndepo .false.
627    set_namelist namelist_pisces_cfg ln_ironsed .false.
628    set_namelist namelist_pisces_cfg ln_hydrofe .false.
629    # put ln_pisdmp to false : no restoring to global mean value
630    set_namelist namelist_pisces_cfg ln_pisdmp .false.
631    if [ ${USING_MPMD} == "yes" ] ; then
632       set_xio_using_server iodef.xml true
633    else
634       set_xio_using_server iodef.xml false
635    fi
636    cd ${SETTE_DIR}
637    . ./prepare_job.sh input_ORCA2_OFF_PISCES.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
638    cd ${SETTE_DIR}
639    . ./fcm_job.sh $NPROC  ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
640fi
641
642
643# TESTS FOR ORCA2_LIM3 CONFIGURATION
644if [ ${config} -eq 7 ] ;  then
645    ## Restartability tests for ORCA2_LIM3
646    export TEST_NAME="LONG"
647    cd ${CONFIG_DIR}
648    . ./makenemo -m ${CMP_NAM} -n ORCA2LIM3_LONG -r ORCA2_LIM3 -j 8 del_key ${DEL_KEYS}
649    cd ${SETTE_DIR}
650    . ./param.cfg
651    . ./all_functions.sh
652    . ./prepare_exe_dir.sh
653    JOB_FILE=${EXE_DIR}/run_job.sh
654    NPROC=4
655    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
656    cd ${EXE_DIR}
657    set_namelist namelist_cfg cn_exp \"O2L3_LONG\"
658    set_namelist namelist_cfg nn_it000 1
659    set_namelist namelist_cfg nn_itend 150
660    set_namelist namelist_cfg nn_stock 75
661    set_namelist namelist_cfg ln_clobber .true.
662    set_namelist namelist_cfg ln_read_cfg .true.
663    set_namelist namelist_cfg ln_linssh .false.
664    set_namelist namelist_cfg nn_msh 1
665    set_namelist namelist_cfg nn_fwb 0
666    set_namelist namelist_cfg jpni 2
667    set_namelist namelist_cfg jpnj 2
668    set_namelist namelist_cfg jpnij 4
669    if [ ${USING_MPMD} == "yes" ] ; then
670       set_xio_using_server iodef.xml true
671    else
672       set_xio_using_server iodef.xml false
673    fi
674    cd ${SETTE_DIR}
675    . ./prepare_job.sh input_ORCA2_LIM3.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
676   
677    cd ${SETTE_DIR}
678    export TEST_NAME="SHORT"
679    . ./prepare_exe_dir.sh
680    cd ${EXE_DIR}
681    set_namelist namelist_cfg cn_exp \"O2L3_SHORT\"
682    set_namelist namelist_cfg nn_it000 76
683    set_namelist namelist_cfg nn_itend 150
684    set_namelist namelist_cfg nn_stock 75
685    set_namelist namelist_cfg ln_rstart .true.
686    set_namelist namelist_cfg nn_rstctl 2
687    set_namelist namelist_cfg ln_clobber .true.
688    set_namelist namelist_cfg ln_read_cfg .true.
689    set_namelist namelist_cfg ln_linssh .false.
690    set_namelist namelist_cfg nn_msh 1
691    set_namelist namelist_cfg nn_fwb 0
692    set_namelist namelist_cfg jpni 2
693    set_namelist namelist_cfg jpnj 2
694    set_namelist namelist_cfg jpnij 4
695    set_namelist namelist_cfg cn_ocerst_in \"O2L3_LONG_00000075_restart\"
696    set_namelist namelist_ice_cfg cn_icerst_in \"O2L3_LONG_00000075_restart_ice\"
697    for (( i=1; i<=$NPROC; i++)) ; do
698        L_NPROC=$(( $i - 1 ))
699        L_NPROC=`printf "%04d\n" ${L_NPROC}`
700        ln -sf ../LONG/O2L3_LONG_00000075_restart_${L_NPROC}.nc .
701        ln -sf ../LONG/O2L3_LONG_00000075_restart_ice_${L_NPROC}.nc .
702    done
703    if [ ${USING_MPMD} == "yes" ] ; then
704       set_xio_using_server iodef.xml true
705    else
706       set_xio_using_server iodef.xml false
707    fi
708    cd ${SETTE_DIR}
709    . ./prepare_job.sh input_ORCA2_LIM3.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
710    cd ${SETTE_DIR}
711    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
712fi
713
714if [ ${config} -eq 8 ] ;  then
715    ## Reproducibility tests for ORCA2_LIM3
716    export TEST_NAME="REPRO_8_4"
717    cd ${CONFIG_DIR}
718    . ./makenemo -m ${CMP_NAM} -n ORCA2LIM3_32 -r ORCA2_LIM3 -j 8 add_key "key_mpp_rep" del_key ${DEL_KEYS}
719    cd ${SETTE_DIR}
720    . ./param.cfg
721    . ./all_functions.sh
722    . ./prepare_exe_dir.sh
723    JOB_FILE=${EXE_DIR}/run_job.sh
724    NPROC=32
725    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
726    cd ${EXE_DIR}
727    set_namelist namelist_cfg nn_it000 1
728    set_namelist namelist_cfg nn_itend 75
729    set_namelist namelist_cfg nn_fwb 0
730    set_namelist namelist_cfg ln_ctl .false.
731    set_namelist namelist_cfg ln_clobber .true.
732    set_namelist namelist_cfg ln_read_cfg .true.
733    set_namelist namelist_cfg ln_linssh .false.
734    set_namelist namelist_cfg ln_hpg_sco .true.
735    set_namelist namelist_cfg jpni 8
736    set_namelist namelist_cfg jpnj 4
737    set_namelist namelist_cfg jpnij 32
738    if [ ${USING_MPMD} == "yes" ] ; then
739       set_xio_using_server iodef.xml true
740    else
741       set_xio_using_server iodef.xml false
742    fi
743    cd ${SETTE_DIR}
744    . ./prepare_job.sh input_ORCA2_LIM3.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
745    cd ${SETTE_DIR}
746    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
747
748    cd ${SETTE_DIR}
749    export TEST_NAME="REPRO_4_8"
750    . ./prepare_exe_dir.sh
751    JOB_FILE=${EXE_DIR}/run_job.sh
752    NPROC=32
753    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
754    cd ${EXE_DIR}
755    set_namelist namelist_cfg nn_it000 1
756    set_namelist namelist_cfg nn_itend 75
757    set_namelist namelist_cfg ln_clobber .true.
758    set_namelist namelist_cfg ln_read_cfg .true.
759    set_namelist namelist_cfg ln_linssh .false.
760    set_namelist namelist_cfg ln_hpg_sco .true.
761    set_namelist namelist_cfg nn_fwb 0
762    set_namelist namelist_cfg jpni 4
763    set_namelist namelist_cfg jpnj 8
764    set_namelist namelist_cfg jpnij 32
765    if [ ${USING_MPMD} == "yes" ] ; then
766       set_xio_using_server iodef.xml true
767    else
768       set_xio_using_server iodef.xml false
769    fi
770
771    cd ${SETTE_DIR}
772    . ./prepare_job.sh input_ORCA2_LIM3.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
773    cd ${SETTE_DIR}
774    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
775fi
776
777
778# TESTS FOR AMM12 CONFIGURATION
779if [ ${config} -eq 9 ] ;  then
780    ## Restartability tests for AMM12
781    export TEST_NAME="LONG"
782    cd ${CONFIG_DIR}
783    . ./makenemo -m ${CMP_NAM} -n AMM12_LONG -r AMM12 -j 8 add_key "key_tide" del_key ${DEL_KEYS}
784    cd ${SETTE_DIR}
785    . ./param.cfg
786    . ./all_functions.sh
787    . ./prepare_exe_dir.sh
788    JOB_FILE=${EXE_DIR}/run_job.sh
789    NPROC=32
790    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
791    cd ${EXE_DIR}
792    set_namelist namelist_cfg nn_it000 1
793    set_namelist namelist_cfg nn_itend 576
794    set_namelist namelist_cfg nn_stock 288
795    set_namelist namelist_cfg nn_fwb 0
796    set_namelist namelist_cfg ln_ctl .false.
797    set_namelist namelist_cfg ln_clobber .true.
798    set_namelist namelist_cfg ln_read_cfg .true.
799    set_namelist namelist_cfg ln_linssh .false.
800    set_namelist namelist_cfg jpni 8
801    set_namelist namelist_cfg jpnj 4
802    set_namelist namelist_cfg jpnij 32
803    if [ ${USING_MPMD} == "yes" ] ; then
804       set_xio_using_server iodef.xml true
805    else
806       set_xio_using_server iodef.xml false
807    fi
808    cd ${SETTE_DIR}
809    . ./prepare_job.sh input_AMM12.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
810
811    cd ${SETTE_DIR}
812    export TEST_NAME="SHORT"
813    . ./prepare_exe_dir.sh
814    cd ${EXE_DIR}
815    set_namelist namelist_cfg nn_it000 289
816    set_namelist namelist_cfg nn_itend 576
817    set_namelist namelist_cfg nn_fwb 0
818    set_namelist namelist_cfg ln_ctl .false.
819    set_namelist namelist_cfg ln_clobber .true.
820    set_namelist namelist_cfg ln_read_cfg .true.
821    set_namelist namelist_cfg ln_linssh .false.
822    set_namelist namelist_cfg jpni 8
823    set_namelist namelist_cfg jpnj 4
824    set_namelist namelist_cfg jpnij 32
825    set_namelist namelist_cfg ln_rstart .true.
826    set_namelist namelist_cfg nn_rstctl 2
827    set_namelist namelist_cfg cn_ocerst_in \"AMM12_00000288_restart_oce_out\"
828    set_namelist namelist_cfg nn_date0 20120102
829    for (( i=1; i<=$NPROC; i++)) ; do
830        L_NPROC=$(( $i - 1 ))
831        L_NPROC=`printf "%04d\n" ${L_NPROC}`
832        ln -sf ../LONG/AMM12_00000288_restart_oce_out_${L_NPROC}.nc .
833    done
834    if [ ${USING_MPMD} == "yes" ] ; then
835       set_xio_using_server iodef.xml true
836    else
837       set_xio_using_server iodef.xml false
838    fi
839    cd ${SETTE_DIR}
840    . ./prepare_job.sh input_AMM12.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
841    cd ${SETTE_DIR}
842    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
843fi
844
845if [ ${config} -eq 10 ] ;  then
846## Reproducibility tests for AMM12
847    export TEST_NAME="REPRO_8_4"
848    cd ${CONFIG_DIR}
849    . ./makenemo -m ${CMP_NAM} -n AMM12_32 -r AMM12 -j 8 add_key "key_mpp_rep key_tide" del_key ${DEL_KEYS}
850    cd ${SETTE_DIR}
851    . ./param.cfg
852    . ./all_functions.sh
853    . ./prepare_exe_dir.sh
854    JOB_FILE=${EXE_DIR}/run_job.sh
855    NPROC=32
856    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
857    cd ${EXE_DIR}
858    set_namelist namelist_cfg nn_it000 1
859    set_namelist namelist_cfg nn_itend 576
860    set_namelist namelist_cfg nn_fwb 0
861    set_namelist namelist_cfg ln_ctl .false.
862    set_namelist namelist_cfg ln_clobber .true.
863    set_namelist namelist_cfg ln_read_cfg .true.
864    set_namelist namelist_cfg ln_write_cfg .true.
865    set_namelist namelist_cfg ln_linssh .false.
866    set_namelist namelist_cfg nn_msh 1
867    set_namelist namelist_cfg jpni 8
868    set_namelist namelist_cfg jpnj 4
869    set_namelist namelist_cfg jpnij 32
870    if [ ${USING_MPMD} == "yes" ] ; then
871       set_xio_using_server iodef.xml true
872    else
873       set_xio_using_server iodef.xml false
874    fi
875    cd ${SETTE_DIR}
876    . ./prepare_job.sh input_AMM12.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
877    cd ${SETTE_DIR}
878    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
879
880    cd ${SETTE_DIR}
881    export TEST_NAME="REPRO_4_8"
882    . ./prepare_exe_dir.sh
883    JOB_FILE=${EXE_DIR}/run_job.sh
884    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
885    cd ${EXE_DIR}
886    set_namelist namelist_cfg nn_it000 1
887    set_namelist namelist_cfg nn_itend 576
888    set_namelist namelist_cfg nn_fwb 0
889    set_namelist namelist_cfg ln_ctl .false.
890    set_namelist namelist_cfg ln_clobber .true.
891    set_namelist namelist_cfg ln_read_cfg .true.
892    set_namelist namelist_cfg ln_write_cfg .true.
893    set_namelist namelist_cfg ln_linssh .false.
894    set_namelist namelist_cfg nn_msh 1
895    set_namelist namelist_cfg jpni 4
896    set_namelist namelist_cfg jpnj 8
897    set_namelist namelist_cfg jpnij 32
898    if [ ${USING_MPMD} == "yes" ] ; then
899       set_xio_using_server iodef.xml true
900    else
901       set_xio_using_server iodef.xml false
902    fi
903    cd ${SETTE_DIR}
904    . ./prepare_job.sh input_AMM12.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
905    cd ${SETTE_DIR}
906    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
907fi
908
909
910# TESTS FOR ORCA2_SAS_LIM CONFIGURATION
911if [ ${config} -eq 11 ] ;  then
912    ## Restartability tests for SAS
913    export TEST_NAME="LONG"
914    cd ${CONFIG_DIR}
915    . ./makenemo -m ${CMP_NAM} -n SAS_LONG -r ORCA2_SAS_LIM -j 8 add_key "key_mpp_rep" del_key ${DEL_KEYS}
916    cd ${SETTE_DIR}
917    . ./param.cfg
918    . ./all_functions.sh
919    . ./prepare_exe_dir.sh
920    JOB_FILE=${EXE_DIR}/run_job.sh
921    NPROC=32
922    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
923    cd ${EXE_DIR}
924    set_namelist namelist_cfg cn_exp \"SAS\"
925    set_namelist namelist_cfg nn_it000 1
926    set_namelist namelist_cfg nn_itend 100
927    set_namelist namelist_cfg nn_stock 50
928    set_namelist namelist_cfg ln_ctl .false.
929    set_namelist namelist_cfg ln_clobber .true.
930    set_namelist namelist_cfg ln_read_cfg .true.
931    set_namelist namelist_cfg ln_linssh .true.
932    set_namelist namelist_cfg nn_fwb 0
933    set_namelist namelist_cfg jpni 8
934    set_namelist namelist_cfg jpnj 4
935    set_namelist namelist_cfg jpnij 32
936    if [ ${USING_MPMD} == "yes" ] ; then
937       set_xio_using_server iodef.xml true
938    else
939       set_xio_using_server iodef.xml false
940    fi
941    cd ${SETTE_DIR}
942    . ./prepare_job.sh input_SAS.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
943
944    cd ${SETTE_DIR}
945    export TEST_NAME="SHORT"
946    . ./prepare_exe_dir.sh
947    cd ${EXE_DIR}
948    set_namelist namelist_cfg cn_exp \"SAS\"
949    set_namelist namelist_cfg nn_it000 51
950    set_namelist namelist_cfg nn_itend 100
951    set_namelist namelist_cfg ln_ctl .false.
952    set_namelist namelist_cfg ln_clobber .true.
953    set_namelist namelist_cfg ln_read_cfg .true.
954    set_namelist namelist_cfg ln_linssh .true.
955    set_namelist namelist_cfg nn_fwb 0
956    set_namelist namelist_cfg jpni 8
957    set_namelist namelist_cfg jpnj 4
958    set_namelist namelist_cfg jpnij 32
959    set_namelist namelist_cfg nn_rstctl 2
960    set_namelist namelist_cfg cn_ocerst_in \"SAS_00000050_restart\"
961    if [ ${USING_MPMD} == "yes" ] ; then
962       set_xio_using_server iodef.xml true
963    else
964       set_xio_using_server iodef.xml false
965    fi
966    for (( i=1; i<=$NPROC; i++)) ; do
967        L_NPROC=$(( $i - 1 ))
968        L_NPROC=`printf "%04d\n" ${L_NPROC}`
969        ln -sf ../LONG/SAS_00000050_restart_${L_NPROC}.nc .
970    done
971    cd ${SETTE_DIR}
972    . ./prepare_job.sh input_SAS.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
973    cd ${SETTE_DIR}
974    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
975fi
976
977# TESTS FOR ISOMIP CONFIGURATION
978if [ ${config} -eq 13 ] ;  then
979    ## Restartability tests for ISOMIP
980    export TEST_NAME="LONG"
981    cd ${CONFIG_DIR}
982    . ./makenemo -m ${CMP_NAM} -n ISOMIP_LONG -r ISOMIP -j 8 del_key ${DEL_KEYS}
983    cd ${SETTE_DIR}
984    . ./param.cfg
985    . ./all_functions.sh
986    . ./prepare_exe_dir.sh
987    JOB_FILE=${EXE_DIR}/run_job.sh
988    NPROC=4
989    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
990    cd ${EXE_DIR}
991    set_namelist namelist_cfg cn_exp \"ISOMIP_LONG\"
992    set_namelist namelist_cfg nn_it000 1
993    set_namelist namelist_cfg nn_itend 96
994    set_namelist namelist_cfg nn_stock 48
995    set_namelist namelist_cfg ln_clobber .true.
996    set_namelist namelist_cfg ln_read_cfg .true.
997    set_namelist namelist_cfg ln_linssh .true.
998    set_namelist namelist_cfg nn_fwb 0
999    set_namelist namelist_cfg jpni 2
1000    set_namelist namelist_cfg jpnj 2
1001    set_namelist namelist_cfg jpnij 4
1002    if [ ${USING_MPMD} == "yes" ] ; then
1003       set_xio_using_server iodef.xml true
1004    else
1005       set_xio_using_server iodef.xml false
1006    fi
1007    cd ${SETTE_DIR}
1008    . ./prepare_job.sh input_ISOMIP.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
1009
1010    cd ${SETTE_DIR}
1011    export TEST_NAME="SHORT"
1012    . ./prepare_exe_dir.sh
1013    cd ${EXE_DIR}
1014    set_namelist namelist_cfg cn_exp \"ISOMIP_SHORT\"
1015    set_namelist namelist_cfg nn_it000 49
1016    set_namelist namelist_cfg nn_itend 96
1017    set_namelist namelist_cfg nn_stock 48
1018    set_namelist namelist_cfg ln_rstart .true.
1019    set_namelist namelist_cfg nn_rstctl 2
1020    set_namelist namelist_cfg ln_clobber .true.
1021    set_namelist namelist_cfg ln_read_cfg .true.
1022    set_namelist namelist_cfg ln_linssh .true.
1023    set_namelist namelist_cfg nn_fwb 0
1024    set_namelist namelist_cfg jpni 2
1025    set_namelist namelist_cfg jpnj 2
1026    set_namelist namelist_cfg jpnij 4
1027    set_namelist namelist_cfg cn_ocerst_in \"ISOMIP_LONG_00000048_restart\"
1028    if [ ${USING_MPMD} == "yes" ] ; then
1029       set_xio_using_server iodef.xml true
1030    else
1031       set_xio_using_server iodef.xml false
1032    fi
1033    for (( i=1; i<=$NPROC; i++)) ; do
1034        L_NPROC=$(( $i - 1 ))
1035        L_NPROC=`printf "%04d\n" ${L_NPROC}`
1036        ln -sf ../LONG/ISOMIP_LONG_00000048_restart_${L_NPROC}.nc .
1037    done
1038    if [ ${USING_MPMD} == "yes" ] ; then
1039       set_xio_using_server iodef.xml true
1040    else
1041       set_xio_using_server iodef.xml false
1042    fi
1043    cd ${SETTE_DIR}
1044    . ./prepare_job.sh input_ISOMIP.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
1045    cd ${SETTE_DIR}
1046    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
1047fi
1048if [ ${config} -eq 14 ] ;  then
1049    ## Reproducibility tests for ISOMIP
1050    export TEST_NAME="REPRO_1_4"
1051    cd ${CONFIG_DIR}
1052    . ./makenemo -m ${CMP_NAM} -n ISOMIP_4 -r ISOMIP -j 8 add_key "key_mpp_rep" del_key ${DEL_KEYS}
1053    cd ${SETTE_DIR}
1054    . ./param.cfg
1055    . ./all_functions.sh
1056    . ./prepare_exe_dir.sh
1057    JOB_FILE=${EXE_DIR}/run_job.sh
1058    NPROC=4
1059    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
1060    cd ${EXE_DIR}
1061    set_namelist namelist_cfg cn_exp \"ISOMIP_14\"
1062    set_namelist namelist_cfg nn_it000 1
1063    set_namelist namelist_cfg nn_itend 48
1064    set_namelist namelist_cfg ln_ctl .false.
1065    set_namelist namelist_cfg ln_clobber .true.
1066    set_namelist namelist_cfg ln_read_cfg .true.
1067    set_namelist namelist_cfg ln_linssh .true.
1068    set_namelist namelist_cfg nn_fwb 0
1069    set_namelist namelist_cfg jpni 1
1070    set_namelist namelist_cfg jpnj 4
1071    set_namelist namelist_cfg jpnij 4
1072    if [ ${USING_MPMD} == "yes" ] ; then
1073       set_xio_using_server iodef.xml true
1074    else
1075       set_xio_using_server iodef.xml false
1076    fi
1077    cd ${SETTE_DIR}
1078    . ./prepare_job.sh input_ISOMIP.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
1079    cd ${SETTE_DIR}
1080    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
1081
1082    cd ${SETTE_DIR}
1083    export TEST_NAME="REPRO_2_2"
1084    . ./prepare_exe_dir.sh
1085    JOB_FILE=${EXE_DIR}/run_job.sh
1086    NPROC=4
1087    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
1088    cd ${EXE_DIR}
1089    set_namelist namelist_cfg cn_exp \"ISOMIP_22\"
1090    set_namelist namelist_cfg nn_it000 1
1091    set_namelist namelist_cfg nn_itend 48
1092    set_namelist namelist_cfg ln_ctl .false.
1093    set_namelist namelist_cfg ln_clobber .true.
1094    set_namelist namelist_cfg ln_read_cfg .true.
1095    set_namelist namelist_cfg ln_linssh .true.
1096    set_namelist namelist_cfg nn_fwb 0
1097    set_namelist namelist_cfg jpni 2
1098    set_namelist namelist_cfg jpnj 2
1099    set_namelist namelist_cfg jpnij 4
1100    if [ ${USING_MPMD} == "yes" ] ; then
1101       set_xio_using_server iodef.xml true
1102    else
1103       set_xio_using_server iodef.xml false
1104    fi
1105    cd ${SETTE_DIR}
1106    . ./prepare_job.sh input_ISOMIP.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
1107    cd ${SETTE_DIR}
1108    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
1109
1110fi
1111
1112## Test assimilation interface code, OBS and ASM for reproducibility
1113## Restartability not tested (ASM code not restartable while increments are being applied)
1114if [ ${config} -eq 15 ] ; then
1115   ## Reproducibility tests for ORCA2_LIM_OBS
1116    export TEST_NAME="REPRO_4_4"
1117    cd ${CONFIG_DIR}
1118    . ./makenemo -m ${CMP_NAM} -n ORCA2_LIM_OBS -r ORCA2_LIM -j 8 add_key "key_mpp_rep key_asminc" del_key ${DEL_KEYS}
1119    cd ${SETTE_DIR}
1120    . ./param.cfg
1121    . ./all_functions.sh
1122    . ./prepare_exe_dir.sh
1123    JOB_FILE=${EXE_DIR}/run_job.sh
1124    NPROC=16
1125    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
1126    cd ${EXE_DIR}
1127    set_namelist namelist_cfg nn_it000 1
1128    set_namelist namelist_cfg nn_itend 75
1129    set_namelist namelist_cfg nn_fwb 0
1130    set_namelist namelist_cfg ln_ctl .false.
1131    set_namelist namelist_cfg ln_clobber .true.
1132    set_namelist namelist_cfg ln_read_cfg .true.
1133    set_namelist namelist_cfg ln_linssh .false.
1134    set_namelist namelist_cfg jpni 4
1135    set_namelist namelist_cfg jpnj 4
1136    set_namelist namelist_cfg jpnij 16
1137    set_namelist namelist_cfg ln_diaobs .true.
1138    set_namelist namelist_cfg ln_t3d .true.
1139    set_namelist namelist_cfg ln_s3d .true.
1140    set_namelist namelist_cfg ln_sst .true.
1141    set_namelist namelist_cfg ln_sla .true.
1142    set_namelist namelist_cfg ln_sic .true.
1143    set_namelist namelist_cfg ln_vel3d .true.
1144    set_namelist namelist_cfg ln_bkgwri .true.
1145    set_namelist namelist_cfg ln_trainc .true.
1146    set_namelist namelist_cfg ln_dyninc .true.
1147    set_namelist namelist_cfg ln_sshinc .true.
1148    set_namelist namelist_cfg ln_asmiau .true.
1149    if [ ${USING_MPMD} == "yes" ] ; then
1150       set_xio_using_server iodef.xml true
1151    else
1152       set_xio_using_server iodef.xml false
1153    fi
1154    cd ${SETTE_DIR}
1155    . ./prepare_job.sh input_ORCA2_LIM_OBS.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
1156    cd ${SETTE_DIR}
1157    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
1158
1159   cd ${SETTE_DIR}
1160    export TEST_NAME="REPRO_2_8"
1161    . ./prepare_exe_dir.sh
1162    JOB_FILE=${EXE_DIR}/run_job.sh
1163    NPROC=16
1164    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
1165    cd ${EXE_DIR}
1166    set_namelist namelist_cfg nn_it000 1
1167    set_namelist namelist_cfg nn_itend 75
1168    set_namelist namelist_cfg nn_fwb 0
1169    set_namelist namelist_cfg ln_ctl .false.
1170    set_namelist namelist_cfg ln_clobber .true.
1171    set_namelist namelist_cfg ln_read_cfg .true.
1172    set_namelist namelist_cfg ln_linssh .false.
1173    set_namelist namelist_cfg jpni 2
1174    set_namelist namelist_cfg jpnj 8
1175    set_namelist namelist_cfg jpnij 16
1176    set_namelist namelist_cfg ln_diaobs .true.
1177    set_namelist namelist_cfg ln_t3d .true.
1178    set_namelist namelist_cfg ln_s3d .true.
1179    set_namelist namelist_cfg ln_sst .true.
1180    set_namelist namelist_cfg ln_sla .true.
1181    set_namelist namelist_cfg ln_sic .true.
1182    set_namelist namelist_cfg ln_vel3d .true.
1183    set_namelist namelist_cfg ln_bkgwri .true.
1184    set_namelist namelist_cfg ln_trainc .true.
1185    set_namelist namelist_cfg ln_dyninc .true.
1186    set_namelist namelist_cfg ln_sshinc .true.
1187    set_namelist namelist_cfg ln_asmiau .true.
1188    if [ ${USING_MPMD} == "yes" ] ; then
1189       set_xio_using_server iodef.xml true
1190    else
1191       set_xio_using_server iodef.xml false
1192    fi
1193    cd ${SETTE_DIR}
1194    . ./prepare_job.sh input_ORCA2_LIM_OBS.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
1195    cd ${SETTE_DIR}
1196    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
1197fi
1198# TEST FOR ORCA2_LIM_AGRIF : simple test of running AGRIF (no restartability neither reproducibility tests)
1199if [ ${config} -eq 16 ] ;  then
1200    ## ORCA2_LIM with Agulhas AGRIF zoom in MPI
1201    export TEST_NAME="SHORT"
1202    cd ${CONFIG_DIR}
1203    . ./makenemo -m ${CMP_NAM} -n ORCA2AGUL_1_2 -r ORCA2_LIM -j 8 add_key "key_mpp_rep key_agrif" del_key "key_zdftmx" del_key ${DEL_KEYS}
1204    cd ${SETTE_DIR}
1205    . ./param.cfg
1206    . ./all_functions.sh
1207    . ./prepare_exe_dir.sh
1208    JOB_FILE=${EXE_DIR}/run_job.sh
1209    NPROC=2
1210    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
1211    cd ${EXE_DIR}
1212    set_namelist namelist_cfg nn_it000 1
1213    set_namelist namelist_cfg nn_itend 75
1214    set_namelist namelist_cfg ln_ctl .false.
1215    set_namelist namelist_cfg ln_clobber .true.
1216    set_namelist namelist_cfg nn_fwb 0
1217    set_namelist namelist_cfg jpni 1
1218    set_namelist namelist_cfg jpnj 2
1219    set_namelist namelist_cfg jpnij 2
1220#
1221    set_namelist 1_namelist_cfg nn_it000 1
1222    set_namelist 1_namelist_cfg nn_itend 150
1223    set_namelist 1_namelist_cfg ln_ctl .false.
1224    set_namelist 1_namelist_cfg ln_clobber .true.
1225
1226    if [ ${USING_MPMD} == "yes" ] ; then
1227       set_xio_using_server iodef.xml true
1228    else
1229       set_xio_using_server iodef.xml false
1230    fi
1231    cd ${SETTE_DIR}
1232    . ./prepare_job.sh input_ORCA2_LIM_AGRIF.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
1233    cd ${SETTE_DIR}
1234    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
1235fi
1236
1237# test code corruption with AGRIF
1238# Compile and run with or without AGRIF ORCA2_LIM
1239if [ ${config} -eq 17 ] ;  then
1240    # First run same as 16 but without zoom
1241    export TEST_NAME="SHORT_NOZOOM"
1242    cd ${CONFIG_DIR}
1243    . ./makenemo -m ${CMP_NAM} -n ORCA2AGUL_2_2 -r ORCA2_LIM -j 8 add_key "key_mpp_rep key_agrif" del_key "key_zdftmx" del_key ${DEL_KEYS}
1244    cd ${SETTE_DIR}
1245    . ./param.cfg
1246    . ./all_functions.sh
1247    . ./prepare_exe_dir.sh
1248    JOB_FILE=${EXE_DIR}/run_job.sh
1249    NPROC=4
1250    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
1251    cd ${EXE_DIR}
1252    set_namelist namelist_cfg nn_it000 1
1253    set_namelist namelist_cfg nn_itend 75
1254    set_namelist namelist_cfg ln_ctl .false.
1255    set_namelist namelist_cfg ln_clobber .true.
1256    set_namelist namelist_cfg nn_fwb 0
1257    set_namelist namelist_cfg jpni 2
1258    set_namelist namelist_cfg jpnj 2
1259    set_namelist namelist_cfg jpnij 4
1260#
1261#   Set the number of fine grids to zero:   
1262    sed -i "1s/.*/0/" ${EXE_DIR}/AGRIF_FixedGrids.in
1263
1264    if [ ${USING_MPMD} == "yes" ] ; then
1265       set_xio_using_server iodef.xml true
1266    else
1267       set_xio_using_server iodef.xml false
1268    fi
1269    cd ${SETTE_DIR}
1270    . ./prepare_job.sh input_ORCA2_LIM_AGRIF.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
1271    cd ${SETTE_DIR}
1272    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
1273
1274    export TEST_NAME="SHORT_NOAGRIF"
1275    cd ${CONFIG_DIR}
1276    . ./makenemo -m ${CMP_NAM} -n ORCA2AGUL_2_2_NAG -r ORCA2_LIM -j 8 add_key "key_mpp_rep" del_key "key_zdftmx" del_key ${DEL_KEYS}
1277    cd ${SETTE_DIR}
1278    . ./param.cfg
1279    . ./all_functions.sh
1280    . ./prepare_exe_dir.sh
1281    JOB_FILE=${EXE_DIR}/run_job.sh
1282    NPROC=4
1283    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
1284    cd ${EXE_DIR}
1285    set_namelist namelist_cfg nn_it000 1
1286    set_namelist namelist_cfg nn_itend 75
1287    set_namelist namelist_cfg ln_ctl .false.
1288    set_namelist namelist_cfg ln_clobber .true.
1289    set_namelist namelist_cfg nn_fwb 0
1290    set_namelist namelist_cfg jpni 2
1291    set_namelist namelist_cfg jpnj 2
1292    set_namelist namelist_cfg jpnij 4
1293#
1294    if [ ${USING_MPMD} == "yes" ] ; then
1295       set_xio_using_server iodef.xml true
1296    else
1297       set_xio_using_server iodef.xml false
1298    fi
1299    cd ${SETTE_DIR}
1300    . ./prepare_job.sh input_ORCA2_LIM_AGRIF.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
1301    cd ${SETTE_DIR}
1302    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
1303
1304fi
1305
1306## Restartability tests for ORCA2_LIM_AGRIF
1307if [ ${config} -eq 18 ] ;  then
1308    export TEST_NAME="LONG"
1309    cd ${CONFIG_DIR}
1310    . ./makenemo -m ${CMP_NAM} -n ORCA2AGUL_LONG -r ORCA2_LIM -j 8 add_key "key_mpp_rep key_agrif" del_key "key_zdftmx" del_key ${DEL_KEYS}
1311    cd ${SETTE_DIR}
1312    . ./param.cfg
1313    . ./all_functions.sh
1314    . ./prepare_exe_dir.sh
1315    JOB_FILE=${EXE_DIR}/run_job.sh
1316    NPROC=4
1317    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
1318    cd ${EXE_DIR}
1319    set_namelist namelist_cfg cn_exp \"O2LP_LONG\"
1320    set_namelist namelist_cfg nn_it000 1
1321    set_namelist namelist_cfg nn_itend 150
1322    set_namelist namelist_cfg nn_stock 75
1323    set_namelist namelist_cfg ln_clobber .true.
1324    set_namelist namelist_cfg nn_fwb 0
1325    set_namelist namelist_cfg jpni 2
1326    set_namelist namelist_cfg jpnj 2
1327    set_namelist namelist_cfg jpnij 4
1328#   set_namelist namelist_cfg nn_solv 2
1329#
1330    set_namelist 1_namelist_cfg cn_exp \"O2LP_LONG\"
1331    set_namelist 1_namelist_cfg nn_it000 1
1332    set_namelist 1_namelist_cfg nn_itend 300
1333    set_namelist 1_namelist_cfg nn_stock 150
1334    set_namelist 1_namelist_cfg ln_ctl .false.
1335    set_namelist 1_namelist_cfg ln_clobber .true.
1336#
1337    if [ ${USING_MPMD} == "yes" ] ; then
1338       set_xio_using_server iodef.xml true
1339    else
1340       set_xio_using_server iodef.xml false
1341    fi
1342    cd ${SETTE_DIR}
1343    . ./prepare_job.sh input_ORCA2_LIM_AGRIF.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
1344   
1345    cd ${SETTE_DIR}
1346    export TEST_NAME="SHORT"
1347    . ./prepare_exe_dir.sh
1348    cd ${EXE_DIR}
1349    set_namelist namelist_cfg cn_exp \"O2LP_SHORT\"
1350    set_namelist namelist_cfg nn_it000 76
1351    set_namelist namelist_cfg nn_itend 150
1352    set_namelist namelist_cfg nn_stock 75
1353    set_namelist namelist_cfg ln_rstart .true.
1354    set_namelist namelist_cfg nn_rstctl 2
1355    set_namelist namelist_cfg ln_clobber .true.
1356    set_namelist namelist_cfg nn_fwb 0
1357    set_namelist namelist_cfg jpni 2
1358    set_namelist namelist_cfg jpnj 2
1359
1360    set_namelist namelist_cfg jpnij 4
1361#   set_namelist namelist_cfg nn_solv 2
1362    set_namelist 1_namelist_cfg cn_exp \"O2LP_SHORT\"
1363    set_namelist 1_namelist_cfg nn_it000 151
1364    set_namelist 1_namelist_cfg nn_itend 300
1365    set_namelist 1_namelist_cfg nn_stock 150
1366    set_namelist 1_namelist_cfg ln_rstart .true.
1367    set_namelist 1_namelist_cfg nn_rstctl 2
1368    set_namelist 1_namelist_cfg ln_clobber .true.
1369    set_namelist namelist_cfg cn_ocerst_in \"O2LP_LONG_00000075_restart\"
1370    set_namelist namelist_ice_cfg cn_icerst_in \"O2LP_LONG_00000075_restart_ice\"
1371
1372    set_namelist 1_namelist_cfg cn_ocerst_in \"O2LP_LONG_00000150_restart\"
1373
1374    for (( i=1; i<=$NPROC; i++)) ; do
1375        L_NPROC=$(( $i - 1 ))
1376        L_NPROC=`printf "%04d\n" ${L_NPROC}`
1377        ln -sf ../LONG/O2LP_LONG_00000075_restart_${L_NPROC}.nc .
1378        ln -sf ../LONG/O2LP_LONG_00000075_restart_ice_${L_NPROC}.nc .
1379        ln -sf ../LONG/1_O2LP_LONG_00000150_restart_${L_NPROC}.nc .
1380    done
1381    if [ ${USING_MPMD} == "yes" ] ; then
1382       set_xio_using_server iodef.xml true
1383    else
1384       set_xio_using_server iodef.xml false
1385    fi
1386    cd ${SETTE_DIR}
1387    . ./prepare_job.sh input_ORCA2_LIM_AGRIF.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
1388    cd ${SETTE_DIR}
1389    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
1390fi
1391
1392## Reproducibility tests for ORCA2_LIM_AGRIF
1393if [ ${config} -eq 19 ] ;  then
1394    export TEST_NAME="REPRO_4_4"
1395    cd ${CONFIG_DIR}
1396    . ./makenemo -m ${CMP_NAM} -n ORCA2AGUL_16 -r ORCA2_LIM -j 8 add_key "key_mpp_rep key_agrif" del_key "key_zdftmx" del_key ${DEL_KEYS}
1397    cd ${SETTE_DIR}
1398    . ./param.cfg
1399    . ./all_functions.sh
1400    . ./prepare_exe_dir.sh
1401    JOB_FILE=${EXE_DIR}/run_job.sh
1402    NPROC=16
1403    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
1404    cd ${EXE_DIR}
1405    set_namelist namelist_cfg nn_it000 1
1406    set_namelist namelist_cfg nn_itend 75
1407    set_namelist namelist_cfg ln_ctl .false.
1408    set_namelist namelist_cfg ln_clobber .true.
1409    set_namelist namelist_cfg nn_fwb 0
1410    set_namelist namelist_cfg jpni 4
1411    set_namelist namelist_cfg jpnj 4
1412    set_namelist namelist_cfg jpnij 16
1413#   set_namelist namelist_cfg nn_solv 2
1414#
1415    set_namelist 1_namelist_cfg nn_it000 1
1416    set_namelist 1_namelist_cfg nn_itend 150
1417    set_namelist 1_namelist_cfg ln_ctl .false.
1418    set_namelist 1_namelist_cfg ln_clobber .true.
1419
1420    if [ ${USING_MPMD} == "yes" ] ; then
1421       set_xio_using_server iodef.xml true
1422    else
1423       set_xio_using_server iodef.xml false
1424    fi
1425    cd ${SETTE_DIR}
1426    . ./prepare_job.sh input_ORCA2_LIM_AGRIF.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
1427    cd ${SETTE_DIR}
1428    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
1429
1430    cd ${SETTE_DIR}
1431    export TEST_NAME="REPRO_2_8"
1432    . ./prepare_exe_dir.sh
1433    JOB_FILE=${EXE_DIR}/run_job.sh
1434    NPROC=16
1435    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
1436    cd ${EXE_DIR}
1437    set_namelist namelist_cfg nn_it000 1
1438    set_namelist namelist_cfg nn_itend 75
1439    set_namelist namelist_cfg ln_ctl .false.
1440    set_namelist namelist_cfg ln_clobber .true.
1441    set_namelist namelist_cfg nn_fwb 0
1442    set_namelist namelist_cfg jpni 2
1443    set_namelist namelist_cfg jpnj 8
1444    set_namelist namelist_cfg jpnij 16
1445#   set_namelist namelist_cfg nn_solv 2
1446#
1447    set_namelist 1_namelist_cfg nn_it000 1
1448    set_namelist 1_namelist_cfg nn_itend 150
1449    set_namelist 1_namelist_cfg ln_ctl .false.
1450    set_namelist 1_namelist_cfg ln_clobber .true.
1451
1452    if [ ${USING_MPMD} == "yes" ] ; then
1453       set_xio_using_server iodef.xml true
1454    else
1455       set_xio_using_server iodef.xml false
1456    fi
1457    cd ${SETTE_DIR}
1458    . ./prepare_job.sh input_ORCA2_LIM_AGRIF.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS}
1459    cd ${SETTE_DIR}
1460    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
1461fi
1462
1463done
Note: See TracBrowser for help on using the repository browser.