forked from cms-gem-daq-project/gem-plotting-tools
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathanaXDAQLatency.py
executable file
·104 lines (90 loc) · 3.9 KB
/
anaXDAQLatency.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
#!/bin/env python
"""
anaXDAQLatency
==============
"""
import sys, re
import time, datetime, os
if __name__ == "__main__":
from optparse import OptionParser
parser = OptionParser()
parser.add_option("-i","--infile", type="string", dest="infile",
help="Input file to process", metavar="infile")
parser.add_option("--amc13", type="int", dest="amc13", default=1,
help="AMC13 to look at", metavar="amc13")
parser.add_option("-s", "--slot", type="int", dest="slot",
help="slot in uTCA crate", metavar="slot", default=2)
parser.add_option("-g", "--gtx", type="int", dest="gtx",
help="GTX on the AMC", metavar="gtx")
parser.add_option("--scanmin", type="int", dest="scanmin", default=0,
help="Minimum value of scan parameter range to look at", metavar="scanmin")
parser.add_option("--scanmax", type="int", dest="scanmax", default=256,
help="Maximum value of scan parameter range to look at", metavar="scanmax")
(options, args) = parser.parse_args()
import ROOT as r
if (options.slot == None):
print "Please specify a valid AMC [1,12]"
exit(0)
if (options.gtx == None):
print "Please specify a valid AMC [0,1]"
exit(0)
infilename = "%s"%(options.infile)
latencyMean = r.TH1D("latencyMean", "Latency spread across all VFATs", (options.scanmax-options.scanmin)*10, options.scanmin, options.scanmax)
latencyRMS = r.TH1D("latencyRMS", "Latency RMS across all VFATs", 100, 0, 10)
allVFATsLatency = None
infile = r.TFile(infilename,"READ")
if not infile:
print infilename,"does not exist"
exit(0)
if infile.IsZombie():
print infilename,"is a zombie"
exit(0)
if not infile.IsOpen():
print infilename,"is not open"
exit(0)
baseDir = "AMC13-%d/AMC-%d/GTX-%d/"%(options.amc13,options.slot,options.gtx)
vfatDirs = ["VFAT-%d"%x for x in range(24)]
latCan = r.TCanvas("latCan","latCan", 1000,1000)
latCan.Divide(5,5)
for i,vfat in enumerate(vfatDirs):
inHist = infile.Get(baseDir+vfat+"/latencyScan")
print inHist
if inHist:
latMean = inHist.GetMean()
latRMS = inHist.GetRMS()
print "%s - %2.4f %2.4f"%(vfat,latMean,latRMS)
latencyMean.Fill(latMean)
latencyRMS.Fill(latRMS)
if not allVFATsLatency:
allVFATsLatency = inHist.Clone("allVFATSLatency")
allVFATsLatency.SetTitle("Latency scan for all VFATs summed")
else:
allVFATsLatency.Add(inHist)
pass
pass
inHist = infile.Get(baseDir+vfat+"/latencyScan2D")
print inHist
if inHist:
latCan.cd(i+1)
inHist.SetTitle(vfat)
inHist.GetXaxis().SetRangeUser(options.scanmin,options.scanmax)
inHist.Draw("colz")
#inHist.GetXaxis().SetRangeUser(145,170)
pass
pass
latCan.cd(25)
allVFATsLatency.GetXaxis().SetRangeUser(options.scanmin,options.scanmax)
allVFATsLatency.Draw()
outname = options.infile.split('/')[-1]
print outname
latCan.SaveAs("~/latency_scan_all_vfats_AMC13%02d_AMC%02d_OH%02d_%s.pdf"%(options.amc13,options.slot,options.gtx,outname))
latCan.SaveAs("~/latency_scan_all_vfats_AMC13%02d_AMC%02d_OH%02d_%s.png"%(options.amc13,options.slot,options.gtx,outname))
outCan = r.TCanvas("outCan","outCan", 1000,600)
outCan.Divide(2,1)
outCan.cd(1)
latencyMean.Draw("ep0")
outCan.cd(2)
latencyRMS.Draw("ep0")
outCan.SaveAs("~/latency_scan_AMC13%02d_AMC%02d_OH%02d_%s.pdf"%(options.amc13,options.slot,options.gtx,outname))
outCan.SaveAs("~/latency_scan_AMC13%02d_AMC%02d_OH%02d_%s.png"%(options.amc13,options.slot,options.gtx,outname))
raw_input("press enter to quit")