ATLAS Offline Software
Loading...
Searching...
No Matches
ITkStripOverlayConfig.py
Go to the documentation of this file.
1"""Define methods to construct configured ITk Strip overlay algorithms
2
3Copyright (C) 2002-2026 CERN for the benefit of the ATLAS collaboration
4"""
5
6from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
7from AthenaConfiguration.ComponentFactory import CompFactory
8
9
10def ITkStripOverlayAlgCfg(flags, name="ITkStripOverlay", **kwargs):
11 """Return a ComponentAccumulator for ITk Strip Overlay algorithm"""
12 acc = ComponentAccumulator()
13
14 kwargs.setdefault("BkgInputKey", f"{flags.Overlay.BkgPrefix}ITkStripRDOs")
15 kwargs.setdefault("SignalInputKey", f"{flags.Overlay.SigPrefix}ITkStripRDOs")
16 kwargs.setdefault("OutputKey", "ITkStripRDOs")
17
18 # Input setup
19 from SGComps.SGInputLoaderConfig import SGInputLoaderCfg
20 acc.merge(SGInputLoaderCfg(flags, [f'SCT_RDO_Container#{kwargs["BkgInputKey"]}']))
21
22 # Do SCT overlay
23 acc.addEventAlgo(CompFactory.SCTOverlay(name, **kwargs))
24
25 # Setup output
26 if flags.Output.doWriteRDO:
27 from OutputStreamAthenaPool.OutputStreamConfig import OutputStreamCfg
28 acc.merge(OutputStreamCfg(flags, "RDO", ItemList=[
29 "SCT_RDO_Container#ITkStripRDOs"
30 ]))
31
32 if not flags.Input.isMC:
33 acc.merge(OutputStreamCfg(flags, "RDO", ItemList=[
34 "IDCInDetBSErrContainer#ITkStripByteStreamErrs"
35 ]))
36
37 if flags.Output.doWriteRDO_SGNL:
38 from OutputStreamAthenaPool.OutputStreamConfig import OutputStreamCfg
39 acc.merge(OutputStreamCfg(flags, "RDO_SGNL", ItemList=[
40 f"SCT_RDO_Container#{flags.Overlay.SigPrefix}ITkStripRDOs"
41 ]))
42
43 # for track overlay, write out the signal RDOs because reco tracking will only run on them
44 if flags.Overlay.doTrackOverlay:
45 acc.merge(OutputStreamCfg(flags, "RDO", ItemList=[
46 f"SCT_RDO_Container#{flags.Overlay.SigPrefix}ITkStripRDOs"
47 ]))
48
49 return acc
50
51
52def ITkStripTruthOverlayCfg(flags, name="ITkStripSDOOverlay", **kwargs):
53 """Return a ComponentAccumulator for the ITk Strip SDO overlay algorithm"""
54 acc = ComponentAccumulator()
55
56 # We do not need background SCT SDOs
57 kwargs.setdefault("BkgInputKey", "")
58
59 kwargs.setdefault("SignalInputKey", f"{flags.Overlay.SigPrefix}ITkStripSDO_Map")
60 kwargs.setdefault("OutputKey", "ITkStripSDO_Map")
61
62 # Do SCT truth overlay
63 acc.addEventAlgo(CompFactory.InDetSDOOverlay(name, **kwargs))
64
65 # Setup output
66 if flags.Output.doWriteRDO:
67 from OutputStreamAthenaPool.OutputStreamConfig import OutputStreamCfg
68 acc.merge(OutputStreamCfg(flags, "RDO", ItemList=[
69 "InDetSimDataCollection#ITkStripSDO_Map"
70 ]))
71
72 if flags.Output.doWriteRDO_SGNL:
73 from OutputStreamAthenaPool.OutputStreamConfig import OutputStreamCfg
74 acc.merge(OutputStreamCfg(flags, "RDO_SGNL", ItemList=[
75 f"InDetSimDataCollection#{flags.Overlay.SigPrefix}ITkStripSDO_Map"
76 ]))
77
78 return acc
79
80
82 """Configure and return a ComponentAccumulator for ITk Strip overlay"""
83 acc = ComponentAccumulator()
84
85 # Add ITk Strip overlay digitization algorithm
86 from StripDigitization.StripDigitizationConfig import ITkStripOverlayDigitizationBasicCfg
87 acc.merge(ITkStripOverlayDigitizationBasicCfg(flags))
88
89 # Add ITk Strip overlay algorithm
90 acc.merge(ITkStripOverlayAlgCfg(flags))
91
92 # Add ITk Strip truth overlay
93 if flags.Digitization.EnableTruth:
94 acc.merge(ITkStripTruthOverlayCfg(flags))
95
96 return acc
ITkStripTruthOverlayCfg(flags, name="ITkStripSDOOverlay", **kwargs)
ITkStripOverlayAlgCfg(flags, name="ITkStripOverlay", **kwargs)