CMS 3D CMS Logo

List of all members | Public Member Functions | Public Attributes | Private Member Functions | Private Attributes
TH2PolyOfflineMaps.TH2PolyOfflineMaps Class Reference

Public Member Functions

def __del__ (self)
 
def __init__ (self, inputDQMName, outputDirName, minMaxFileName, limits, modDicName, runNumber, dirs, dirsAliases)
 
def DumpData (self)
 
def PrintTrackerMaps (self)
 
def ReadHistograms (self)
 

Public Attributes

 availableNames
 
 detDict
 
 detIDsFileName
 
 dirs
 
 dirsAliases
 
 geometryFilenames
 
 groupedHistograms
 
 inputFile
 
 inputFileName
 
 internalData
 
 limits
 
 limitsDic
 CREATE LIMITS DICTIONARY. More...
 
 listOfNumHistograms
 
 maxBladeToRing
 
 maxLadderToLayer
 
 minMaxFileName
 
 outputDirName
 
 rawToOnlineDict
 
 runNumber
 

Private Member Functions

def __AddNamedBins (self, geoFile, tX, tY, sX, sY, applyModuleRotation=False)
 
def __BuildOnlineBarrelName (self, signedModule, signedLadder, layer)
 
def __BuildOnlineDiskName (self, signedDisk, signedBlade, panel, ring)
 
def __CreateTrackerBaseMap (self)
 
def __GetBarrelSector (self, layer, signedLadder, signedModule)
 
def __GetPartStr (self, isXlowerThanZero, isYlowerThanZero)
 
def __GroupHistograms (self)
 
def __TraverseDirTree (self, dir)
 LOTS OF CODE BORROWED FROM: PYTHONBINREADER, PIXELTRACKERMAP. More...
 

Private Attributes

 __BaseTrackerMap
 

Detailed Description

Definition at line 59 of file TH2PolyOfflineMaps.py.

Constructor & Destructor Documentation

def TH2PolyOfflineMaps.TH2PolyOfflineMaps.__init__ (   self,
  inputDQMName,
  outputDirName,
  minMaxFileName,
  limits,
  modDicName,
  runNumber,
  dirs,
  dirsAliases 
)

Definition at line 266 of file TH2PolyOfflineMaps.py.

266  def __init__(self, inputDQMName, outputDirName, minMaxFileName, limits, modDicName, runNumber, dirs, dirsAliases):
267 # def __init__(self, inputDQMName, outputDirName, minMaxFileName, limitsFileName, modDicName, runNumber, dirs, dirsAliases):
268  self.inputFileName = inputDQMName
269  self.outputDirName = outputDirName
270  self.minMaxFileName = minMaxFileName
271 # self.limitsFileName = limitsFileName
272  self.detIDsFileName = modDicName
273  self.limits = limits
274 
275  self.runNumber = runNumber
276  self.dirs = dirs
277  self.dirsAliases = dirsAliases
278 
279  self.inputFile = TFile(self.inputFileName)
281  self.availableNames = []
282 
283  self.maxLadderToLayer = {6:1, 14:2, 22:3, 32:4}
284  self.maxBladeToRing = {11:1, 17:2}
285 
287  for i in range(maxPxBarrel):
288  self.geometryFilenames.append(getFileInPath("DQM/SiStripMonitorClient/data/Geometry/vertices_barrel_" + str(i + 1)))
289 # self.geometryFilenames.append("DATA/Geometry/vertices_barrel_" + str(i + 1))
290  for i in range(-maxPxForward, maxPxForward + 1):
291  if i == 0:
292  continue #there is no 0 disk
293  self.geometryFilenames.append(getFileInPath("DQM/SiStripMonitorClient/data/Geometry/vertices_forward_" + str(i)))
294 # self.geometryFilenames.append("DATA/Geometry/vertices_forward_" + str(i))
295 
296  self.internalData = {}
297 
298  if self.inputFile.IsOpen():
299  print("%s opened successfully!" % (self.inputFileName))
300  #Get all neeeded histograms
301  for dir in self.dirs:
302  self.__TraverseDirTree(self.inputFile.Get(dir))
303  # print("Histograms to read %d" % (len(self.listOfNumHistograms)))
304 
305  self.detDict = {}
306 
307  with open(self.detIDsFileName, "r") as detIDs: # create dictionary online -> rawid
308  for entry in detIDs:
309  items = entry.replace("\n", " ").split(" ")
310  self.detDict.update({items[1] : int(items[0])})
311  # init internal data structure
312  self.internalData.update({int(items[0]) : {}})
313 
314  self.rawToOnlineDict = dict((v,k) for k,v in self.detDict.iteritems())
315 
316  self.__GroupHistograms()
317 
319 
320  else:
321  print("Unable to open file %s" % (self.inputFileName))
322 
323  ### CREATE LIMITS DICTIONARY
324 
325  self.limitsDic = {}
326  for y in limits:
327 
328  lineSpl = y.strip().split(" ")
329 
330  if len(lineSpl) < 5:
331  continue
332 
333  currName = lineSpl[0]
334  zMin = float(lineSpl[1])
335  zMax = float(lineSpl[2])
336  isLog = False if lineSpl[3] == "0" else True
337  isAbs = False if lineSpl[4] == "0" else True
338 
339  self.limitsDic.update({currName : {"zMin" : zMin, "zMax" : zMax, "isLog" : isLog, "isAbs" : isAbs}})
def __TraverseDirTree(self, dir)
LOTS OF CODE BORROWED FROM: PYTHONBINREADER, PIXELTRACKERMAP.
S & print(S &os, JobReport::InputFile const &f)
Definition: JobReport.cc:65
def __init__(self, inputDQMName, outputDirName, minMaxFileName, limits, modDicName, runNumber, dirs, dirsAliases)
double split
Definition: MVATrainer.cc:139
def TH2PolyOfflineMaps.TH2PolyOfflineMaps.__del__ (   self)

