source: CONFIG_DEVT/IPSLCM6.5_work_ENSEMBLES/libIGCM/AA_pack_restart @ 6031

Last change on this file since 6031 was 5899, checked in by aclsce, 3 years ago

Modified libIGCM and configuration to run XIOS ensembles.

File size: 13.3 KB
Line 
1#-Q- curie ######################
2#-Q- curie ## CURIE   TGCC/CEA ##
3#-Q- curie ######################
4#-Q- curie #MSUB -r PACKRESTART    # Nom du job
5#-Q- curie #MSUB -o PACKRESTART.out_%I
6#-Q- curie #MSUB -e PACKRESTART.out_%I
7#-Q- curie #MSUB -n 1              # Reservation du processus
8#-Q- curie #MSUB -T 7200          # Limite de temps elapsed du job
9#-Q- curie #MSUB -q ::default_node::
10#-Q- curie #MSUB -c ::default_core::
11#-Q- curie #MSUB -Q normal
12#-Q- curie #MSUB -A ::default_project::
13#-Q- curie set +x
14#-Q- irene ######################
15#-Q- irene ## IRENE   TGCC/CEA ##
16#-Q- irene ######################
17#-Q- irene #MSUB -r PACKRESTART    # Job name
18#-Q- irene #MSUB -o PACKRESTART.out_%I
19#-Q- irene #MSUB -e PACKRESTART.out_%I
20#-Q- irene #MSUB -n 1              # Number of cores
21#-Q- irene #MSUB -T 7200           # Maximum elapsed time
22#-Q- irene #MSUB -q ::default_node::
23#-Q- irene #MSUB -c ::default_core::
24#-Q- irene #MSUB -Q normal
25#-Q- irene #MSUB -A ::default_post_project::
26#-Q- irene #MSUB -m store,work,scratch
27#-Q- irene set +x
28#-Q- irene-amd ##########################
29#-Q- irene-amd ## IRENE-ROME  TGCC/CEA ##
30#-Q- irene-amd ##########################
31#-Q- irene-amd #MSUB -r PACKRESTART     # Job name
32#-Q- irene-amd #MSUB -o PACKRESTART.out_%I
33#-Q- irene-amd #MSUB -e PACKRESTART.out_%I
34#-Q- irene-amd #MSUB -n 1              # Number of cores
35#-Q- irene-amd #MSUB -T 7200          # Maximum elapsed time
36#-Q- irene-amd #MSUB -q ::default_node::
37#-Q- irene-amd #MSUB -c ::default_core::
38#-Q- irene-amd #MSUB -Q normal
39#-Q- irene-amd #MSUB -A ::default_post_project::
40#-Q- irene-amd #MSUB -m store,work,scratch
41#-Q- irene-amd set +x
42#-Q- jeanzay #!/bin/ksh
43#-Q- jeanzay ######################
44#-Q- jeanzay ## JEANZAY    IDRIS ##
45#-Q- jeanzay ######################
46#-Q- jeanzay #SBATCH --job-name=PACKRESTART         # Job Name
47#-Q- jeanzay #SBATCH --output=PACKRESTART.out_%J    # standard output
48#-Q- jeanzay #SBATCH --error=PACKRESTART.out_%J     # error output
49#-Q- jeanzay #SBATCH -N  1                        # Number of core
50#-Q- jeanzay #SBATCH --partition=prepost          # Post-processing partition
51#-Q- jeanzay #SBATCH --time=10:00:00                # Wall clock limit (seconds)
52#-Q- jeanzay #SBATCH --account ::default_project::@cpu
53#-Q- jeanzay set +x
54#-Q- ada #!/bin/ksh
55#-Q- ada #######################
56#-Q- ada ## ADA         IDRIS ##
57#-Q- ada #######################
58#-Q- ada # @ job_type = mpich
59#-Q- ada # @ requirements = (Feature == "prepost")
60#-Q- ada # Temps Elapsed max. d'une requete hh:mm:ss
61#-Q- ada # @ wall_clock_limit = 10:00:00
62#-Q- ada # Nom du travail LoadLeveler
63#-Q- ada # @ job_name   = PACKRESTART
64#-Q- ada # Fichier de sortie standard du travail
65#-Q- ada # @ output     = $(job_name).$(jobid)
66#-Q- ada # Fichier de sortie d'erreur du travail
67#-Q- ada # @ error      =  $(job_name).$(jobid)
68#-Q- ada # pour recevoir un mail en cas de depassement du temps Elapsed (ou autre pb.)
69#-Q- ada # @ notification = error
70#-Q- ada # @ environment  = $DEBUG_debug ; $BigBrother ; $postProcessingStopLevel ; $MODIPSL ; $libIGCM ; $libIGCM_SX ; $POST_DIR ; $Script_Post_Output ; $SUBMIT_DIR ; $PeriodDateBegin ; $DateBegin ; $DateEnd ; $PeriodPack ; $StandAlone ; $MASTER ; wall_clock_limit=$(wall_clock_limit)
71#-Q- ada # @ queue
72#-Q- lxiv8 ######################
73#-Q- lxiv8 ## OBELIX      LSCE ##
74#-Q- lxiv8 ######################
75#-Q- lxiv8 #PBS -N PACKRESTART
76#-Q- lxiv8 #PBS -m a
77#-Q- lxiv8 #PBS -j oe
78#-Q- lxiv8 #PBS -q medium
79#-Q- lxiv8 #PBS -o PACKRESTART.$$
80#-Q- lxiv8 #PBS -S /bin/ksh
81#-Q- ifort_CICLAD ######################
82#-Q- ifort_CICLAD ##   CICLAD    IPSL ##
83#-Q- ifort_CICLAD ######################
84#-Q- ifort_CICLAD #PBS -N PACKRESTART
85#-Q- ifort_CICLAD #PBS -m a
86#-Q- ifort_CICLAD #PBS -j oe
87#-Q- ifort_CICLAD #PBS -q std
88#-Q- ifort_CICLAD #PBS -S /bin/ksh
89#-Q- default #!/bin/ksh
90#-Q- default ##################
91#-Q- default ## DEFAULT HOST ##
92#-Q- default ##################
93
94#**************************************************************
95# Author: Sebastien Denvil
96# Contact: Sebastien.Denvil__at__ipsl.jussieu.fr
97# $Revision:: 1525                                     $ Revision of last commit
98# $Author:: cetlod                                     $ Author of last commit
99# $Date:: 2020-04-27 10:39:22 +0200 (Mon, 27 Apr 2020) $ Date of last commit
100# IPSL (2006)
101#  This software is governed by the CeCILL licence see libIGCM/libIGCM_CeCILL.LIC
102#
103#**************************************************************
104
105#set -eu
106#set -vx
107
108date
109
110#D- Task type DO NOT CHANGE (computing, post-processing or checking)
111TaskType=post-processing
112
113########################################################################
114
115#D- Flag to determine if this job in a standalone mode
116#D- Default : value from AA_job if any
117StandAlone=${StandAlone:=true}
118
119#D- Path to libIGCM
120#D- Default : value from AA_job if any
121# WARNING For StandAlone use : To run this script on some machine (ulam and cesium)
122# WARNING you must check MirrorlibIGCM variable in sys library.
123# WARNING If this variable is true, you must use libIGCM_POST path instead
124# WARNING of your running libIGCM directory.
125libIGCM=${libIGCM:=::modipsl::/libIGCM}
126
127#-D- $hostname of the MASTER job when SUBMIT_DIR is not visible on postprocessing computer.
128MASTER=${MASTER:=ada|curie}
129
130#D- Flag to determine begin date for restart pack
131#D- Default : value from AA_job if any
132DateBegin=${DateBegin:=20000101}
133
134#D- Flag to determine end date for restart pack
135#D- Default : value from AA_job if any
136DateEnd=${DateEnd:=20691231}
137
138#D- Flag to determine pack period
139#D- Default : value from AA_job if any
140PeriodPack=${PeriodPack:=10Y}
141
142#D- Uncomment to run interactively
143#D- For testing purpose, will be remove
144#SUBMIT_DIR=${PWD}
145#RUN_DIR_PATH=${SCRATCHDIR}/Pack_Test
146
147#D- Increased verbosity (1, 2, 3)
148#D- Default : value from AA_job if any
149Verbosity=${Verbosity:=3}
150
151#D- Low level debug : to bypass lib test checks and stack construction
152#D- Default : value from AA_job if any
153DEBUG_debug=${DEBUG_debug:=false}
154
155#D- Keep following comments for now. Will be remove.
156
157#on veut archiver les fichiers restart
158#Dans le cadre du demenagement ils seront renommes
159#ATM/Restart/****.nc
160#OCE/Restart/****.nc
161#...
162#sous la forme
163#RESTART/ATM_****.nc
164#RESTART/OCE_****.nc
165#Attention de bien conserver les dates d'origines
166#
167#Dans le cadre de la production nouvelle chaine
168#ils auront directement le bon nom
169#
170#On veut egalement que l'archive soit par periode de temps
171# cette periode est definie par la taille du pack donc connue
172# en entree du script (1M, 1Y, 5Y, 10Y etc...)
173#
174# $1= PATH/config_card d'une simulation avec
175# TagName/JobName/ExperimentName/SpaceName/DateBegin/DateEnd
176# $2=PeriodPack en M/m ou Y/y
177
178########################################################################
179
180. ${libIGCM}/libIGCM_debug/libIGCM_debug.ksh
181. ${libIGCM}/libIGCM_card/libIGCM_card.ksh
182. ${libIGCM}/libIGCM_date/libIGCM_date.ksh
183#-------
184. ${libIGCM}/libIGCM_sys/libIGCM_sys.ksh
185. ${libIGCM}/libIGCM_config/libIGCM_config.ksh
186. ${libIGCM}/libIGCM_post/libIGCM_post.ksh
187#-------
188RUN_DIR=${RUN_DIR_PATH}
189IGCM_sys_MkdirWork ${RUN_DIR}
190IGCM_sys_Cd ${RUN_DIR}
191#-------
192( ${DEBUG_debug} ) && IGCM_debug_Check
193( ${DEBUG_debug} ) && IGCM_card_Check
194( ${DEBUG_debug} ) && IGCM_date_Check
195
196########################################################################
197
198#set -vx
199
200# ------------------------------------------------------------------
201# Test if all was right before proceeding further
202# ------------------------------------------------------------------
203IGCM_debug_Verif_Exit
204
205if [ ${StandAlone} = true ] ; then
206    CARD_DIR=${SUBMIT_DIR}
207else
208    CARD_DIR=${RUN_DIR_PATH}
209    IGCM_sys_Get_Master ${SUBMIT_DIR}/config.card ${RUN_DIR_PATH}
210    IGCM_sys_Get_Master ${SUBMIT_DIR}/run.card    ${RUN_DIR_PATH}
211    IGCM_sys_Get_Master ${SUBMIT_DIR}/COMP        ${RUN_DIR_PATH}
212    IGCM_sys_Get_Master ${SUBMIT_DIR}/POST        ${RUN_DIR_PATH}
213fi
214
215#==================================
216# First of all
217#
218# Read libIGCM compatibility version in config.card
219# Read UserChoices section
220# Read Ensemble section
221# Read Post section
222# Define all netcdf output directories
223#==================================
224IGCM_config_CommonConfiguration ${CARD_DIR}/config.card
225
226# ------------------------------------------------------------------
227# Activate BigBrother so as to supervise this job
228# ------------------------------------------------------------------
229IGCM_debug_BigBro_Initialize
230
231#==================================
232# Test and set up directories
233#==================================
234IGCM_sys_TestDirArchive ${R_SAVE}
235[ $? != 0 ] && IGCM_debug_Exit "IGCM_sys_TestDirArchive"
236
237STORE_RESTART=${R_SAVE}/RESTART
238IGCM_sys_MkdirArchive ${STORE_RESTART}
239
240# Switch to script variables meaning (try to be compatible with ipsl_pack TGCC moving procedure)
241JobName=${config_UserChoices_JobName}
242echo $JobName $R_BUFR $DateBegin $DateEnd
243
244# Clear txt file lists
245rm -f ${RUN_DIR}/liste_restart_files.txt
246rm -f ${RUN_DIR}/new_liste_restart_files.txt
247rm -f ${RUN_DIR}/liste_pack_*.txt
248rm -f ${RUN_DIR}/liste_pack_light_*.txt
249
250# Create sorted restart list to work with
251find ${R_BUFR}/*/Restart -name "*.*" | sort >> ${RUN_DIR}/liste_restart_files.txt
252
253# Rename restart files we will work with using symlinks
254#gawk -F/ '{dest_name=$(NF-2)("_") $(NF); system("cp --preserve " $0 " "dest_name)}' ${RUN_DIR}/liste_restart_files.txt
255gawk -F/ '{dest_name=$(NF-2)("_") $(NF); system("ln -s " $0 " "dest_name)}' ${RUN_DIR}/liste_restart_files.txt
256
257# List renamed restart files
258find ${RUN_DIR} -maxdepth 1 -mindepth 1 -name "???_*${JobName}*" -ls | sort -k 11 > ${RUN_DIR}/new_liste_restart_files.txt
259
260# ------------------------------------------------------------------
261# Test if all was right before proceeding further
262# ------------------------------------------------------------------
263IGCM_debug_Verif_Exit
264
265# Init loop
266date_begin_pack=${DateBegin}
267date_end_simulation=${DateEnd}
268number_pack=1
269
270IGCM_debug_PrintVariables 3 date_begin_pack
271IGCM_debug_PrintVariables 3 date_end_simulation
272
273# last restart of the previous period : to be deleted
274typeset date_end_previous
275date_end_previous=$( IGCM_date_AddDaysToGregorianDate ${date_begin_pack} -1 )
276
277while [ ${date_begin_pack} -le ${date_end_simulation} ] ; do
278
279  IGCM_debug_PrintVariables 3 number_pack
280
281  DaysTemp=$( IGCM_date_DaysInCurrentPeriod ${date_begin_pack} ${PeriodPack} )
282  date_end_pack=$( IGCM_date_AddDaysToGregorianDate ${date_begin_pack} $(( ${DaysTemp} - 1 )) )
283
284  for file in $( gawk '{print $11}' ${RUN_DIR}/new_liste_restart_files.txt ); do
285    extract_date_file=$( echo ${file}  | sed -e "s/.*${JobName}_//" )
286    date_file=$( echo ${extract_date_file} | sed 's/\([0-9]\{8\}\)_.*$/\1/g' )
287    # warning demenagement. delete last restart of the previous pack
288    [  ${date_file} -eq ${date_end_previous} ] && echo $( readlink ${file} ) >> ${RUN_DIR}/liste_remove_pack_${date_begin_pack}_${date_end_pack}.txt
289    # echo pack number ${number_pack}  ${date_file} ${date_begin_pack} ${date_end_pack}
290    if [ ${date_file} -le ${date_end_pack} ] && [ ${date_file} -ge ${date_begin_pack} ] ; then
291      echo $( basename ${file} ) >> ${RUN_DIR}/liste_pack_${date_begin_pack}_${date_end_pack}.txt
292      # warning demenagement. do not delete last restart of this pack
293      [ ${date_file} -eq ${date_end_pack} ] || echo $( readlink ${file} ) >> ${RUN_DIR}/liste_remove_pack_${date_begin_pack}_${date_end_pack}.txt
294    fi
295    # light pack list of restarts files that will be used
296    if [ X${config_Post_LightRestartPack} = XTRUE ] ; then
297      if [ ${date_file} -le ${date_end_pack} ] && [ ${date_file} -ge ${PeriodDateBegin} ] ; then
298        echo $( basename ${file} ) >> ${RUN_DIR}/liste_pack_light_${date_begin_pack}_${date_end_pack}.txt
299      fi
300    fi
301  done
302
303  # Create tar files
304  IGCM_debug_Print 1 "Tar ongoing"
305  if [ X${config_Post_LightRestartPack} = XTRUE ] ; then
306    tar -cvf ${JobName}_${date_begin_pack}_${date_end_pack}_restart.tar --dereference --files-from ${RUN_DIR}/liste_pack_light_${date_begin_pack}_${date_end_pack}.txt
307  else
308    tar -cvf ${JobName}_${date_begin_pack}_${date_end_pack}_restart.tar --dereference --files-from ${RUN_DIR}/liste_pack_${date_begin_pack}_${date_end_pack}.txt
309  fi
310  # Test return code of tar
311  [ $? != 0 ] && IGCM_debug_Exit "tar failed in pack_restart job"
312  # Save it
313  IGCM_sys_Put_Out ${JobName}_${date_begin_pack}_${date_end_pack}_restart.tar ${STORE_RESTART}
314  # Clean it
315  IGCM_sys_Rm ${JobName}_${date_begin_pack}_${date_end_pack}_restart.tar
316  # ------------------------------------------------------------------
317  # Test if all was right before proceeding cleaning
318  # ------------------------------------------------------------------
319  IGCM_debug_Verif_Exit
320  # Clean links
321  cat ${RUN_DIR}/liste_pack_${date_begin_pack}_${date_end_pack}.txt | xargs rm
322  # Clean files links pointed to
323  cat ${RUN_DIR}/liste_remove_pack_${date_begin_pack}_${date_end_pack}.txt | xargs rm
324  # Save the list of files that has been pack (tar)
325  #mv ${RUN_DIR}/liste_pack_${date_begin_pack}_${date_end_pack}.txt ${STORE_RESTART}
326  IGCM_debug_Print 1 "Tar and cleaning done"
327
328  (( number_pack = number_pack + 1 ))
329
330  # Add 1 day to date_end_pack to have the new date_begin_pack
331  date_begin_pack=$( IGCM_date_AddDaysToGregorianDate ${date_end_pack} 1 )
332
333done
334
335# Clean RUN_DIR_PATH (necessary for cesium and titane only)
336IGCM_sys_RmRunDir -Rf ${RUN_DIR_PATH}
337
338# ------------------------------------------------------------------
339# Finalize BigBrother to inform that the jobs end
340# ------------------------------------------------------------------
341IGCM_debug_BigBro_Finalize
342
343date
Note: See TracBrowser for help on using the repository browser.