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" if not flags.Overlay.IgnoreBkgInputs else "")
15 kwargs.setdefault("SignalInputKey", f"{flags.Overlay.SigPrefix}SCT_RDOs")
16 kwargs.setdefault("OutputKey", "SCT_RDOs")
17
18
19 if kwargs["BkgInputKey"]:
20 from SGComps.SGInputLoaderConfig import SGInputLoaderCfg
21 acc.merge(SGInputLoaderCfg(flags, [f'SCT_RDO_Container#{kwargs["BkgInputKey"]}']))
22
23
24 acc.addEventAlgo(CompFactory.SCTOverlay(name, **kwargs))
25
26
27 if flags.Output.doWriteRDO:
28 from OutputStreamAthenaPool.OutputStreamConfig import OutputStreamCfg
29 acc.merge(OutputStreamCfg(flags, "RDO", ItemList=[
30 "SCT_RDO_Container#SCT_RDOs"
31 ]))
32
33 if not flags.Input.isMC:
34 acc.merge(OutputStreamCfg(flags, "RDO", ItemList=[
35 "IDCInDetBSErrContainer#SCT_ByteStreamErrs"
36 ]))
37
38 if flags.Output.doWriteRDO_SGNL:
39 from OutputStreamAthenaPool.OutputStreamConfig import OutputStreamCfg
40 acc.merge(OutputStreamCfg(flags, "RDO_SGNL", ItemList=[
41 f"SCT_RDO_Container#{flags.Overlay.SigPrefix}SCT_RDOs"
42 ]))
43
44
45 if flags.Overlay.doTrackOverlay:
46 acc.merge(OutputStreamCfg(flags, "RDO", ItemList=[
47 f"SCT_RDO_Container#{flags.Overlay.SigPrefix}SCT_RDOs"
48 ]))
49
50 return acc
51
52