Definition at line 527 of file TH2PolyOfflineMaps.py.

References createfilelist.int, and edm.print().

527  def __del__(self):
528  if self.inputFile.IsOpen():
529  self.inputFile.Close()
530 
531 #--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--

Member Function Documentation

def TH2PolyOfflineMaps.TH2PolyOfflineMaps.__AddNamedBins (   self,
  geoFile,
  tX,
  tY,
  sX,
  sY,
  applyModuleRotation = False 
)
private

Definition at line 189 of file TH2PolyOfflineMaps.py.

References mps_check.array, objects.autophobj.float, and split.

189  def __AddNamedBins(self, geoFile, tX, tY, sX, sY, applyModuleRotation = False):
190 
191  for line in geoFile:
192  lineSpl = line.strip().split("\"")
193 
194  detId = lineSpl[0].split(" ")[0]
195 
196  vertices = lineSpl[1]
197  xy = vertices.split(" ")
198  x, y = array('d'), array('d')
199  verNum = 1
200  for coord in xy:
201  coordSpl = coord.split(",")
202  if applyModuleRotation:
203  x.append(-(float(coordSpl[0]) * sX + tX))
204  y.append((float(coordSpl[1]) * sY + tY))
205  else:
206  x.append(float(coordSpl[0]) * sX + tX)
207  y.append(float(coordSpl[1]) * sY + tY)
208  verNum = verNum + 1
209  #close polygon
210  x.append(x[0])
211  y.append(y[0])
212 
213  # print(detId, vertices)
214  # print(x)
215  # print(y)
216  if applyModuleRotation:
217  bin = TGraph(verNum, y, x)
218  else:
219  bin = TGraph(verNum, x, y)
220  # bin = TGraph(verNum, y, x) # rotation by 90 deg (so that it had the same layout as for the strips)
221  bin.SetName(detId)
222 
223  self.__BaseTrackerMap.AddBin(bin)
224 
def __AddNamedBins(self, geoFile, tX, tY, sX, sY, applyModuleRotation=False)
double split
Definition: MVATrainer.cc:139
def TH2PolyOfflineMaps.TH2PolyOfflineMaps.__BuildOnlineBarrelName (   self,
  signedModule,
  signedLadder,
  layer 
)
private

Definition at line 161 of file TH2PolyOfflineMaps.py.

