10def HGTD_OverlayAlgCfg(flags, name="HGTD_Overlay", **kwargs):
11 """Return a ComponentAccumulator for HGTD overlay algorithm"""
12 acc = ComponentAccumulator()
13
14 kwargs.setdefault("BkgInputKey", f"{flags.Overlay.BkgPrefix}HGTD_RDOs" if not flags.Overlay.IgnoreBkgInputs else "")
15 kwargs.setdefault("SignalInputKey", f"{flags.Overlay.SigPrefix}HGTD_RDOs")
16 kwargs.setdefault("OutputKey", "HGTD_RDOs")
17
18
19 if kwargs["BkgInputKey"]:
20 from SGComps.SGInputLoaderConfig import SGInputLoaderCfg
21 acc.merge(SGInputLoaderCfg(flags, [f'HGTD_RDO_Container#{kwargs["BkgInputKey"]}']))
22
23
24 acc.addEventAlgo(CompFactory.HGTD_Overlay(name, **kwargs))
25
26
27 if flags.Output.doWriteRDO:
28 from OutputStreamAthenaPool.OutputStreamConfig import OutputStreamCfg
29 acc.merge(OutputStreamCfg(flags, "RDO", ItemList=[
30 "HGTD_RDO_Container#HGTD_RDOs"
31 ]))
32
33 if flags.Output.doWriteRDO_SGNL:
34 from OutputStreamAthenaPool.OutputStreamConfig import OutputStreamCfg
35 acc.merge(OutputStreamCfg(flags, "RDO_SGNL", ItemList=[
36 f"HGTD_RDO_Container#{flags.Overlay.SigPrefix}HGTD_RDOs"
37 ]))
38
39 return acc
40
41