5 from AthenaConfiguration.ComponentAccumulator
import ComponentAccumulator
6 from AthenaConfiguration.ComponentFactory
import CompFactory
7 from AthenaMonitoringKernel.GenericMonitoringTool
import GenericMonitoringTool
9 from ROOT
import egammaPID
12 return [val]*( len( tool.EtaBins ) - 1 )
20 HistPath =
'PrecisionElectronHypo/'+name)
26 acc.merge(acc_ElectronCBSelectorTools)
27 acc.merge(acc_ElectronLHSelectorTools)
28 acc.merge(acc_ElectronDNNSelectorTools)
30 thePrecisionElectronHypo = CompFactory.TrigEgammaPrecisionElectronHypoAlg(name)
31 thePrecisionElectronHypo.Electrons =
str(sequenceOut)
32 thePrecisionElectronHypo.RunInView =
True
33 thePrecisionElectronHypo.ElectronCBSelectorTools = acc_ElectronCBSelectorTools.getPublicTools()
34 thePrecisionElectronHypo.ElectronLHSelectorTools = acc_ElectronLHSelectorTools.getPublicTools()
35 thePrecisionElectronHypo.ElectronDNNSelectorTools = acc_ElectronDNNSelectorTools.getPublicTools()
36 thePrecisionElectronHypo.CBNames = [
"medium",
"loose",
"mergedtight"]
37 thePrecisionElectronHypo.LHNames = [
"lhtight",
"lhmedium",
"lhloose",
"lhvloose",
38 "lhtight_nopix",
"lhmedium_nopix",
"lhloose_nopix",
"lhvloose_nopix",
39 "lhtight_nogsf",
"lhmedium_nogsf",
"lhloose_nogsf",
"lhvloose_nogsf",
40 "lhtight_nogsf_nopix",
"lhmedium_nogsf_nopix",
"lhloose_nogsf_nopix",
"lhvloose_nogsf_nopix"]
41 thePrecisionElectronHypo.DNNNames = [
"dnntight",
"dnnmedium",
"dnnloose"]
42 monTool.defineHistogram(
'TIME_exec', type=
'TH1F', path=
'EXPERT', title=
"Precision Electron Hypo Algtime; time [ us ] ; Nruns", xbins=80, xmin=0.0, xmax=8000.0)
43 monTool.defineHistogram(
'TIME_LH_exec', type=
'TH1F', path=
'EXPERT', title=
"Precision Electron Hypo LH Algtime; time [ us ] ; Nruns", xbins=20, xmin=0.0, xmax=2000)
44 monTool.defineHistogram(
'TIME_DNN_exec', type=
'TH1F', path=
'EXPERT', title=
"Precision Electron Hypo DNN Algtime; time [ us ] ; Nruns", xbins=20, xmin=0.0, xmax=2000)
46 thePrecisionElectronHypo.MonTool=monTool
48 return thePrecisionElectronHypo, acc
53 hypo_alg = hypo_tuple[0]
54 hypo_acc = hypo_tuple[1]
55 acc.addEventAlgo( hypo_alg )
62 __operation_points = [
'tight' ,
78 'lhtight_nogsf_nopix' ,
79 'lhmedium_nogsf_nopix' ,
80 'lhloose_nogsf_nopix' ,
81 'lhvloose_nogsf_nopix' ,
89 __operation_points_lhInfo = [
93 __operation_points_gsfInfo = [
117 def __init__(self, name, monGroups, cpart, tool=None):
119 from AthenaCommon.Logging
import logging
120 self.
__log = logging.getLogger(
'TrigEgammaPrecisionElectronHypoTool')
123 self.
__sel = cpart[
'addInfo'][0]
if cpart[
'addInfo']
else cpart[
'IDinfo']
131 from AthenaConfiguration.ComponentFactory
import CompFactory
132 tool = CompFactory.TrigEgammaPrecisionElectronHypoTool( name )
134 tool.EtaBins = [0.0, 0.6, 0.8, 1.15, 1.37, 1.52, 1.81, 2.01, 2.37, 2.47]
136 tool.dETACLUSTERthr = 0.1
137 tool.dPHICLUSTERthr = 0.1
138 tool.RelPtConeCut = -999
141 tool.AcceptAll =
False
143 tool.IsoValidation =
False
189 self.
tool().dETACLUSTERthr = 9999.
190 self.
tool().dPHICLUSTERthr = 9999.
194 self.
tool().DoNoPid =
True
198 self.
tool().dETACLUSTERthr = 9999.
199 self.
tool().dPHICLUSTERthr = 9999.
206 self.
__log.fatal(f
"Bad LRT selection name: {self.d0Info()}")
210 self.
tool().AcceptAll =
True
216 self.
__log.fatal(f
"Bad Iso selection name: {self.isoInfo()}")
217 if flags.Trigger.egamma.isoValidation:
218 self.
tool().IsoValidation = flags.Trigger.egamma.isoValidation
219 valIsoCut = {
None:
None,
'ivarloose': 0.15,
'ivarmedium': 0.065,
'ivartight': 0.06}
220 self.
tool().RelPtConeCut = valIsoCut[self.
isoInfo()]
229 self.
__log.fatal(
"Bad selection name: %s" % self.
pidname())
240 elif 'nopid' == self.
pidname():
253 if hasattr(self.
tool(),
"MonTool"):
255 doValidationMonitoring = flags.Trigger.doValidationMonitoring
258 if (any(
'egammaMon:online' in group
for group
in monGroups)
or doValidationMonitoring):
268 monTool.defineHistogram(
'dEta', type=
'TH1F', path=
'EXPERT', title=
"PrecisionElectron Hypo #Delta#eta_{EF L1}; #Delta#eta_{EF L1}", xbins=80, xmin=-0.01, xmax=0.01)
269 monTool.defineHistogram(
'dPhi', type=
'TH1F', path=
'EXPERT', title=
"PrecisionElectron Hypo #Delta#phi_{EF L1}; #Delta#phi_{EF L1}", xbins=80, xmin=-0.01, xmax=0.01)
270 monTool.defineHistogram(
'Et_em', type=
'TH1F', path=
'EXPERT', title=
"PrecisionElectron Hypo cluster E_{T}^{EM};E_{T}^{EM} [MeV]", xbins=50, xmin=-2000, xmax=100000)
271 monTool.defineHistogram(
'Eta', type=
'TH1F', path=
'EXPERT', title=
"PrecisionElectron Hypo entries per Eta;Eta", xbins=100, xmin=-2.5, xmax=2.5)
272 monTool.defineHistogram(
'Phi', type=
'TH1F', path=
'EXPERT', title=
"PrecisionElectron Hypo entries per Phi;Phi", xbins=128, xmin=-3.2, xmax=3.2)
273 monTool.defineHistogram(
'EtaBin', type=
'TH1I', path=
'EXPERT', title=
"PrecisionElectron Hypo entries per Eta bin;Eta bin no.", xbins=11, xmin=-0.5, xmax=10.5)
274 monTool.defineHistogram(
'LikelihoodRatio', type=
'TH1F', path=
'EXPERT', title=
"PrecisionElectron Hypo LH", xbins=100, xmin=-5, xmax=5)
275 monTool.defineHistogram(
'mu', type=
'TH1F', path=
'EXPERT', title=
"Average interaction per crossing", xbins=100, xmin=0, xmax=100)
276 monTool.defineHistogram(
'relptvarcone20',type=
'TH1F',path=
'EXPERT',title=
"PrecisionElectron Hypo; ptvarcone20/pt;", xbins=50, xmin=0, xmax=2)
277 monTool.defineHistogram(
'relptvarcone30',type=
'TH1F',path=
'EXPERT',title=
"PrecisionElectron Hypo; ptvarcone30/pt;", xbins=50, xmin=0, xmax=2)
278 monTool.defineHistogram(
'ptvarcone20',type=
'TH1F',path=
'EXPERT',title=
"PrecisionElectron Hypo ptvarcone20; ptvarcone20;", xbins=50, xmin=0, xmax=5.0)
279 monTool.defineHistogram(
'ptvarcone30',type=
'TH1F',path=
'EXPERT',title=
"PrecisionElectron Hypo ptvarcone30; ptvarcone30;", xbins=50, xmin=0, xmax=5.0)
282 cuts=[
'Input',
'#Delta #eta EF-L1',
'#Delta #phi EF-L1',
'eta',
'E_{T}^{EM}',
'LH',
'Isolation']
283 monTool.defineHistogram(
'CutCounter', type=
'TH1I', path=
'EXPERT', title=
"PrecisionElectron Hypo Cut Counter;Cut Counter", xbins=7, xmin=0, xmax=7, opt=
"kCumulative",xlabels=cuts)
287 if flags.Trigger.doValidationMonitoring:
288 monTool.defineHistogram(
'relptcone20',type=
'TH1F',path=
'EXPERT',title=
"PrecisionElectron Hypo; ptcone20/pt;", xbins=50, xmin=0, xmax=2)
289 monTool.defineHistogram(
'relptcone30',type=
'TH1F',path=
'EXPERT',title=
"PrecisionElectron Hypo; ptcone30/pt;", xbins=50, xmin=0, xmax=2)
290 monTool.defineHistogram(
'ptcone20',type=
'TH1F',path=
'EXPERT',title=
"PrecisionElectron Hypo ptcone20; ptcone20;", xbins=50, xmin=0, xmax=5.0)
291 monTool.defineHistogram(
'ptcone30',type=
'TH1F',path=
'EXPERT',title=
"PrecisionElectron Hypo ptcone30; ptcone30;", xbins=50, xmin=0, xmax=5.0)
292 monTool.defineHistogram(
'trk_d0', type=
"TH1F", path=
'EXPERT', title=
"PrecisionElectron Hypo Track d0; d0 [mm]", xbins=100, xmin=-1, xmax=1)
294 self.
tool().MonTool = monTool
297 def _IncTool(flags, name, monGroups, cpart, tool=None):
299 config.compile(flags)
305 """ Use menu decoded chain dictionary to configure the tool """
306 cparts = [i
for i
in d[
'chainParts']
if ((i[
'signature']==
'Electron')
or (i[
'signature']==
'Electron'))]
307 return _IncTool( flags, d[
'chainName'], d[
'monGroups'], cparts[0] , tool=tool )
318 if not ConfigFilePath:
319 ConfigFilePath = flags.Trigger.egamma.dnnVersion
321 import collections.abc
322 SelectorNames = collections.OrderedDict({
323 'dnntight' :
'AsgElectronDNNTightSelector',
324 'dnnmedium' :
'AsgElectronDNNMediumSelector',
325 'dnnloose' :
'AsgElectronDNNLooseSelector',
328 ElectronToolConfigFile = collections.OrderedDict({
329 'dnntight' :
'ElectronDNNMulticlassTight.conf',
330 'dnnmedium' :
'ElectronDNNMulticlassMedium.conf',
331 'dnnloose' :
'ElectronDNNMulticlassLoose.conf',
334 for dnnname, name
in SelectorNames.items():
335 SelectorTool = CompFactory.AsgElectronSelectorTool(name)
336 SelectorTool.ConfigFile = ConfigFilePath +
'/' + ElectronToolConfigFile[dnnname]
337 SelectorTool.skipDeltaPoverP =
True
338 acc.addPublicTool(SelectorTool)
351 import collections.abc
352 SelectorConfigFiles = collections.OrderedDict({
353 'lhtight' :
'ElectronLikelihoodTightTriggerConfig',
354 'lhmedium' :
'ElectronLikelihoodMediumTriggerConfig',
355 'lhloose' :
'ElectronLikelihoodLooseTriggerConfig',
356 'lhvloose' :
'ElectronLikelihoodVeryLooseTriggerConfig'
359 VariationConfigInfos = collections.OrderedDict({
366 VariationConfigInfos[
'_default'][
'postfix'] =
''
367 VariationConfigInfos[
'_nopix'][
'postfix'] =
'_NoPix'
368 VariationConfigInfos[
'_nogsf'][
'postfix'] =
''
369 VariationConfigInfos[
'_nogsf_nopix'][
'postfix'] =
'_NoPix'
371 VariationConfigInfos[
'_default'][
'path'] = ConfigFilePath
if ConfigFilePath
else flags.Trigger.egamma.electronPidVersion
372 VariationConfigInfos[
'_nopix'][
'path'] = ConfigFileNoPixPath
if ConfigFileNoPixPath
else flags.Trigger.egamma.electronNoPixPidVersion
373 VariationConfigInfos[
'_nogsf'][
'path'] = ConfigFileNoGSFPath
if ConfigFileNoGSFPath
else flags.Trigger.egamma.electronNoGSFPidVersion
374 VariationConfigInfos[
'_nogsf_nopix'][
'path'] = ConfigFileNoGSFNoPixPath
if ConfigFileNoGSFNoPixPath
else flags.Trigger.egamma.electronNoGSFNoPixPidVersion
376 from AthenaCommon.Logging
import logging
377 log = logging.getLogger(
'TrigEgammaPrecisionElectronHypoTool')
378 log.debug(
'TrigEgammaPrecisionElectronLHSelectorCfg, order of LH tools:' )
380 for pidvar, config
in VariationConfigInfos.items():
381 for pidname, configfilebase
in SelectorConfigFiles.items():
382 fullpidname = pidname
if pidvar ==
'_default' else pidname + pidvar
383 toolname =
'AsgElectronSelector_' + fullpidname
384 configfile = config[
'path'] +
'/' + configfilebase + config[
'postfix'] +
'.conf'
385 skipdeltapcheck =
True if 'nogsf' in pidvar
else False
387 log.debug(
' --> %s, config file: %s', fullpidname, configfile )
389 SelectorTool = CompFactory.AsgElectronLikelihoodTool(toolname)
390 SelectorTool.ConfigFile = configfile
391 SelectorTool.usePVContainer =
False
392 SelectorTool.skipDeltaPoverP = skipdeltapcheck
393 acc.addPublicTool(SelectorTool)
404 from ElectronPhotonSelectorTools.TrigEGammaPIDdefs
import BitDefElectron
407 | 1 << BitDefElectron.ClusterEtaRange_Electron
408 | 1 << BitDefElectron.ClusterHadronicLeakage_Electron
409 | 1 << BitDefElectron.ClusterMiddleEnergy_Electron
410 | 1 << BitDefElectron.ClusterMiddleEratio37_Electron
411 | 1 << BitDefElectron.ClusterMiddleWidth_Electron
412 | 1 << BitDefElectron.ClusterStripsWtot_Electron
415 ElectronMediumHI = (ElectronLooseHI
416 | 1 << BitDefElectron.ClusterMiddleEratio33_Electron
417 | 1 << BitDefElectron.ClusterBackEnergyFraction_Electron
418 | 1 << BitDefElectron.ClusterStripsEratio_Electron
419 | 1 << BitDefElectron.ClusterStripsDeltaEmax2_Electron
420 | 1 << BitDefElectron.ClusterStripsDeltaE_Electron
421 | 1 << BitDefElectron.ClusterStripsFracm_Electron
422 | 1 << BitDefElectron.ClusterStripsWeta1c_Electron
425 if not ConfigFilePath:
426 ConfigFilePath = flags.Trigger.egamma.electronHIPidVersion
428 from collections
import OrderedDict
429 SelectorNames = OrderedDict({
430 'medium':
'AsgElectronIsEMSelectorHIMedium',
431 'loose':
'AsgElectronIsEMSelectorHILoose',
432 'mergedtight' :
'AsgElectronIsEMSelectorMergedTight',
435 ElectronToolConfigFile = {
436 'medium':
'ElectronIsEMMediumSelectorCutDefs.conf',
437 'loose':
'ElectronIsEMLooseSelectorCutDefs.conf',
438 'mergedtight' :
'ElectronIsEMMergedTightSelectorCutDefs.conf',
442 'medium': ElectronMediumHI,
443 'loose': ElectronLooseHI,
444 'mergedtight' : egammaPID.ElectronTightHLT,
447 for sel, name
in SelectorNames.items():
448 SelectorTool = CompFactory.AsgElectronIsEMSelector(name)
449 SelectorTool.ConfigFile = ConfigFilePath +
'/' + ElectronToolConfigFile[sel]
450 SelectorTool.isEMMask = ElectronMaskBits[sel]
451 acc.addPublicTool(SelectorTool)