References PhaseITreeProducer.ModuleLvlValuesReader.__GetBarrelSector(), TH2PolyOfflineMaps.TH2PolyOfflineMaps.__GetBarrelSector(), PhaseITreeProducer.ModuleLvlValuesReader.__GetPartStr(), TH2PolyOfflineMaps.TH2PolyOfflineMaps.__GetPartStr(), funct.abs(), and harvestTrackValidationPlots.str.

Referenced by TH2PolyOfflineMaps.TH2PolyOfflineMaps.ReadHistograms().

161  def __BuildOnlineBarrelName(self, signedModule, signedLadder, layer): #in Phase1 it is assumed that there are only full modules
162  thePart = self.__GetPartStr(signedModule < 0, signedLadder < 0)
163  theSector = str(self.__GetBarrelSector(layer, signedLadder, signedModule))
164  return "BPix_B" + thePart + "_SEC" + theSector + "_LYR" + str(layer) + "_LDR" + str(abs(signedLadder)) + "F_MOD" + str(abs(signedModule))
165 
def __GetBarrelSector(self, layer, signedLadder, signedModule)
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
def __GetPartStr(self, isXlowerThanZero, isYlowerThanZero)
def __BuildOnlineBarrelName(self, signedModule, signedLadder, layer)
def TH2PolyOfflineMaps.TH2PolyOfflineMaps.__BuildOnlineDiskName (   self,
  signedDisk,
  signedBlade,
  panel,
  ring 
)
private

Definition at line 166 of file TH2PolyOfflineMaps.py.

References PhaseITreeProducer.ModuleLvlValuesReader.__GetPartStr(), TH2PolyOfflineMaps.TH2PolyOfflineMaps.__GetPartStr(), funct.abs(), and harvestTrackValidationPlots.str.

Referenced by TH2PolyOfflineMaps.TH2PolyOfflineMaps.ReadHistograms().

166  def __BuildOnlineDiskName(self, signedDisk, signedBlade, panel, ring):
167  thePart = self.__GetPartStr(signedDisk < 0, signedBlade < 0)
168  return "FPix_B" + thePart + "_D" + str(abs(signedDisk)) + "_BLD" + str(abs(signedBlade)) + "_PNL" + str(panel) + "_RNG" + str(ring)
169 
def __BuildOnlineDiskName(self, signedDisk, signedBlade, panel, ring)
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
def __GetPartStr(self, isXlowerThanZero, isYlowerThanZero)
def TH2PolyOfflineMaps.TH2PolyOfflineMaps.__CreateTrackerBaseMap (   self)
private

Definition at line 225 of file TH2PolyOfflineMaps.py.

226 
227  self.__BaseTrackerMap = TH2Poly("Summary", "", -10, 160, -70, 70)
228  # self.__BaseTrackerMap = TH2Poly("Summary", "Tracker Map", 0, 0, 0, 0)
229  self.__BaseTrackerMap.SetFloat(1)
230  self.__BaseTrackerMap.GetXaxis().SetTitle("")
231  self.__BaseTrackerMap.GetYaxis().SetTitle("")
232  self.__BaseTrackerMap.SetOption("COLZ L")
233  self.__BaseTrackerMap.SetStats(0)
234 
235  # BARREL FIRST
236  for i in range(maxPxBarrel):
237  with open(self.geometryFilenames[i], "r") as geoFile:
238  currBarrelTranslateX = 0
239  currBarrelTranslateY = barrelLadderShift[i]
240 
241  self.__AddNamedBins(geoFile, currBarrelTranslateX, currBarrelTranslateY, 1, 1, True)
242 
243  # break # debug only 1st layer
244 
245  # MINUS FORWARD
246  for i in range(-maxPxForward, 0):
247  with open(self.geometryFilenames[maxPxBarrel + maxPxForward + i], "r") as geoFile:
248  currForwardTranslateX = forwardDiskXShift[-i - 1]
249  currForwardTranslateY = -forwardDiskYShift
250 
251  self.__AddNamedBins(geoFile, currForwardTranslateX, currForwardTranslateY, 1, 1)
252 
253  # PLUS FORWARD
254  for i in range(maxPxForward):
255  with open(self.geometryFilenames[maxPxBarrel + maxPxForward + i], "r") as geoFile:
256  currForwardTranslateX = forwardDiskXShift[i]
257  currForwardTranslateY = forwardDiskYShift
258 
259  self.__AddNamedBins(geoFile, currForwardTranslateX, currForwardTranslateY, 1, 1)
260 
261  # self.__BaseTrackerMap.Fill("305139728", 2)
262 
263  print("Base Tracker Map: constructed")
264 
S & print(S &os, JobReport::InputFile const &f)
Definition: JobReport.cc:65
def __AddNamedBins(self, geoFile, tX, tY, sX, sY, applyModuleRotation=False)
def TH2PolyOfflineMaps.TH2PolyOfflineMaps.__GetBarrelSector (   self,
  layer,
  signedLadder,
  signedModule 
)
private

