4from AthenaCommon.Logging
import logging
5from AthenaConfiguration.ComponentAccumulator
import ComponentAccumulator
6from AthenaConfiguration.ComponentFactory
import CompFactory
7from AthenaMonitoringKernel.GenericMonitoringTool
import GenericMonitoringTool
8from AthenaConfiguration.AccumulatorCache
import AccumulatorCache
9from TriggerMenuMT.HLT.CommonSequences.FullScanDefs
import em_clusters, lc_clusters, fs_towers, fs_cells
11from TrigEDMConfig.TriggerEDM
import recordable
13mlog = logging.getLogger (
'TrigCaloRecConfig')
17 """Monitoring tool for TrigCaloClusterMaker"""
19 monTool = GenericMonitoringTool(flags, 'MonTool')
21 if isFullScan is None:
22 isFullScan = doMonCells
24 maxNumberOfClusters = 1200 if isFullScan else 50
26 monTool.defineHistogram('container_size', path='EXPERT', type='TH1F', title="Container Size; Number of Clusters; Number of Events", xbins=50, xmin=0.0, xmax=maxNumberOfClusters)
27 monTool.defineHistogram('container_size_by_mu', path='EXPERT', type='TH1F', title="Container Size; Number of Clusters; Number of Events", xbins=50, xmin=0.0, xmax=maxNumberOfClusters/60)
28 monTool.defineHistogram('Et', path='EXPERT', type='TH1F', title="Cluster E_T; E_T [ MeV ] ; Number of Clusters", xbins=135, xmin=-200.0, xmax=2500.0)
29 monTool.defineHistogram('Eta', path='EXPERT', type='TH1F', title="Cluster #eta; #eta ; Number of Clusters", xbins=100, xmin=-2.5, xmax=2.5)
30 monTool.defineHistogram('Phi', path='EXPERT', type='TH1F', title="Cluster #phi; #phi ; Number of Clusters", xbins=64, xmin=-3.2, xmax=3.2)
31 monTool.defineHistogram('Eta,Phi', path='EXPERT', type='TH2F', title="Number of Clusters; #eta ; #phi ; Number of Clusters", xbins=100, xmin=-2.5, xmax=2.5, ybins=128, ymin=-3.2, ymax=3.2)
32 monTool.defineHistogram('clusterSize', path='EXPERT', type='TH1F', title="Cluster Type; Type ; Number of Clusters", xbins=13, xmin=0.5, xmax=13.5)
33 monTool.defineHistogram('signalState', path='EXPERT', type='TH1F', title="Signal State; Signal State ; Number of Clusters", xbins=4, xmin=-1.5, xmax=2.5)
34 monTool.defineHistogram('size', path='EXPERT', type='TH1F', title="Cluster Size; Size [Cells] ; Number of Clusters", xbins=125, xmin=0.0, xmax=250.0)
35 monTool.defineHistogram('N_BAD_CELLS', path='EXPERT', type='TH1F', title="N_BAD_CELLS; N_BAD_CELLS ; Number of Clusters", xbins=250, xmin=0.5, xmax=250.5)
36 monTool.defineHistogram('ENG_FRAC_MAX', path='EXPERT', type='TH1F', title="ENG_FRAC_MAX; ENG_FRAC_MAX ; Number of Clusters", xbins=50, xmin=0.0, xmax=1.1)
37 monTool.defineHistogram('mu', path='EXPERT', type='TH1F', title="mu; mu; Number of Events", xbins=50, xmin=0.0, xmax=100)
38 monTool.defineHistogram('mu,container_size', path='EXPERT', type='TH2F', title="Container Size versus #mu; #mu; cluster container size", xbins=50, xmin=20.0, xmax=70, ybins=50, ymin=0.0, ymax=maxNumberOfClusters)
41 monTool.defineHistogram('count_1thrsigma', path='EXPERT', type='TH1F', title="count_1thrsigma; count_1thresigma; Number of Events", xbins=60, xmin=0.0, xmax=12e3)
42 monTool.defineHistogram('count_2thrsigma', path='EXPERT', type='TH1F', title="count_2thrsigma; count_2thresigma; Number of Events", xbins=60, xmin=0.0, xmax=6e3)
43 monTool.defineHistogram('count_1thrsigma_by_mu2', path='EXPERT', type='TH1F', title="count_1thrsigma_by_mu2; count_1thresigma_by_mu2; Number of Events", xbins=50, xmin=0.0, xmax=10)
44 monTool.defineHistogram('count_2thrsigma_by_mu2', path='EXPERT', type='TH1F', title="count_2thrsigma_by_mu2; count_2thresigma_by_mu2; Number of Events", xbins=50, xmin=0.0, xmax=5)
45 monTool.defineHistogram('mu,count_1thrsigma', path='EXPERT', type='TH2F', title="nCells above 1st thr versus #mu; #mu; nCells", xbins=50, xmin=20.0, xmax=70, ybins=60, ymin=0.0, ymax=12e3)
46 monTool.defineHistogram('mu,count_2thrsigma', path='EXPERT', type='TH2F', title="nCells above 2nd thr versus #mu; #mu; nCells", xbins=50, xmin=20.0, xmax=70, ybins=60, ymin=0.0, ymax=6e3)
52def hltCaloCellMakerCfg(flags, name=None, roisKey='UNSPECIFIED', CellsName=None, monitorCells=False, doTau=False,sequenceName=None):
53 acc = ComponentAccumulator()
54 from TrigT2CaloCommon.TrigCaloDataAccessConfig import trigCaloDataAccessSvcCfg, CaloDataAccessSvcDependencies
55 acc.merge(trigCaloDataAccessSvcCfg(flags))
56 #choose RoI for fullscan
57 if (roisKey == 'UNSPECIFIED'):
58 from HLTSeeding.HLTSeedingConfig import mapThresholdToL1RoICollection
59 roisKey = mapThresholdToL1RoICollection("FSNOSEED")
60 # choose cells name given parameters
61 cellsFromName = 'CaloCellsFS' if "FS" in name else "CaloCells"
62 cells = cellsFromName if CellsName is None else CellsName
64 from AthenaMonitoringKernel.GenericMonitoringTool import GenericMonitoringTool
65 monTool = GenericMonitoringTool(flags, 'MonTool')
66 monTool.defineHistogram('Cells_N', path='EXPERT', type='TH1F', title="Cells N; NCells; events",
67 xbins=40, xmin=0, xmax=1600 if monitorCells else 240000)
68 monTool.defineHistogram('TIME_exec', path='EXPERT', type='TH1F', title="Cells time; time [ us ] ; Nruns",
69 xbins=80, xmin=0, xmax=800 if monitorCells else 160000)
71 monTool.defineHistogram('Cells_eT', path='EXPERT', type='TH1F', title="Cells E_T; E_T [ GeV ] ; Nclusters",
72 xbins=100, xmin=0.0, xmax=100.0)
73 monTool.defineHistogram('Cells_eta', path='EXPERT', type='TH1F', title="Cells #eta; #eta ; Nclusters",
74 xbins=100, xmin=-2.5, xmax=2.5)
75 monTool.defineHistogram('Cells_phi', path='EXPERT', type='TH1F', title="Cells #phi; #phi ; Nclusters",
76 xbins=128, xmin=-3.2, xmax=3.2)
78 if sequenceName is not None:
79 from AthenaCommon.CFElements import parOR
80 acc.merge(ComponentAccumulator(parOR(sequenceName)))
81 cellMaker = CompFactory.HLTCaloCellMaker(name,
83 TrigDataAccessMT = acc.getService('TrigCaloDataAccessSvc'),
84 ExtraInputs = CaloDataAccessSvcDependencies,
86 monitorCells = monitorCells,
88 TileCellsInROI = False if not doTau else True)
89 acc.addEventAlgo(cellMaker, primary=True,sequenceName=sequenceName)
93def hltCaloCellCorrectorCfg(flags,name='HLTCaloCellCorrector', inputEDM='CellsClusters', outputEDM='CorrectedCellsClusters', eventShape='HIEventShape'):
94 acc = ComponentAccumulator()
95 cellCorrector = CompFactory.HLTCaloCellCorrector(name = name,
96 EventShapeCollection = eventShape,
97 InputCellKey = inputEDM,
98 OutputCellKey = outputEDM)
99 acc.addEventAlgo(cellCorrector)
104def hltCaloCellSeedlessMakerCfg(flags, roisKey='UNSPECIFIED',sequenceName=None):
105 acc = ComponentAccumulator()
106 hltCaloCellMakerAcc = hltCaloCellMakerCfg(flags, "CaloCellSeedLessFS",
108 CellsName ="SeedLessFS",
111 acc.merge(hltCaloCellMakerAcc,sequenceName=sequenceName)
113 from CaloTools.CaloNoiseCondAlgConfig import CaloNoiseCondAlgCfg
114 acc.merge(CaloNoiseCondAlgCfg(flags, noisetype="electronicNoise"))
115 acc.addCondAlgo(CompFactory.CaloNoiseSigmaDiffCondAlg())
121def L0CaloGlobalRoIBuilderCfg(flags,DoNoiseThrRings=True):
122 acc = ComponentAccumulator()
123 from TrigT2CaloEgamma.TrigT2CaloEgammaConfig import RingerReFexConfig
124 nameTool='RingerGlobalFex'
125 nameAlgo='L0CaloGlobalRoIBuilder'
126 nameContCalo='CaloClustersGlobal'
127 nameContRinger='RingerGlobal'
128 if ( DoNoiseThrRings ):
129 nameTool='RingerGlobal2sigFex'
130 nameAlgo='L0CaloGlobalRoI2sigBuilder'
131 nameContCalo='CaloClusters2sigGlobal'
132 nameContRinger='Ringer2sigGlobal'
133 ringer = RingerReFexConfig(flags,name=nameTool,RingerKey='NOTNEEDED',
134 ClustersName=nameContCalo,DoNoiseThrRings=DoNoiseThrRings)
135 from AthenaCommon.CFElements import parOR
136 accSeq = ComponentAccumulator(parOR("HLTBeginSeq"))
137 L0CaloGlobalRoIBuilderAlg = CompFactory.CaloGlobalRoIBuilder(name=nameAlgo,
138 Cells ="SeedLessFS", ClustersName=nameContCalo,
139 RingerKey=nameContRinger,
141 accSeq.addEventAlgo(L0CaloGlobalRoIBuilderAlg, sequenceName="HLTBeginSeq")
143 from CaloTools.CaloNoiseCondAlgConfig import CaloNoiseCondAlgCfg
144 acc.merge(CaloNoiseCondAlgCfg(flags))
149def CaloL0RingerPreCfg(flags,DoNoiseThrRings=True):
150 flags.Trigger.ExtraEDMList+= CaloL0RingerPrepareList(DoNoiseThrRings)
152def CaloL0RingerPrepareList(DoNoiseThrRings=True):
155 extraEDMList+=[('xAOD::TrigRingerRingsContainer#Ringer2sigGlobal', 'BS ESD AODFULL', 'Calo'), ('xAOD::TrigRingerRingsAuxContainer#Ringer2sigGlobalAux.', 'BS ESD AODFULL', 'Calo'), ('xAOD::TrigEMClusterContainer#CaloClusters2sigGlobal', 'BS ESD AODFULL', 'Calo'), ('xAOD::TrigEMClusterAuxContainer#CaloClusters2sigGlobalAux.', 'BS ESD AODFULL', 'Calo')]
157 extraEDMList+=[('xAOD::TrigRingerRingsContainer#RingerGlobal', 'BS ESD AODFULL', 'Calo'), ('xAOD::TrigRingerRingsAuxContainer#RingerGlobalAux.', 'BS ESD AODFULL', 'Calo'), ('xAOD::TrigEMClusterContainer#CaloClustersGlobal', 'BS ESD AODFULL', 'Calo'), ('xAOD::TrigEMClusterAuxContainer#CaloClustersGlobalAux.', 'BS ESD AODFULL', 'Calo')]
160def CaloL0RingerCfg(flags,DoNoiseThrRings=True):
161 from OutputStreamAthenaPool.OutputStreamConfig import addToESD,addToAOD
162 extraContent=CaloL0RingerPrepareList(DoNoiseThrRings)
163 acc = ComponentAccumulator()
164 from AthenaCommon.CFElements import parOR
165 if (flags.Output.doWriteRDO):
166 accSeq = ComponentAccumulator(parOR("HLTBeginSeq"))
167 accSeq.merge(hltCaloCellSeedlessMakerCfg(flags, sequenceName="HLTBeginSeq"))
168 accSeq.merge(L0CaloGlobalRoIBuilderCfg(flags,DoNoiseThrRings=DoNoiseThrRings))
171 if (flags.Output.doWriteESD or flags.Output.doWriteAOD):
172 if ( flags.Output.doWriteESD ):
173 acc.merge(addToESD(flags, extraContent))
174 if ( flags.Output.doWriteAOD ):
175 acc.merge(addToAOD(flags, extraContent))
180def hltCaloLocalCalib(flags, name = "TrigLocalCalib"):
181 det_version_is_rome = flags.GeoModel.AtlasVersion.startswith("Rome")
182 localCalibTool = CompFactory.CaloLCWeightTool("TrigLCWeight",
183 CorrectionKey="H1ClusterCellWeights",
184 SignalOverNoiseCut=2.0, UseHadProbability=True)
185 trigLCClassify = CompFactory.CaloLCClassificationTool("TrigLCClassify",
186 ClassificationKey="EMFracClassify",
187 UseSpread=False, MaxProbability=0.85 if det_version_is_rome else 0.5,
188 UseNormalizedEnergyDensity=not det_version_is_rome,
189 StoreClassificationProbabilityInAOD=True)
190 tool = CompFactory.CaloClusterLocalCalib( name,
191 ClusterRecoStatus=[1, 2], ClusterClassificationTool=[ trigLCClassify ],
192 LocalCalibTools=[ localCalibTool ])
196def hltCaloOOCalib(flags, name = "TrigOOCCalib"):
197 localCalibTool = CompFactory.CaloLCOutOfClusterTool("TrigLCOut",
198 CorrectionKey="OOCCorrection",UseEmProbability=False,
199 UseHadProbability=True)
200 tool = CompFactory.CaloClusterLocalCalib( name,
201 ClusterRecoStatus=[1, 2],
202 LocalCalibTools=[ localCalibTool ] )
205def hltCaloOOCPi0Calib(flags, name = "TrigOOCPi0Calib" ):
206 localCalibTool = CompFactory.CaloLCOutOfClusterTool("TrigLCOutPi0",
207 CorrectionKey="OOCPi0Correction", UseEmProbability=True,
208 UseHadProbability=False)
209 tool = CompFactory.CaloClusterLocalCalib( name,
210 ClusterRecoStatus=[1, 2],
211 LocalCalibTools=[ localCalibTool ] )
214def hltCaloDMCalib(flags, name = "TrigDMCalib" ):
215 localCalibTool = CompFactory.CaloLCDeadMaterialTool("TrigLCDeadMaterial",
216 HadDMCoeffKey="HadDMCoeff2", ClusterRecoStatus=0,
217 WeightModeDM=2,UseHadProbability=True)
218 tool = CompFactory.CaloClusterLocalCalib( name,
219 ClusterRecoStatus=[1, 2],
220 LocalCalibTools=[ localCalibTool ] )
226def hltTopoClusterMakerCfg(flags, name, clustersKey="HLT_TopoCaloClustersFS", cellsKey=None, doLC=False, suffix=''):
227 acc = ComponentAccumulator()
228 cellsFromName = 'CaloCellsFS' if "FS" in clustersKey else "CaloCells"
229 cells = cellsFromName if cellsKey is None else cellsKey
231 from CaloRec.CaloTopoClusterConfig import (
232 CaloTopoClusterToolCfg,
233 CaloTopoClusterSplitterToolCfg,
236 topoMaker = acc.popToolsAndMerge(CaloTopoClusterToolCfg(flags, cellsname=cells))
237 topoMaker.RestrictPSNeighbors = False
238 listClusterCorrectionTools = []
240 from CaloTools.CaloNoiseCondAlgConfig import CaloNoiseCondAlgCfg
241 # We need the electronic noise for the LC weights
242 acc.merge(CaloNoiseCondAlgCfg(flags, noisetype="electronicNoise"))
243 from CaloRec.CaloTopoClusterConfig import caloTopoCoolFolderCfg
244 acc.merge(caloTopoCoolFolderCfg(flags))
245 listClusterCorrectionTools = [ hltCaloLocalCalib(flags), hltCaloOOCalib(flags),
246 hltCaloOOCPi0Calib(flags), hltCaloDMCalib(flags) ]
249 topoMaker.SeedCutsInT = flags.Trigger.Calo.TopoCluster.doTimeCut
250 topoMaker.CutOOTseed = flags.Trigger.Calo.TopoCluster.extendTimeCut and flags.Trigger.Calo.TopoCluster.doTimeCut
251 topoMaker.UseTimeCutUpperLimit = flags.Trigger.Calo.TopoCluster.useUpperLimitForTimeCut
252 topoMaker.TimeCutUpperLimit = flags.Trigger.Calo.TopoCluster.timeCutUpperLimit
254 topoSplitter = acc.popToolsAndMerge(CaloTopoClusterSplitterToolCfg(flags))
256 topoMoments = CompFactory.CaloClusterMomentsMaker ('TrigTopoMoments')
257 topoMoments.MaxAxisAngle = 20*deg
258 topoMoments.TwoGaussianNoise = flags.Calo.TopoCluster.doTwoGaussianNoise
259 topoMoments.MinBadLArQuality = 4000
260 topoMoments.MomentsNames = ['FIRST_PHI',
294 clustermakername = name + suffix
295 doMonCells = "FS" in clustermakername
297 alg = CompFactory.CaloClusterMaker(
299 ClustersOutputName=clustersKey if "CaloMon" in clustermakername else recordable(clustersKey),
300 ClusterCellLinkOutputName = clustersKey+"_links",
301 ClusterMakerTools = [ topoMaker, topoSplitter, topoMoments],
302 ClusterCorrectionTools = listClusterCorrectionTools,
303 SaveUncalibratedSignalState = True,
304 WriteTriggerSpecificInfo = True)
306 from CaloTools.CaloNoiseCondAlgConfig import CaloNoiseCondAlgCfg
307 acc.merge(CaloNoiseCondAlgCfg(flags))
308 acc.addEventAlgo(alg, primary=True)
309 monitor = CompFactory.TrigCaloClusterMonitor(name + 'Monitoring' + suffix,
311 ClustersName = clustersKey,
312 MonitorCells = doMonCells,
313 MonitoringTool = trigCaloClusterMonitoringTool(flags, doMonCells))
314 acc.addEventAlgo(monitor, primary=False)
319def hltCaloTopoClusterCalibratorCfg(flags, name, clustersin, clustersout, **kwargs):
320 """ Create the LC calibrator """
321 from CaloTools.CaloNoiseCondAlgConfig import CaloNoiseCondAlgCfg
323 # We need the electronic noise for the LC weights
324 acc = ComponentAccumulator()
325 acc.merge(CaloNoiseCondAlgCfg(flags, noisetype="electronicNoise"))
327 from CaloRec.CaloTopoClusterConfig import caloTopoCoolFolderCfg
328 acc.merge(caloTopoCoolFolderCfg(flags))
330 calibrator = CompFactory.TrigCaloClusterCalibrator(
331 name, InputClusters=clustersin, OutputClusters=clustersout,
333 #OutputCellLinks = clustersout+"_cellLinks", **kwargs
336 calibrator.ClusterCorrectionTools = [ hltCaloLocalCalib(flags), hltCaloOOCalib(flags),
337 hltCaloOOCPi0Calib(flags), hltCaloDMCalib(flags) ]
338 #NB: Could we take these from CaloRec.CaloTopoClusterConfig.getTopoClusterLocalCalibTools?
341 monTool = GenericMonitoringTool(flags, "MonTool")
342 monTool.defineHistogram('Et', path='EXPERT', type='TH1F',
343 title="Cluster E_T; E_T [ MeV ] ; Number of Clusters",
344 xbins=135, xmin=-200.0, xmax=2500.0)
345 monTool.defineHistogram('Eta', path='EXPERT', type='TH1F',
346 title="Cluster #eta; #eta ; Number of Clusters",
347 xbins=100, xmin=-2.5, xmax=2.5)
348 monTool.defineHistogram('Phi', path='EXPERT', type='TH1F',
349 title="Cluster #phi; #phi ; Number of Clusters",
350 xbins=64, xmin=-3.2, xmax=3.2)
351 monTool.defineHistogram('Eta,Phi', path='EXPERT', type='TH2F',
352 title="Number of Clusters; #eta ; #phi ; Number of Clusters",
353 xbins=100, xmin=-2.5, xmax=2.5, ybins=128, ymin=-3.2, ymax=3.2)
354 calibrator.MonTool = monTool
356 acc.addEventAlgo(calibrator, primary=True)
359##################### Unifying all cluster reco algs together ##################
360from TriggerMenuMT.HLT.Egamma.TrigEgammaKeys import getTrigEgammaKeys
363def hltCaloTopoClusteringCfg(
364 flags, namePrefix=None,nameSuffix=None, CellsName=None, monitorCells=False, roisKey="UNSPECIFIED",clustersKey=None, doLCFS=False, doTau = False):
366 CellsName = "CaloCellsLC"
367 clustersKeyFromName = "HLT_TopoCaloClustersLC"
368 elif nameSuffix == "FS":
369 clustersKeyFromName = em_clusters
371 TrigEgammaKeys = getTrigEgammaKeys(flags)
372 clustersKeyFromName = TrigEgammaKeys.precisionTopoClusterContainer
374 clusters = clustersKeyFromName if clustersKey is None else clustersKey
375 acc = ComponentAccumulator()
377 hltCaloCellMakerCfg(flags, namePrefix + "HLTCaloCellMaker"+nameSuffix, roisKey=roisKey, CellsName=CellsName, monitorCells=monitorCells, doTau = doTau)
380 clustermakername_nosuffix = namePrefix + "HLTCaloClusterMaker"
382 clustermakername = clustermakername_nosuffix + nameSuffix
384 # TODO - Don't use hasFlag here, use another concrete flag instead
385 if flags.hasFlag("CaloRecGPU.GlobalFlags.UseCaloRecGPU") and flags.CaloRecGPU.GlobalFlags.UseCaloRecGPU and "FS" in clustermakername:
386 flags = flags.cloneAndReplace("CaloRecGPU.ActiveConfig", "Trigger.CaloRecGPU.Default", True)
387 from CaloRecGPU.CaloRecGPUConfig import GPUCaloTopoClusterCfg
390 GPUKernelSvc = CompFactory.GPUKernelSizeOptimizerSvc()
391 acc.addService(GPUKernelSvc)
393 gpuhyb = GPUCaloTopoClusterCfg(flags,
396 clustersname = clusters if "CaloMon" in clustermakername else recordable(clusters),
397 name = clustermakername,
398 ReallyUseGPUTools = not flags.CaloRecGPU.GlobalFlags.UseCPUToolsInstead)
402 monitorCells = "FS" in clustermakername
404 monitor = CompFactory.TrigCaloClusterMonitor(clustermakername_nosuffix + 'Monitoring' + nameSuffix,
405 CellsName = CellsName,
406 ClustersName = clusters,
407 MonitorCells = monitorCells,
408 MonitoringTool = trigCaloClusterMonitoringTool(flags, monitorCells))
409 acc.addEventAlgo(monitor, primary=False)
412 calt=hltTopoClusterMakerCfg(flags, clustermakername_nosuffix, cellsKey=CellsName, clustersKey=clusters, doLC=doTau, suffix = nameSuffix)
415 acc.merge( hltCaloTopoClusterCalibratorCfg(
417 "HLTCaloClusterCalibratorLCFS",
418 clustersin=em_clusters,
419 clustersout=lc_clusters,
420 OutputCellLinks=lc_clusters + "_cellLinks",
425###################################EgammaSpecific TopoClustering####################################
427def egammaTopoClusteringCfg(flags, RoIs):
428 cfg = hltCaloTopoClusteringCfg(flags, namePrefix="", nameSuffix="RoI", CellsName="CaloCells", monitorCells=True, roisKey=RoIs)
433def egammaTopoClusteringCfg_LRT(flags, RoIs):
434 TrigEgammaKeys_LRT = getTrigEgammaKeys(flags, name = '_LRT')
435 cfg = hltCaloTopoClusteringCfg(flags, namePrefix="", nameSuffix="RoI_LRT", CellsName="CaloCells", monitorCells=True, roisKey=RoIs, clustersKey= TrigEgammaKeys_LRT.precisionTopoClusterContainer)
439###################################JetMetSpecific TopoClustering####################################
441def jetmetTopoClusteringCfg(flags, RoIs):
442 cfg = hltCaloTopoClusteringCfg(flags, namePrefix="", nameSuffix="FS", CellsName="CaloCellsFS", monitorCells=False, roisKey=RoIs)
446def jetmetTopoClusteringCfg_LC(flags, RoIs):
447 cfg = hltCaloTopoClusteringCfg(flags, namePrefix="", nameSuffix="FS", CellsName="CaloCellsFS", monitorCells=False, roisKey=RoIs, doLCFS=True)
450###################################TauSpecific TopoClustering####################################
452def tauTopoClusteringCfg(flags, RoIs):
453 cfg = hltCaloTopoClusteringCfg(flags, namePrefix="Tau", nameSuffix="", CellsName="CaloCellsLC", monitorCells=False, roisKey=RoIs, clustersKey="HLT_TopoCaloClustersLC", doTau= True)
457def hltCaloTopoClusteringHICfg(
458 flags, CellsName=None, roisKey="UNSPECIFIED", doLC=False,algSuffix='HIRoI', ion=True):
459 TrigEgammaKeys = getTrigEgammaKeys(flags, ion=ion)
460 eventShape = TrigEgammaKeys.egEventShape
461 clustersKey = TrigEgammaKeys.precisionTopoClusterContainer
462 acc = ComponentAccumulator()
463 acc.merge(hltCaloCellMakerCfg(flags, "HLTCaloCellMaker"+algSuffix, roisKey=roisKey, CellsName=CellsName, monitorCells=True))
464 acc.merge(hltCaloCellCorrectorCfg(flags,name='HLTRoICaloCellCorrector', inputEDM='CaloCells', outputEDM='CorrectedRoICaloCells', eventShape=eventShape))
465 acc.merge(hltTopoClusterMakerCfg(flags, "TrigCaloClusterMaker_topo"+algSuffix, clustersKey=clustersKey,cellsKey="CorrectedRoICaloCells"))
469def hltHICaloTowerMakerCfg(flags, name, towersKey, cellsKey="CaloCellsFS", RoIs=""):
470 acc = ComponentAccumulator()
471 larcmbtwrbldr = CompFactory.LArTowerBuilderTool("LArCmbTwrBldr",
472 CellContainerName = cellsKey,
473 IncludedCalos = [ "LAREM", "LARHEC" ]
476 fcalcmbtwrbldr = CompFactory.LArFCalTowerBuilderTool("FCalCmbTwrBldr",
477 CellContainerName = cellsKey,
481 #input to TileTowerBuilder: cells in TILE
482 tilecmbtwrbldr = CompFactory.TileTowerBuilderTool("TileCmbTwrBldr",
483 CellContainerName = cellsKey,
484 # debugging aid, keep for convenience
486 #DumpWeightMap = False
491 alg = CompFactory.TrigCaloTowerMaker(name,
493 CaloTowers=towersKey,
494 NumberOfPhiTowers=64,
495 NumberOfEtaTowers=100,
501 TowerMakerTools = [ tilecmbtwrbldr, larcmbtwrbldr, fcalcmbtwrbldr ]
503 from CaloTools.CaloNoiseCondAlgConfig import CaloNoiseCondAlgCfg
504 acc.merge(CaloNoiseCondAlgCfg(flags))
505 acc.addEventAlgo(alg, primary=True)
509def hltHICaloClusterMakerCfg(flags, name, towersKey, cellsKey, clustersKey) :
510 """Function to equip HLT HI cluster builder from towers and cells, adds to output AOD stream"""
511 acc = ComponentAccumulator()
514 alg=CompFactory.HIClusterMaker(name,
515 InputTowerKey=towersKey,
516 CaloCellContainerKey=cellsKey,
517 OutputContainerKey=clustersKey
519 acc.addEventAlgo(alg, primary=True)
523def HICaloTowerCfg(flags):
524 """ Create the towers for heavy ion """
525 acc = ComponentAccumulator()
527 hltCaloCellMakerCfg(flags, "HLTCaloCellMakerFS", roisKey='')
529 # Then build the towers
531 hltHICaloTowerMakerCfg(
533 "HLTHICaloTowerMakerFS",
538 # Then build the clusters
540 hltHICaloClusterMakerCfg(
542 "HLTHICaloClusterMakerFS",
545 clustersKey = "HLT_HICaloClustersFS"
552if __name__ == "__main__":
553 from AthenaConfiguration.TestDefaults import defaultTestFiles, defaultGeometryTags
554 from AthenaConfiguration.AllConfigFlags import initConfigFlags
556 flags = initConfigFlags()
557 flags.Input.Files = defaultTestFiles.RAW_RUN3
558 flags.GeoModel.AtlasVersion = defaultGeometryTags.RUN3
559 flags.IOVDb.GlobalTag = "CONDBR2-ES1PA-2022-07"
560 flags.Common.isOnline = True
561 outputContainers = ["CaloCellContainer#SeedLessFS",
562 "xAOD::EventInfo#EventInfo",
563 "xAOD::TrigEMClusterContainer#CaloClustersGlobal",
564 "xAOD::TrigEMClusterAuxContainer#CaloClustersGlobalAux.",
565 "xAOD::TrigRingerRingsContainer#RingerGlobal",
566 "xAOD::TrigRingerRingsAuxContainer#RingerGlobalAux."]
567 flags.Output.ESDFileName='TrigCaloRecCheck'
572 from AthenaConfiguration.MainServicesConfig import MainServicesCfg
573 cfg = MainServicesCfg(flags)
575 from LArGeoAlgsNV.LArGMConfig import LArGMCfg
576 cfg.merge(LArGMCfg(flags))
577 from TileGeoModel.TileGMConfig import TileGMCfg
578 cfg.merge(TileGMCfg(flags))
580 from DetDescrCnvSvc.DetDescrCnvSvcConfig import DetDescrCnvSvcCfg
581 cfg.merge(DetDescrCnvSvcCfg(flags))
583 from ByteStreamCnvSvc.ByteStreamConfig import ByteStreamReadCfg
584 cfg.merge(ByteStreamReadCfg(flags))
585 cfg.getService("ByteStreamCnvSvc").ROD2ROBmap=["-1"]
587 storeGateSvc = cfg.getService("StoreGateSvc")
588 storeGateSvc.Dump=True
589 theL0CaloGlobalRoIBuilderCfg = L0CaloGlobalRoIBuilderCfg(flags)
590 from OutputStreamAthenaPool.OutputStreamConfig import OutputStreamCfg
592 from AthenaCommon.CFElements import parOR
593 cfg.addSequence(parOR("HLTBeginSeq"),parentName="AthMasterSeq")
595 CAs = [hltCaloCellSeedlessMakerCfg(flags,roisKey=''),
596 theL0CaloGlobalRoIBuilderCfg,
597 hltCaloCellMakerCfg(flags, "SthFS",roisKey=''),
598 OutputStreamCfg(flags,flags.Output.ESDFileName,ItemList=outputContainers)]
599 #hltTopoClusterMakerCfg(flags, "TrigCaloClusterMaker_topoFS")]
602 ca.printConfig(withDetails=True, summariseProps=True)
trigCaloClusterMonitoringTool(flags, doMonCells=False, isFullScan=None)