1 from alternateValidationTemplates
import *
2 from offlineValidationTemplates
import *
3 from geometryComparisonTemplates
import *
4 from monteCarloValidationTemplates
import *
5 from trackSplittingValidationTemplates
import *
6 from zMuMuValidationTemplates
import *
7 from TkAlExceptions
import AllInOneError
20 conditionsTemplate=
"""
21 process.conditionsIn.oO[rcdName]Oo. = CalibTracker.Configuration.Common.PoolDBESSource_cfi.poolDBESSource.clone(
22 connect = cms.string('.oO[connectString]Oo.'),
23 toGet = cms.VPSet(cms.PSet(record = cms.string('.oO[rcdName]Oo.'),
24 tag = cms.string('.oO[tagName]Oo.')
28 process.prefer_conditionsIn.oO[rcdName]Oo. = cms.ESPrefer("PoolDBESSource", "conditionsIn.oO[rcdName]Oo.")
38 source /afs/cern.ch/cms/caf/setup.sh
39 cd .oO[CMSSW_BASE]Oo./src
40 export SCRAM_ARCH=.oO[SCRAM_ARCH]Oo.
42 # rfmkdir -p .oO[workdir]Oo.
43 # rfmkdir -p .oO[datadir]Oo.
45 if [[ $HOSTNAME = lxplus[0-9]*\.cern\.ch ]] # check for interactive mode
47 rfmkdir -p .oO[workdir]Oo.
48 rm -f .oO[workdir]Oo./*
51 mkdir -p $CWD/TkAllInOneTool
52 cd $CWD/TkAllInOneTool
55 # rm -f .oO[workdir]Oo./*
63 echo "List of files in $(pwd):"
70 rfmkdir -p .oO[logdir]Oo. >&! /dev/null
71 gzip -f LOGFILE_*_.oO[name]Oo..log
72 find .oO[workdir]Oo. -maxdepth 1 -name "LOGFILE*.oO[alignmentName]Oo.*" -print | xargs -I {} bash -c "rfcp {} .oO[logdir]Oo."
74 #copy root files to eos
75 cmsMkdir /store/caf/user/$USER/.oO[eosdir]Oo.
76 root_files=$(ls --color=never -d *.oO[alignmentName]Oo.*.root)
79 for file in ${root_files}
81 cmsStage -f ${file} /store/caf/user/$USER/.oO[eosdir]Oo.
86 if [[ $HOSTNAME = lxplus[0-9]*\.cern\.ch ]] # check for interactive mode
88 rm -rf .oO[workdir]Oo.
97 parallelScriptTemplate=
"""
101 #export STAGE_SVCCLASS=cmscafuser
102 #save path to the LSF batch working directory (/pool/lsf)
103 export LSFWORKDIR=$PWD
104 echo LSF working directory is $LSFWORKDIR
105 source /afs/cern.ch/cms/caf/setup.sh
106 # source /afs/cern.ch/cms/sw/cmsset_default.sh
107 cd .oO[CMSSW_BASE]Oo./src
108 # export SCRAM_ARCH=slc5_amd64_gcc462
109 export SCRAM_ARCH=.oO[SCRAM_ARCH]Oo.
110 eval `scramv1 ru -sh`
111 #rfmkdir -p ${LSFWORKDIR}
113 # make rfmkdir silent in case directory already exists
114 rfmkdir -p .oO[datadir]Oo. >&! /dev/null
115 cmsMkdir /store/caf/user/$USER/.oO[eosdir]Oo.
117 #remove possible result file from previous runs
118 previous_results=$(cmsLs -l /store/caf/user/$USER/.oO[eosdir]Oo. | awk '{print $5}')
119 for file in ${previous_results}
121 # if [ ${file} = *.oO[datadir]Oo./*.oO[alignmentName]Oo.*.root ]
122 if [ ${file} = /store/caf/user/$USER/.oO[eosdir]Oo./.oO[outputFile]Oo. ]
124 cmsStage -f ${file} ${file}.bak
128 #rm -f ${LSFWORKDIR}/*
136 echo "List of files in $(pwd):"
143 rfmkdir -p .oO[logdir]Oo. >&! /dev/null
144 gzip LOGFILE_*_.oO[name]Oo..log
145 find ${LSFWORKDIR} -maxdepth 1 -name "LOGFILE*.oO[alignmentName]Oo.*" -print | xargs -I {} bash -c "rfcp {} .oO[logdir]Oo."
147 #copy root files to eos
148 cmsMkdir /store/caf/user/$USER/.oO[eosdir]Oo.
149 root_files=$(ls --color=never -d ${LSFWORKDIR}/*.oO[alignmentName]Oo._.oO[nIndex]Oo.*.root)
152 echo "\${root_files}:"
154 for file in ${root_files}
156 # echo "cmsStage -f ${file} /store/caf/user/$USER/.oO[eosdir]Oo."
157 cmsStage -f ${file} /store/caf/user/$USER/.oO[eosdir]Oo.
161 #cleanup - do not remove workdir, since another parallel job might be running in the same node
162 find ${LSFWORKDIR} -maxdepth 1 -name "*.oO[alignmentName]Oo._.oO[nIndex]Oo.*.root" -print | xargs -I {} bash -c "rm {}"
172 cd .oO[CMSSW_BASE]Oo./src
173 export SCRAM_ARCH=.oO[SCRAM_ARCH]Oo.
174 eval `scramv1 ru -sh`
176 if [[ $HOSTNAME = lxplus[0-9]*\.cern\.ch ]] # check for interactive mode
178 mkdir -p .oO[workdir]Oo.
183 echo "Working directory: $(pwd -P)"
185 ###############################################################################
186 # download root files from eos
187 root_files=$(cmsLs -l /store/caf/user/$USER/.oO[eosdir]Oo. | awk '{print $5}' \
188 | grep ".root$" | grep -v "result.root$")
189 for file in ${root_files}
191 cmsStage -f ${file} .
198 .oO[CompareAlignments]Oo.
200 .oO[RunExtendedOfflineValidation]Oo.
202 for file in $(ls -d --color=never *_result.root)
204 cmsStage -f ${file} /store/caf/user/$USER/.oO[eosdir]Oo.
211 #zip stdout and stderr from the farm jobs
213 find . -name "*.stderr" -exec gzip -f {} \;
214 find . -name "*.stdout" -exec gzip -f {} \;
220 compareAlignmentsExecution=
"""
221 #merge for .oO[validationId]Oo.
222 cp .oO[CMSSW_BASE]Oo./src/Alignment/OfflineValidation/scripts/compareAlignments.cc .
223 root -q -b 'compareAlignments.cc++(\".oO[compareStrings]Oo.\")'
224 mv result.root .oO[validationId]Oo._result.root
230 extendedValidationExecution=
"""
231 #run extended offline validation scripts
232 if [[ $HOSTNAME = lxplus[0-9]*\.cern\.ch ]] # check for interactive mode
234 rfmkdir -p .oO[workdir]Oo./ExtendedOfflineValidation_Images
236 mkdir -p ExtendedOfflineValidation_Images
239 rfcp .oO[extendeValScriptPath]Oo. .
240 rfcp .oO[CMSSW_BASE]Oo./src/Alignment/OfflineValidation/macros/PlotAlignmentValidation.C .
241 root -x -b -q TkAlExtendedOfflineValidation.C
242 rfmkdir -p .oO[datadir]Oo./ExtendedOfflineValidation_Images
244 if [[ $HOSTNAME = lxplus[0-9]*\.cern\.ch ]] # check for interactive mode
246 image_files=$(ls --color=never .oO[workdir]Oo./ExtendedOfflineValidation_Images/*ps)
248 ls .oO[workdir]Oo./ExtendedOfflineValidation_Images
250 image_files=$(ls --color=never ExtendedOfflineValidation_Images/*ps)
252 ls ExtendedOfflineValidation_Images
255 for image in ${image_files}
257 cp ${image} .oO[datadir]Oo./ExtendedOfflineValidation_Images
264 extendedValidationTemplate=
"""
265 void TkAlExtendedOfflineValidation()
267 // load framework lite just to find the CMSSW libs...
268 gSystem->Load("libFWCoreFWLite");
269 AutoLibraryLoader::enable();
271 gROOT->ProcessLine(".L .oO[CMSSW_BASE]Oo./src/Alignment/OfflineValidation/macros/PlotAlignmentValidation.C++");
272 // gROOT->ProcessLine(".L ./PlotAlignmentValidation.C++");
274 .oO[extendedInstantiation]Oo.
275 p.setOutputDir("./ExtendedOfflineValidation_Images");
276 p.setTreeBaseDir(".oO[OfflineTreeBaseDir]Oo.");
277 p.plotDMR(".oO[DMRMethod]Oo.",.oO[DMRMinimum]Oo.,".oO[DMROptions]Oo.");
278 p.plotSurfaceShapes(".oO[SurfaceShapes]Oo.");
292 datasetpath = .oO[dataset]Oo.
293 pset = .oO[cfgFile]Oo.
294 total_number_of_.oO[McOrData]Oo.
295 number_of_jobs = .oO[numberOfJobs]Oo.
296 output_file = .oO[outputFile]Oo.
297 runselection = .oO[runRange]Oo.
298 lumi_mask = .oO[JSON]Oo.
303 storage_element = T2_CH_CERN
304 user_remote_dir = .oO[eosdir]Oo.
305 ui_working_dir = .oO[crabWorkingDir]Oo.
306 # script_exe = .oO[script]Oo.
310 queue = .oO[queue]Oo.
327 if not templateName
in globals().
keys():
328 msg =
"unkown template to replace %s"%templateName
330 if not alternateTemplateName
in globals().
keys():
331 msg =
"unkown template to replace %s"%alternateTemplateName
333 globals()[ templateName ] = globals()[ alternateTemplateName ]
def alternateTemplate
### Alternate Templates ###