Definition at line 105 of file TH2PolyOfflineMaps.py.

References funct.abs().

Referenced by TH2PolyOfflineMaps.TH2PolyOfflineMaps.__BuildOnlineBarrelName().

105  def __GetBarrelSector(self, layer, signedLadder, signedModule): #adapted from PixelBarrelName
106  theLadder = abs(signedLadder)
107  theModule = abs(signedModule)
108 
109  sector = 0
110 
111  if layer == 1:
112 
113  if theLadder == 1:
114  if theModule >= 2:
115  return 1
116  else:
117  return 2
118  if theLadder == 2:
119  if theModule >= 3:
120  return 2
121  else:
122  return 3
123  if theLadder == 3:
124  if theModule >= 4:
125  return 3
126  else:
127  return 4
128  if theLadder == 4:
129  if theModule >= 2:
130  return 5
131  else:
132  return 6
133  if theLadder == 5:
134  if theModule >= 3:
135  return 6
136  else:
137  return 7
138  if theLadder == 6:
139  if theModule >= 4:
140  return 7
141  else:
142  return 8
143  # here is used simplified form of assignment, see source file for reference
144  elif layer == 2:
145  i = theLadder // 5
146  sector = i * 3
147  shortLadder = theLadder - 5 * i
148  for i in range(0, shortLadder, 2):
149  sector = sector + 1
150  return sector
151  elif layer == 3:
152  sector = 1
153  for i in range(2, theLadder, 3):
154  if (i + 1) % 3 == 0:
155  sector = sector + 1
156  return sector
157  elif layer == 4:
158  sector = (theLadder + 3) // 4
159  return sector
160 
def __GetBarrelSector(self, layer, signedLadder, signedModule)
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
def TH2PolyOfflineMaps.TH2PolyOfflineMaps.__GetPartStr (   self,
  isXlowerThanZero,
  isYlowerThanZero 
)
private

Definition at line 95 of file TH2PolyOfflineMaps.py.

Referenced by TH2PolyOfflineMaps.TH2PolyOfflineMaps.__BuildOnlineBarrelName(), and TH2PolyOfflineMaps.TH2PolyOfflineMaps.__BuildOnlineDiskName().

95  def __GetPartStr(self, isXlowerThanZero, isYlowerThanZero):
96  if isXlowerThanZero and isYlowerThanZero:
97  return "mO"
98  if isXlowerThanZero and isYlowerThanZero == False:
99  return "mI"
100  if isXlowerThanZero == False and isYlowerThanZero:
101  return "pO"
102  if isXlowerThanZero == False and isYlowerThanZero == False:
103  return "pI"
104 
def __GetPartStr(self, isXlowerThanZero, isYlowerThanZero)
def TH2PolyOfflineMaps.TH2PolyOfflineMaps.__GroupHistograms (   self)
private

Definition at line 170 of file TH2PolyOfflineMaps.py.

170  def __GroupHistograms(self):
171  currentGroupName = ""
172  groupOfHists = []
174 
175  ##### GROUP ALL LAYERS/RINGS HAVING SIMILAR INFORMATION
176  for obj in self.listOfNumHistograms:
177  objName = obj.GetName()
178  objNameSplit = objName.split("_")
179  objNameCollected = ''.join(objNameSplit[0:-1])
180  if objNameCollected != currentGroupName:
181  if len(groupOfHists):
182  self.groupedHistograms.append(groupOfHists)
183  groupOfHists = []
184 
185  currentGroupName = objNameCollected
186  groupOfHists.append(obj)
187  self.groupedHistograms.append(groupOfHists) #the last group
188 
static std::string join(char **cmd)
Definition: RemoteFile.cc:18
def TH2PolyOfflineMaps.TH2PolyOfflineMaps.__TraverseDirTree (   self,
  dir 
)
private

