75def plot(data, showThreads=True, batch=False, nevtcolors=10, width=1200, height=500):
76 import ROOT
77
78 tmin = min(f.start for f in data)
79 tmax = max(f.end for f in data)
80 slots = 1 + max(f.slot for f in data)
81 threads = sorted(list(set(f.thread for f in data)))
82 threadid = dict((k, v) for v, k in enumerate(threads))
83 ymax = len(threads) if showThreads else slots
84
85 c = ROOT.TCanvas("timeline", "Timeline", width, height)
86 c.SetLeftMargin(0.05)
87 c.SetRightMargin(0.2)
88 c.SetTopMargin(0.1)
89 c.SetBottomMargin(0.1)
90 c.coord = ROOT.TH2I("coord", ";Time (ns)", 100, 0, tmax - tmin, ymax, 0, ymax)
91 c.coord.GetYaxis().SetTitle(("Thread" if showThreads else "Slot"))
92 c.coord.GetYaxis().SetTitleOffset(0.5)
93 c.coord.GetYaxis().CenterTitle()
94 c.coord.SetStats(False)
95 c.coord.GetYaxis().SetNdivisions(ymax)
96 c.coord.GetXaxis().CenterTitle()
97
98 c.Draw()
99 c.coord.Draw()
100
101 c.lines = []
102 colors = {}
103 setPalette(ymax, nevtcolors)
104 mycolors = algcolors
105 for d in data:
106 y = threadid[d.thread] if showThreads else d.slot
107 alg = d.algorithm
108 if alg not in colors and len(mycolors) > 0:
109 colors[alg] = mycolors.pop(0)
110 if len(mycolors) == 0:
111 print("Too many algorithm to show")
112
113 if alg in colors:
114 t0 = d.start - tmin
115 t1 = d.end - tmin
116
117
118 l = ROOT.TBox(t0, y + 0.1, t1, y + 0.8)
119 l.SetFillColor(colors[alg])
120
121
122 l2 = ROOT.TBox(t0, y + 0.8, t1, y + 0.9)
123 l2.SetFillColor(evtcolors[d.event % nevtcolors])
124 c.lines += [l, l2]
125
126 l2.Draw()
127 l.Draw()
128
129
130 tevt, nbslots = findEvents(data)
131 bheight = 0.1
132 for k, v in tevt.items():
133 y = ymax + bheight * v[2]
134 l = ROOT.TBox(v[0] - tmin, y + 0.2 * bheight, v[1] - tmin, y + bheight)
135 l.SetFillColor(evtcolors[k % nevtcolors])
136 c.lines += [l]
137 l.Draw()
138
139
140 c.leg = ROOT.TLegend(0.8, 0.4, 0.98, 0.9)
141 for alg, cl in sorted(colors.items(), key=operator.itemgetter(1)):
142 e = c.leg.AddEntry("", alg, "F")
143 e.SetLineColor(cl)
144 e.SetFillColor(cl)
145 e.SetFillStyle(1001)
146
147
148 bwidth = 0.18 / nevtcolors
149 for cl in range(nevtcolors):
150 l = ROOT.TLine()
151 c.lines.append(l)
152 l.SetLineWidth(10)
153 l.SetLineColor(evtcolors[cl])
154 l.DrawLineNDC(0.807 + bwidth * cl, 0.37, 0.807 + bwidth * (cl + 1), 0.37)
155
156 c.t1 = ROOT.TText(0.807, 0.314, "Events")
157 c.t1.SetNDC()
158 c.t1.SetTextFont(42)
159 c.t1.SetTextSize(0.04)
160 c.t1.Draw()
161
162 c.t2 = ROOT.TText(0.02, 0.92, "Event")
163 c.t2.SetNDC()
164 c.t2.SetTextFont(42)
165 c.t2.SetTextSize(0.03)
166 c.t2.SetTextAngle(90)
167 c.t2.Draw()
168 c.t3 = ROOT.TText(0.03, 0.922, "Slots")
169 c.t3.SetNDC()
170 c.t3.SetTextFont(42)
171 c.t3.SetTextSize(0.03)
172 c.t3.SetTextAngle(90)
173 c.t3.Draw()
174
175 c.leg.Draw()
176 c.Update()
177 if not batch:
178 eval(input())
179 return c
180
181