-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdumps2root2pdf-HF.py
executable file
·143 lines (103 loc) · 3.8 KB
/
dumps2root2pdf-HF.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
#!/usr/bin/env python
import os
import sys
import graphs
import oneRun
from options import oparser
def bail(dat, fields, reason):
sys.exit("problem with %s (%s): %s" % (dat, str(fields), reason))
def command(dat):
__feds = {22: 1118,
29: 1120,
32: 1122,
718: 718,
719: 719,
}
fields = dat.split("_")
if len(fields) != 3:
bail(dat, fields, "Expected filename prefix_cratenumber[_mb].dat")
prefix2, crate, suffix = fields
if suffix not in [".dat", "mb.dat"]:
bail(dat, fields, "unknown suffix %s" % suffix)
try:
crate = int(crate)
if crate not in __feds:
bail(dat, fields, "%s not in hard-coded list %s" % (crate, sorted(__feds.keys())))
except ValueError:
bail(dat, fields, "crate '%s' could not converted to an integer" % crate)
prefix = prefix2[1 + prefix2.rfind("/"):]
fed = __feds[crate]
tag = "deadbeef" if fed < 1000 else "badcoffee"
root1 = "data/%s_%s_%d.root" % (tag, prefix, fed)
root2 = root1.replace("data/%s_" % tag, "output/")
cmd = " && ".join(["cat %s | cpp/%s %s" % (dat, tag, fed),
"mv %s%d.root %s" % (tag, fed, root1),
])
return prefix, fed, root1, root2, cmd
def rooted(dats=[], options=None):
feds = {}
prefixes = []
for dat in dats:
if not os.path.exists(dat):
sys.exit("file %s does not exist." % dat)
prefix, fed, root1, root2, cmd = command(dat)
prefixes.append(prefix)
feds[fed] = (root1, root2)
print "%s %4d: %s" % (prefix, fed, root1)
# print cmd; continue
os.system(cmd)
return sorted(list(prefixes))[0], feds
def toCompare(feds, split1, split2):
if split1 in feds:
return filter(lambda x: x in feds, split2)
else:
return []
def histogrammed(prefix, feds, split=1118):
roots = []
feds1s = []
feds2s = []
comp = toCompare(feds, split, [718, 719])
for fed, (root1, rootOut) in sorted(feds.iteritems()):
if fed in comp:
continue
if comp and fed == split:
for cfed in comp:
print "comparison of %4d to %4d:" % (cfed, fed)
options.feds1 = str(cfed)
options.file1 = feds[cfed][0]
options.outputFile = feds[cfed][1]
options.file2 = root1
options.feds2 = str(fed)
roots.append(options.outputFile)
feds1s.append([cfed])
feds2s.append([fed])
oneRun.main(options)
else:
print "solo %4d:" % fed
options.feds1 = str(fed)
options.file1 = root1
options.outputFile = rootOut
options.feds2 = ""
options.file2 = ""
roots.append(options.outputFile)
feds1s.append([fed])
feds2s.append([])
oneRun.main(options)
return prefix, roots, feds1s, feds2s
def plot(prefix, roots, feds1s, feds2s):
graphs.makeSummaryPdfMulti(inputFiles=roots,
feds1s=feds1s,
feds2s=feds2s,
pdf="output/%s.pdf" % prefix)
if not any(feds2s):
outputFile = "output/%s.root" % prefix
cmd = " ".join(["hadd -f", outputFile] + roots)
os.system(cmd)
graphs.makeSummaryPdf(inputFile=outputFile,
feds1=sorted(sum(feds1s, [])),
pdf=outputFile.replace(".root", "_merged.pdf"))
if __name__ == "__main__":
options, args = oparser(arg=".dat [.dat ...]").parse_args()
if not args:
sys.exit("Please provide at least one .dat file as an argument")
plot(*histogrammed(*rooted(args, options)))