LOTS OF CODE BORROWED FROM: PYTHONBINREADER, PIXELTRACKERMAP.

Definition at line 67 of file TH2PolyOfflineMaps.py.

References InefficientDoubleROC.InefficientDeadROCs.__TraverseDirTree(), PhaseITreeProducer.ModuleLvlValuesReader.__TraverseDirTree(), TH2PolyOfflineMaps.TH2PolyOfflineMaps.__TraverseDirTree(), InefficientDoubleROC.InefficientDeadROCs.dirs, PhaseITreeProducer.ModuleLvlValuesReader.dirs, TH2PolyOfflineMaps.TH2PolyOfflineMaps.dirs, PhaseITreeProducer.ModuleLvlValuesReader.dirsAliases, TH2PolyOfflineMaps.TH2PolyOfflineMaps.dirsAliases, join(), edm.print(), and split.

Referenced by TH2PolyOfflineMaps.TH2PolyOfflineMaps.__TraverseDirTree().

67  def __TraverseDirTree(self, dir):
68 
69  try:
70  currPath = (dir.GetPath().split(":/"))[1]
71  except:
72  print("Exception raised: Path not found in the input file")
73  return
74 
75  for obj in dir.GetListOfKeys():
76  if not obj.IsFolder():
77  if obj.ReadObjectAny(TClass.GetClass("TH2")):
78  th2 = deepcopy(obj.ReadObj())
79  name = th2.GetName()
80  if 6 < th2.GetNbinsX() < 10 and name.find("per") != -1 and name.find("Lumisection") == -1: #take only module lvl plots
81  print(''.join([dir.GetPath(), '/', name]))
82 
83  # fix when there are plots starting with the same strings in different directories
84  prefix = ""
85  for i in self.dirs:
86  if currPath.startswith(i):
87  prefix = self.dirsAliases[i]
88  break
89  # print(currPath, prefix)
90  th2.SetName(prefix + th2.GetName())
91  self.listOfNumHistograms.append(th2)
92  else:
93  self.__TraverseDirTree(obj.ReadObj())
94 
def __TraverseDirTree(self, dir)
LOTS OF CODE BORROWED FROM: PYTHONBINREADER, PIXELTRACKERMAP.
S & print(S &os, JobReport::InputFile const &f)
Definition: JobReport.cc:65
static std::string join(char **cmd)
Definition: RemoteFile.cc:18
double split
Definition: MVATrainer.cc:139
def TH2PolyOfflineMaps.TH2PolyOfflineMaps.DumpData (   self)

Definition at line 387 of file TH2PolyOfflineMaps.py.

References PhaseITreeProducer.ModuleLvlValuesReader.availableNames, TH2PolyOfflineMaps.TH2PolyOfflineMaps.availableNames, PhaseITreeProducer.ModuleLvlValuesReader.internalData, TH2PolyOfflineMaps.TH2PolyOfflineMaps.internalData, and edm.print().

387  def DumpData(self):
388  for key in self.internalData:
389  print("#"*20)
390  print(key)
391  module = self.internalData[key]
392  for d in module:
393  print(d, module[d])
394 
395  print(len(self.internalData))
396 
397  for i in self.availableNames:
398  print(i)
399  print(len(self.availableNames))
400 
S & print(S &os, JobReport::InputFile const &f)
Definition: JobReport.cc:65
def TH2PolyOfflineMaps.TH2PolyOfflineMaps.PrintTrackerMaps (   self)

Definition at line 401 of file TH2PolyOfflineMaps.py.

