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}")
34 prefix =
"ActsCombined" if "ActiveConfig" not in flags.Tracking
else flags.Tracking.ActiveConfig.extension
35 prefix += f
"To{TrackParticleContainer}"
36 from ActsConfig.ActsTrackFindingConfig
import ActsTrackToTrackParticleCnvAlgCfg
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")
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
60 name = f
"ActsMeasurementTo{TrackParticleContainer}DecorationAlg",
61 TrackParticleKey = TrackParticleContainer))
63 if flags.Acts.Particles.doAnalysis:
64 from ActsConfig.ActsAnalysisConfig
import ActsResidualAnalysisAlgCfg
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