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