References TH2PolyOfflineMaps.TH2PolyOfflineMaps.__BaseTrackerMap, funct.abs(), PhaseITreeProducer.ModuleLvlValuesReader.internalData, TH2PolyOfflineMaps.TH2PolyOfflineMaps.internalData, relativeConstraints.keys, TH2PolyOfflineMaps.TH2PolyOfflineMaps.limitsDic, TH2PolyOfflineMaps.TH2PolyOfflineMaps.minMaxFileName, TH2PolyOfflineMaps.TH2PolyOfflineMaps.outputDirName, edm.print(), TH2PolyOfflineMaps.TH2PolyOfflineMaps.rawToOnlineDict, tcds::Header_v1.runNumber, hcalCalib.runNumber, PUDumper.runNumber, DTStatusFlagHandler.runNumber, DTT0Handler.runNumber, DTTPGParametersHandler.runNumber, DTDeadFlagHandler.runNumber, DTReadOutMappingHandler.runNumber, DTPerformanceHandler.runNumber, DTRangeT0Handler.runNumber, Vx3DHLTAnalyzer.runNumber, ValidIsoTrkCalib.runNumber, TH2PolyOfflineMaps.TH2PolyOfflineMaps.runNumber, and harvestTrackValidationPlots.str.

401  def PrintTrackerMaps(self):
402  monitoredValues = []
403  gStyle.SetPalette(1)
404  for key in self.internalData:
405  monitoredValues = self.internalData[key].keys()
406  # print(monitoredValues)
407  break
408 
409  if os.path.exists(self.outputDirName) == False: # check whether directory exists
410  os.system("mkdir " + self.outputDirName)
411 
412  with open(self.outputDirName + self.minMaxFileName, "w") as minMaxFile:
413 
414  for mv in monitoredValues:
415  currentHist = deepcopy(self.__BaseTrackerMap)
416  # currentHist.SetTitle("Run " + self.runNumber + ": Tracker Map for " + mv) // to make it compatible between ROOT v.
417  histoTitle = "Run " + self.runNumber + ": Tracker Map for " + mv
418 
419  applyLogScale = False
420  applyAbsValue = False
421  if mv in self.limitsDic:
422  limitsElem = self.limitsDic[mv]
423 
424  print(mv + " found in limits dictionary - applying custom limits...")
425 
426  currentHist.SetMinimum(limitsElem["zMin"])
427  currentHist.SetMaximum(limitsElem["zMax"])
428  applyLogScale = limitsElem["isLog"]
429  applyAbsValue = limitsElem["isAbs"]
430 
431  listOfVals = []
432  onlineName = ""
433  for detId in self.internalData:
434  val = (self.internalData[detId])[mv]
435  onlineName = self.rawToOnlineDict[detId]
436  listOfVals.append([val, detId, onlineName])
437  if applyAbsValue:
438  currentHist.Fill(str(detId), abs(val))
439  else:
440  currentHist.Fill(str(detId), val)
441 
442  listOfVals = sorted(listOfVals, key = lambda item: item[0])
443 
444  minMaxFile.write("\n" + mv + "\n\n")
445 
446  minMaxFile.write("MIN:\n")
447  for i in range(extremeBinsNum):
448  minMaxFile.write("\t" + str(listOfVals[i][1]) + " " + str(listOfVals[i][2]) + " " + str(listOfVals[i][0]) + "\n")
449 
450  minMaxFile.write("MAX:\n")
451  for i in range(extremeBinsNum):
452  minMaxFile.write("\t" + str(listOfVals[-i - 1][1]) + " " + str(listOfVals[-i - 1][2]) + " " + str(listOfVals[-i - 1][0]) + "\n")
453 
454  c1 = TCanvas(mv, mv, plotWidth , plotHeight)
455 
456  if applyLogScale:
457  c1.SetLogz()
458 
459 
460 
461  currentHist.Draw("AC COLZ L")
462 
463  gPad.Update()
464  palette = currentHist.FindObject("palette");
465  palette.SetX1NDC(0.89);
466  palette.SetX2NDC(0.91);
467  palette.SetLabelSize(0.05);
468  gPad.Update()
469 
470 
471 
472  ### IMPORTANT - REALTIVE POSITIONING IS MESSY IN CURRENT VERION OF PYROOT
473  ### IT CAN CHANGE FROM VERSION TO VERSION, SO YOU HAVE TO ADJUST IT FOR YOUR NEEDS
474  ### !!!!!!!!!!!!!
475 
476  # draw axes (z, phi -> BARREL; x, y -> FORWARD)
477  ###################################################
478 
479  ### z arrow
480  arrow = TArrow(0.05, 27.0, 0.05, -30.0, 0.02, "|>")
481  arrow.SetLineWidth(4)
482  arrow.Draw()
483  ### phi arrow
484  phiArrow = TArrow(0.0, 27.0, 30.0, 27.0, 0.02, "|>")
485  phiArrow.SetLineWidth(4)
486  phiArrow.Draw()
487  ### x arror
488  xArrow = TArrow(25.0, 44.5, 50.0, 44.5, 0.02, "|>")
489  xArrow.SetLineWidth(4)
490  xArrow.Draw()
491  ### y arror
492  yArrow = TArrow(25.0, 44.5, 25.0, 69.5, 0.02, "|>")
493  yArrow.SetLineWidth(4)
494  yArrow.Draw()
495 
496  ###################################################
497 
498  # add some captions
499  txt = TLatex()
500  txt.SetNDC()
501  txt.SetTextFont(1)
502  txt.SetTextColor(1)
503  txt.SetTextAlign(22)
504  txt.SetTextAngle(0)
505 
506  # draw new-style title
507  txt.SetTextSize(0.05)
508  txt.DrawLatex(0.5, 0.95, histoTitle)
509 
510  txt.SetTextSize(0.03)
511 
512  txt.DrawLatex(0.5, 0.125, "-DISK")
513  txt.DrawLatex(0.5, 0.075, "NUMBER ->")
514  txt.DrawLatex(0.5, 0.875, "+DISK")
515 
516  txt.DrawLatex(0.17, 0.35, "+z")
517  txt.DrawLatexNDC(0.36, 0.685, "+phi") # WAY TO FORCE IT TO DRAW LATEX CORRECTLY NOT FOUND ('#' DOESN'T WORK)
518  txt.DrawLatex(0.38, 0.73, "+x")
519  txt.DrawLatex(0.26, 0.875, "+y")
520 
521  txt.SetTextAngle(90)
522  txt.DrawLatex(0.17, 0.5, "BARREL")
523 
524  #save to the png
525  c1.Print(self.outputDirName + mv + ".png")
526 
S & print(S &os, JobReport::InputFile const &f)
Definition: JobReport.cc:65
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
def TH2PolyOfflineMaps.TH2PolyOfflineMaps.ReadHistograms (   self)

