1 from __future__
import print_function
6 print(
"ERROR in Matrix")
7 print(
"overwriting",key,
"not allowed")
18 print(
"ERROR in Step")
19 print(
"overwriting",key,
"not allowed")
23 self.update({key:value})
28 value=self[keypair[1]]
29 self.update({keypair[0]:value})
43 print(
'steps',s,stepsDict[s])
44 steps.append(stepsDict[s])
49 return range(lumis[0],(lumis[1]+1))
52 jsonFile2015 =
findFileInPath(
"DPGAnalysis/Skims/data/Cert_13TeV_16Dec2015ReReco_Collisions15_25ns_50ns_JSON.txt")
53 jsonFile2016 =
findFileInPath(
"DPGAnalysis/Skims/data/Cert_271036-274240_13TeV_PromptReco_Collisions16_JSON.txt")
56 with open(jsonFile2015)
as data_file:
57 data_json2015 = json.load(data_file)
59 with open(jsonFile2016)
as data_file:
60 data_json2016 = json.load(data_file)
64 def selectedLS(list_runs=[],maxNum=-1,l_json=data_json2015):
66 if not isinstance(list_runs[0], int):
67 print(
"ERROR: list_runs must be a list of integers")
73 if str(run)
in l_json.keys():
77 for LSsegment
in l_json[
str(run)] :
79 ls_count += (LSsegment[-1] - LSsegment[0] + 1)
80 if (ls_count > maxNum) & (maxNum != -1):
83 if runNumber
in local_dict.keys():
84 local_dict[runNumber].
append(LSsegment)
86 local_dict[runNumber] = [LSsegment]
90 print(
"run %s is NOT present in json %s\n\n"%(run, l_json))
93 if ( len(local_dict) > 0 ) :
96 print(
"No luminosity section interval passed the json and your selection; returning None")
104 InputInfoNDefault=2000000
106 def __init__(self,dataSet,dataSetParent='',label='',run=[],ls={},files=1000,events=InputInfoNDefault,split=10,location='CAF',ib_blacklist=None,ib_block=None) :
119 def das(self, das_options, dataset):
120 if len(self.
run) != 0
or self.
ls:
121 queries = self.
queries(dataset)[:3]
122 if len(self.
run) != 0:
123 command =
";".
join([
"dasgoclient %s --query '%s'" % (das_options, query)
for query
in queries])
128 commands.append(
"dasgoclient %s --query 'lumi,%s' --format json | das-selected-lumis.py %s " % (das_options, queries.pop(), lumis.pop()))
129 command =
";".
join(commands)
130 command =
"({0})".
format(command)
132 command =
"dasgoclient %s --query '%s'" % (das_options, self.
queries(dataset)[0])
136 command +=
" | grep -E -v "
138 from os
import getenv
139 if getenv(
"CMSSW_USE_IBEOS",
"false")==
"true":
return command +
" | ibeos-lfn-sort"
140 return command +
" | sort -u"
143 if len(self.
run) != 0:
144 return "echo '{\n"+
",".
join((
'"%d":[[1,268435455]]\n'%(x,)
for x
in self.
run))+
"}'"
146 return "echo '{\n"+
",".
join((
'"%d" : %s\n'%(
int(x),self.
ls[x])
for x
in self.
ls.
keys()))+
"}'"
152 for run
in self.
ls.
keys():
154 for rng
in self.
ls[run]: run_lumis.append(
str(rng[0])+
","+
str(rng[1]))
155 query_lumis.append(
":".
join(run_lumis))
159 query_by =
"block" if self.
ib_block else "dataset"
170 return [
"file {0}={1} run={2}".
format(query_by, query_source, query_run)
for query_run
in self.
ls.
keys()]
181 site =
" site=T2_CH_CERN"
182 if "CMSSW_DAS_QUERY_SITES" in os.environ:
183 if os.environ[
"CMSSW_DAS_QUERY_SITES"]:
184 site =
" site=%s" % os.environ[
"CMSSW_DAS_QUERY_SITES"]
187 if len(self.
run) != 0:
188 return [
"file {0}={1} run={2}{3}".
format(query_by, query_source, query_run, site)
for query_run
in self.
run]
191 return [
"file {0}={1}{2}".
format(query_by, query_source, site)]
204 if TELL:
print(last,dictlist)
207 return copy.copy(dictlist[0])
209 reducedlist=dictlist[0:
max(0,last-1)]
210 if TELL:
print(reducedlist)
212 d=copy.copy(dictlist[last])
214 d.update(dictlist[last-1])
216 reducedlist.append(d)
217 return merge(reducedlist,TELL)
222 if TELL:
print(
"original dict, BEF: %s"%d)
224 if TELL:
print(
"copy-removed dict, AFT: %s"%e)
230 stCond={
'--conditions':
'auto:run1_mc'}
232 return {
'--relval':
'%s000,%s'%(N,s)}
234 return {
'--relval':
'%s000000,%s'%(N,s)}
238 if (
'INPUT' in steps[s]):
239 oldD=steps[s][
'INPUT'].dataSet
240 for (ref,newRef)
in listOfPairs:
242 steps[s][
'INPUT'].dataSet=oldD.replace(ref,newRef)
243 if '--pileup_input' in steps[s]:
244 for (ref,newRef)
in listOfPairs:
245 if ref
in steps[s][
'--pileup_input']:
246 steps[s][
'--pileup_input']=steps[s][
'--pileup_input'].
replace(ref,newRef)
253 def genvalid(fragment,d,suffix='all',fi='',dataSet=''):
257 c[
'-s']=c[
'-s'].
replace(
'genvalid',
'genvalid_'+suffix)
259 c[
'--filein']=
'lhe:%d'%(fi,)
261 c[
'--filein']=
'das:%s'%(dataSet,)