ATLAS Offline Software
Functions
ELG_prun Namespace Reference

Functions

def ELG_prun (sample)
 

Function Documentation

◆ ELG_prun()

def ELG_prun.ELG_prun (   sample)

Definition at line 10 of file ELG_prun.py.

10 def ELG_prun(sample) :
11 
12  try:
13  from pandatools import PandaToolsPkgInfo # noqa: F401
14  except ImportError:
15  print ("prun needs additional setup, try:")
16  print (" lsetup panda")
17  return 99
18 
19  cmd = ["prun"]
20 
21  #These are options that can be set by the user
22  opts = ['destSE',
23  'site',
24  'rootVer',
25  'cmtConfig',
26  'excludedSite',
27  'nGBPerJob',
28  'memory',
29  'maxCpuCount',
30  'nFiles',
31  'nFilesPerJob',
32  'nEventsPerJob',
33  'nJobs',
34  'maxFileSize',
35  'maxNFilesPerJob',
36  'addNthFieldOfInDSToLFN',
37  'cpuTimePerEvent',
38  'maxWalltime',
39  'voms',
40  'workingGroup',
41  'tmpDir']
42 
43  #These are options that can be set by the user
44  switches = ['express',
45  'noSubmit',
46  'skipScout',
47  'disableAutoRetry',
48  'useNewCode',
49  'official',
50  'mergeOutput',
51  'useRootCore',
52  'useAthenaPackages',
53  'avoidVP']
54 
55  using_nEventsPerJob = False
56  from ROOT import SH
57  for opt in opts :
58  arg = sample.meta().castDouble('nc_' + opt, -1, SH.MetaObject.CAST_NOCAST_DEFAULT)
59  if abs(arg + 1) > 1e-6 :
60  cmd += ["--" + opt + "=" + str(int(round(arg)))]
61  if opt=="nEventsPerJob":
62  using_nEventsPerJob=True
63  else :
64  arg = sample.meta().castString('nc_' + opt)
65  if len(arg) :
66  cmd += ["--" + opt + "=" + arg]
67 
68  # nGBPerJob and nEventsPerJob are incompatible to prun
69  if using_nEventsPerJob:
70  cmd = [ x for x in cmd if "nGBPerJob" not in x ]
71  print(cmd)
72 
73  for switch in switches :
74  arg = sample.meta().castDouble('nc_' + switch, 0, SH.MetaObject.CAST_NOCAST_DEFAULT)
75  if arg != 0 :
76  cmd += ["--" + switch]
77  else :
78  arg = sample.meta().castString('nc_' + switch)
79  if len(arg) :
80  if arg != "False" and arg != "false" and arg != "FALSE" :
81  cmd += ["--" + switch]
82 
83  #These options should normally not be touched by the user
84  internalOpts = ['exec',
85  'inDS',
86  'outDS',
87  'outputs',
88  'writeInputToTxt',
89  'match',
90  'framework']
91 
92  for opt in internalOpts :
93  value = sample.meta().castString('nc_' + opt)
94  if opt == "exec" and using_nEventsPerJob:
95  value += " %SKIPEVENTS %MAXEVENTS"
96  cmd += ["--" + opt + "=" + value]
97 
98  if sample.meta().castDouble('nc_mergeOutput', 1, SH.MetaObject.CAST_NOCAST_DEFAULT) == 0 or sample.meta().castString('nc_mergeOutput').upper() == 'FALSE' :
99  #don't set merge script
100  pass
101  else :
102  cmd += ["--mergeScript=" + sample.meta().castString('nc_mergeScript')]
103 
104  if len(sample.meta().castString('nc_EventLoop_SubmitFlags')) :
105  cmd += shlex.split (sample.meta().castString('nc_EventLoop_SubmitFlags'))
106 
107  if sample.meta().castDouble('nc_showCmd', 0, SH.MetaObject.CAST_NOCAST_DEFAULT) != 0 :
108  print (cmd)
109 
110  if not os.path.isfile('jobcontents.tgz') :
111  import copy
112  dummycmd = copy.deepcopy(cmd)
113  dummycmd += ["--outTarBall=jobcontents.tgz"]
114  if len(sample.meta().castString('nc_EventLoop_UserFiles')) :
115  dummycmd += ["--extFile=jobdef.root,runjob.sh," + sample.meta().castString('nc_EventLoop_UserFiles').replace(" ",",")]
116  pass
117  else :
118  dummycmd += ["--extFile=jobdef.root,runjob.sh"]
119  pass
120  dummycmd += ["--noSubmit"]
121 
122  try:
123  out = subprocess.check_output(dummycmd, stderr=subprocess.STDOUT)
124  except subprocess.CalledProcessError as e:
125  # Handle a case where we couldn't get the grid nickname in advance
126  if b'Need to generate a grid proxy' in e.output and any( ['%nickname%' in x for x in cmd ] ):
127  print('Detected nickname still undefined. Trying to replace it.')
128  try:
129  from pandatools import PsubUtils
130  nickname = PsubUtils.getNickname()
131  dummycmd = [ x.replace('%nickname%',nickname) for x in dummycmd ]
132  cmd = [ x.replace('%nickname%',nickname) for x in cmd ]
133  except Exception as e_rep:
134  print(f'Nickname replacement failed with error {e_rep.returncode}: {e_rep.output}')
135  # Now try the job again
136  try:
137  out = subprocess.check_output(dummycmd, stderr=subprocess.STDOUT)
138  except subprocess.CalledProcessError as e_take2:
139  print ("Command:")
140  print (e_take2.cmd)
141  print ("failed with return code " , e_take2.returncode)
142  print ("output was:")
143  print (e_take2.output)
144  return 1
145  else:
146  print ("Command:")
147  print (e.cmd)
148  print ("failed with return code " , e.returncode)
149  print ("output was:")
150  print (e.output)
151  return 1
152 
153  cmd += ["--inTarBall=jobcontents.tgz"]
154 
155  out = ""
156  try:
157  out = subprocess.check_output(cmd, stderr=subprocess.STDOUT)
158  except subprocess.CalledProcessError as e:
159  print ("Command:")
160  print (e.cmd)
161  print ("failed with return code ", e.returncode)
162  print ("output was:")
163  print (e.output)
164  return 2
165 
166  jediTaskID = 0
167  try:
168  line = re.findall(r'TaskID=\d+', str(out))[0]
169  jediTaskID = int(re.findall(r'\d+', line)[0])
170  except IndexError:
171  print (out)
172  return 3
173 
174  return jediTaskID
ELG_prun.ELG_prun
def ELG_prun(sample)
Definition: ELG_prun.py:10
replace
std::string replace(std::string s, const std::string &s2, const std::string &s3)
Definition: hcg.cxx:307
CaloCellPos2Ntuple.int
int
Definition: CaloCellPos2Ntuple.py:24
MuonGM::round
float round(const float toRound, const unsigned int decimals)
Definition: Mdt.cxx:27
upper
int upper(int c)
Definition: LArBadChannelParser.cxx:49
print
void print(char *figname, TCanvas *c1)
Definition: TRTCalib_StrawStatusPlots.cxx:25
str
Definition: BTagTrackIpAccessor.cxx:11