Definition at line 342 of file TH2PolyOfflineMaps.py.

References PhaseITreeProducer.ModuleLvlValuesReader.__BuildOnlineBarrelName(), TH2PolyOfflineMaps.TH2PolyOfflineMaps.__BuildOnlineBarrelName(), PhaseITreeProducer.ModuleLvlValuesReader.__BuildOnlineDiskName(), TH2PolyOfflineMaps.TH2PolyOfflineMaps.__BuildOnlineDiskName(), InefficientDoubleROC.InefficientDeadROCs.detDict, PhaseITreeProducer.ModuleLvlValuesReader.detDict, TH2PolyOfflineMaps.TH2PolyOfflineMaps.detDict, PhaseITreeProducer.ModuleLvlValuesReader.groupedHistograms, TH2PolyOfflineMaps.TH2PolyOfflineMaps.groupedHistograms, createfilelist.int, PhaseITreeProducer.ModuleLvlValuesReader.internalData, TH2PolyOfflineMaps.TH2PolyOfflineMaps.internalData, join(), PhaseITreeProducer.ModuleLvlValuesReader.maxBladeToRing, TH2PolyOfflineMaps.TH2PolyOfflineMaps.maxBladeToRing, PhaseITreeProducer.ModuleLvlValuesReader.maxLadderToLayer, TH2PolyOfflineMaps.TH2PolyOfflineMaps.maxLadderToLayer, edm.print(), split, and update.

