6 TrackContainers: list[str],
7 TrackParticleContainer: str,
8 persistifyCollection: bool =
True,
9 PerigeeExpression: str =
None) -> ComponentAccumulator:
19 assert isinstance(TrackContainers, list)
20 for container
in TrackContainers:
21 assert isinstance(container, str)
25 if PerigeeExpression
is None:
26 PerigeeExpression = flags.Tracking.perigeeExpression
28 print(
"Storing track and track particle containers:")
29 print(f
"- track collection(s): {TrackContainers}")
30 print(f
"- track particle collection: {TrackParticleContainer}")
32 acc = ComponentAccumulator()
34 prefix =
"ActsCombined" if not flags.hasCategory(
"Tracking.ActiveConfig")
else flags.Tracking.ActiveConfig.extension
35 prefix += f
"To{TrackParticleContainer}"
36 from ActsConfig.ActsTrackFindingConfig
import ActsTrackToTrackParticleCnvAlgCfg
37 acc.merge(ActsTrackToTrackParticleCnvAlgCfg(flags,
38 name = f
"{prefix}TrackToTrackParticleCnvAlg",
39 ACTSTracksLocation = TrackContainers,
40 TrackParticlesOutKey = TrackParticleContainer,
41 PerigeeExpression = PerigeeExpression))
43 if flags.Tracking.doTruth :
45 track_to_truth_maps = []
46 from ActsConfig.ActsTruthConfig
import ActsTrackParticleTruthDecorationAlgCfg
47 for trackContainer
in TrackContainers:
48 track_to_truth_maps.append(f
"{trackContainer}ToTruthParticleAssociation")
49 acc.merge(ActsTrackParticleTruthDecorationAlgCfg(flags,
50 name = f
'{prefix}TruthDecorationAlg',
51 TrackToTruthAssociationMaps = track_to_truth_maps,
52 TrackParticleContainerName = TrackParticleContainer,
53 OutputLevel = WARNING
if len(TrackContainers)==1
else INFO,
54 ComputeTrackRecoEfficiency =
False if len(TrackContainers)==1
else True))
57 if flags.Acts.storeTrackStateInfo:
58 from ActsConfig.ActsObjectDecorationConfig
import ActsMeasurementToTrackParticleDecorationAlgCfg
59 acc.merge(ActsMeasurementToTrackParticleDecorationAlgCfg(flags,
60 name = f
"ActsMeasurementTo{TrackParticleContainer}DecorationAlg",
61 TrackParticleKey = TrackParticleContainer))
63 if flags.Acts.Particles.doAnalysis:
64 from ActsConfig.ActsAnalysisConfig
import ActsResidualAnalysisAlgCfg
65 acc.merge(ActsResidualAnalysisAlgCfg(flags,
66 name = f
"Acts{TrackParticleContainer}ResidualAnalysisAlg",
67 TrackParticles = TrackParticleContainer))
73 if persistifyCollection:
75 trackparticles_shortlist = []
if flags.Acts.EDM.PersistifyTracks
else [
'-actsTrack']
76 trackparticles_variables =
".".join(trackparticles_shortlist)
77 toAOD += [f
"xAOD::TrackParticleContainer#{TrackParticleContainer}",
78 f
"xAOD::TrackParticleAuxContainer#{TrackParticleContainer}Aux." + trackparticles_variables]
80 from OutputStreamAthenaPool.OutputStreamConfig
import addToAOD
81 acc.merge(addToAOD(flags, toAOD))
87 acc = ComponentAccumulator()
90 if flags.Tracking.ActiveConfig.storeSiSPSeededTracks:
92 TrackParticleContainer = f
'SiSPSeededTracks{flags.Tracking.ActiveConfig.extension}TrackParticles'
94 TrackContainers = [f
"{flags.Tracking.ActiveConfig.extension}Tracks"],
95 TrackParticleContainer = TrackParticleContainer))
100 if flags.Tracking.ActiveConfig.storeSeparateContainer:
104 acts_tracks = f
"{flags.Tracking.ActiveConfig.extension}Tracks" if not flags.Acts.doAmbiguityResolution
else f
"{flags.Tracking.ActiveConfig.extension}ResolvedTracks"
105 TrackParticles = f
'InDet{flags.Tracking.ActiveConfig.extension}TrackParticles'
107 TrackContainers = [acts_tracks],
108 TrackParticleContainer = TrackParticles))
ComponentAccumulator ITkActsTrackParticleCreationCfg(flags, *, list[str] TrackContainers, str TrackParticleContainer, bool persistifyCollection=True, str PerigeeExpression=None)
ComponentAccumulator ITkActsTrackParticlePersistificationCfg(flags)