ATLAS Offline Software
Loading...
Searching...
No Matches
SCTOverlayConfig.py
Go to the documentation of this file.
1"""Define methods to construct configured SCT 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 SCTOverlayAlgCfg(flags, name="SCTOverlay", **kwargs):
11 """Return a ComponentAccumulator for SCTOverlay algorithm"""
12 acc = ComponentAccumulator()
13
14 kwargs.setdefault("BkgInputKey", f"{flags.Overlay.BkgPrefix}SCT_RDOs")
15 kwargs.setdefault("SignalInputKey", f"{flags.Overlay.SigPrefix}SCT_RDOs")
16 kwargs.setdefault("OutputKey", "SCT_RDOs")
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#SCT_RDOs"
30 ]))
31
32 if not flags.Input.isMC:
33 acc.merge(OutputStreamCfg(flags, "RDO", ItemList=[
34 "IDCInDetBSErrContainer#SCT_ByteStreamErrs"
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}SCT_RDOs"
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}SCT_RDOs"
47 ]))
48
49 return acc
50
51
52def SCTTruthOverlayCfg(flags, name="SCTSDOOverlay", **kwargs):
53 """Return a ComponentAccumulator for the SCT 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}SCT_SDO_Map")
60 kwargs.setdefault("OutputKey", "SCT_SDO_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#SCT_SDO_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}SCT_SDO_Map"
76 ]))
77
78 return acc
79
80
81def SCTOverlayCfg(flags):
82 """Configure and return a ComponentAccumulator for SCT overlay"""
83 acc = ComponentAccumulator()
84
85 # Add SCT overlay digitization algorithm
86 from SCT_Digitization.SCT_DigitizationConfig import SCT_OverlayDigitizationBasicCfg
87 acc.merge(SCT_OverlayDigitizationBasicCfg(flags))
88
89 # Add SCT overlay algorithm
90 acc.merge(SCTOverlayAlgCfg(flags))
91
92 # Add SCT truth overlay
93 if flags.Digitization.EnableTruth:
94 acc.merge(SCTTruthOverlayCfg(flags))
95
96 return acc
SCTTruthOverlayCfg(flags, name="SCTSDOOverlay", **kwargs)
SCTOverlayAlgCfg(flags, name="SCTOverlay", **kwargs)