342  def ReadHistograms(self):
343  if self.inputFile.IsOpen():
344  for group in self.groupedHistograms:
345  # name = ''.join(group[0].GetName().split("_")[0:-1])
346  if len(group) == 0:
347  return
348  print(group[0].GetName())
349  name = ''.join(group[0].GetName().split("_per_")[0])
350  self.availableNames.append(name)
351  # print(name)
352  for obj in group:
353  nbinsX = obj.GetNbinsX()
354  nbinsY = obj.GetNbinsY()
355 
356  if nbinsX == 9: # BARREL
357  maxX = nbinsX // 2
358  maxY = nbinsY // 2
359 
360  for x in range(-maxX, maxX + 1):
361  if x == 0:
362  continue
363  for y in range(-maxY, maxY + 1, 1):
364  if y == 0:
365  continue
366  onlineName = self.__BuildOnlineBarrelName(x, y, self.maxLadderToLayer[maxY])
367  self.internalData[self.detDict[onlineName]].update({name : obj.GetBinContent(x + maxX + 1, y + maxY + 1)})
368 
369  elif nbinsX == 7: # FORWARD
370  maxX = nbinsX // 2
371  maxY = nbinsY // 4
372 
373  for x in range(-maxX, maxX + 1):
374  if x == 0:
375  continue
376  for y in range(-maxY, maxY + 1):
377  if int(y) == 0:
378  continue
379  for panel in range(1, 3):
380  onlineName = self.__BuildOnlineDiskName(x, y, panel, self.maxBladeToRing[maxY])
381  self.internalData[self.detDict[onlineName]].update({name : obj.GetBinContent(x + maxX + 1, (y + maxY) * 2 + panel)})
382  else:
383  print("Unrecognized plot")
384  else:
385  print("Histograms saved to internal data structure")
386 
S & print(S &os, JobReport::InputFile const &f)
Definition: JobReport.cc:65
def __BuildOnlineDiskName(self, signedDisk, signedBlade, panel, ring)
static std::string join(char **cmd)
Definition: RemoteFile.cc:18
def __BuildOnlineBarrelName(self, signedModule, signedLadder, layer)
#define update(a, b)
double split
Definition: MVATrainer.cc:139

Member Data Documentation

TH2PolyOfflineMaps.TH2PolyOfflineMaps.__BaseTrackerMap
private
TH2PolyOfflineMaps.TH2PolyOfflineMaps.availableNames
TH2PolyOfflineMaps.TH2PolyOfflineMaps.detDict
TH2PolyOfflineMaps.TH2PolyOfflineMaps.detIDsFileName

Definition at line 272 of file TH2PolyOfflineMaps.py.

TH2PolyOfflineMaps.TH2PolyOfflineMaps.dirs
TH2PolyOfflineMaps.TH2PolyOfflineMaps.dirsAliases
TH2PolyOfflineMaps.TH2PolyOfflineMaps.geometryFilenames

Definition at line 286 of file TH2PolyOfflineMaps.py.

TH2PolyOfflineMaps.TH2PolyOfflineMaps.groupedHistograms
TH2PolyOfflineMaps.TH2PolyOfflineMaps.inputFile

Definition at line 279 of file TH2PolyOfflineMaps.py.

TH2PolyOfflineMaps.TH2PolyOfflineMaps.inputFileName

Definition at line 268 of file TH2PolyOfflineMaps.py.

TH2PolyOfflineMaps.TH2PolyOfflineMaps.internalData
TH2PolyOfflineMaps.TH2PolyOfflineMaps.limits

Definition at line 273 of file TH2PolyOfflineMaps.py.

TH2PolyOfflineMaps.TH2PolyOfflineMaps.limitsDic

CREATE LIMITS DICTIONARY.

Definition at line 325 of file TH2PolyOfflineMaps.py.

Referenced by TH2PolyOfflineMaps.TH2PolyOfflineMaps.PrintTrackerMaps().

TH2PolyOfflineMaps.TH2PolyOfflineMaps.listOfNumHistograms

Definition at line 280 of file TH2PolyOfflineMaps.py.

TH2PolyOfflineMaps.TH2PolyOfflineMaps.maxBladeToRing
TH2PolyOfflineMaps.TH2PolyOfflineMaps.maxLadderToLayer
TH2PolyOfflineMaps.TH2PolyOfflineMaps.minMaxFileName
TH2PolyOfflineMaps.TH2PolyOfflineMaps.outputDirName
TH2PolyOfflineMaps.TH2PolyOfflineMaps.rawToOnlineDict
TH2PolyOfflineMaps.TH2PolyOfflineMaps.runNumber