4 if not flags.hasCategory(
"Tracking.ActiveConfig"):
8 if flags.Tracking.ActiveConfig.extension
in [
"",
"HeavyIon"]:
11 return f
"ITk{flags.Tracking.ActiveConfig.extension}" == flags.Tracking.ITkPrimaryPassConfig.value
14 if flags.hasCategory(
"Tracking.ActiveConfig")
and flags.Tracking.ActiveConfig.extension
in [
"ActsValidateF100",
"ActsValidateF150"]
and flags.Tracking.doITkFastTracking:
16 return flags.Tracking.doITkFastTracking
and isPrimaryPass(flags)
19 return "Validate" in flags.Tracking.ActiveConfig.extension
25 from TrkConfig.TrkConfigFlags
import ITkPrimaryPassConfig
26 return flags.Tracking.ITkPrimaryPassConfig
in [ITkPrimaryPassConfig.Acts, \
27 ITkPrimaryPassConfig.ActsLegacy, \
28 ITkPrimaryPassConfig.ActsHeavyIon]
33 return flags.Tracking.ITkPrimaryPassConfig.value.replace(
"ITk",
"")
41 if len(flags.Tracking.recoChain) != 1:
42 raise ValueError(f
"Conflicting reco configuration: Tracking.recoChain should have only one element but we found {flags.Tracking.recoChain}")
45 from TrkConfig.TrkConfigFlags
import ITkPrimaryPassConfig
46 if flags.Tracking.ITkPrimaryPassConfig
is ITkPrimaryPassConfig.Acts:
47 if not flags.Tracking.doITkFastTracking:
48 raise ValueError(f
"Main pass is set to Acts Fast Tracking but Tracking.doITkFastTracking is set to {flags.Tracking.doITkFastTracking}")
50 if flags.Tracking.doITkFastTracking:
51 raise ValueError(f
"Main pass is NOT set to Fast Tracking but Tracking.doITkFastTracking is set to {flags.Tracking.doITkFastTracking}")
54 if flags.Acts.doAmbiguityResolution:
55 from ActsConfig.ActsConfigFlags
import AmbiguitySolverMode
58 if flags.Acts.AmbiguitySolverMode
is not AmbiguitySolverMode.OUTSIDE_TF:
59 raise ValueError(f
"Conflicting reco configuration: Acts.doAmbiguityResolution has been requested and this will schedule the ACTS ambiguity solver algorithm, yet the ambiguity mode (set to {flags.Acts.AmbiguitySolverMode}) is not compatible with this.")
63 trackingPasses += [flags.cloneAndReplace(
64 "Tracking.ActiveConfig",
65 f
"Tracking.{flags.Tracking.ITkPrimaryPassConfig.value}Pass")]
68 if flags.Acts.doITkConversion:
70 if not flags.Detector.EnableCalo:
71 raise ValueError(
"Problem in the job configuration: required reconstruction of photon conversion tracks but Calorimeter Detector is not enabled")
72 trackingPasses += [flags.cloneAndReplace(
73 "Tracking.ActiveConfig",
74 "Tracking.ITkActsConversionPass")]
77 if flags.Acts.doLargeRadius:
78 trackingPasses += [flags.cloneAndReplace(
79 "Tracking.ActiveConfig",
80 "Tracking.ITkActsLargeRadiusPass")]
84 if flags.Acts.doLowPt:
85 trackingPasses += [flags.cloneAndReplace(
86 "Tracking.ActiveConfig",
87 "Tracking.ITkActsLowPtPass")]
89 print(
"List of scheduled passes:")
90 for trackingPass
in trackingPasses:
91 print(f
'- {trackingPass.Tracking.ActiveConfig.extension}')
95 for current_flags
in trackingPasses:
98 if nPrimaryPasses != 1:
99 raise ValueError(f
"Problem in the job configuration: exactly one primary pass is required for a proper configuration, but we found {nPrimaryPasses} instead!")
101 return trackingPasses
104 generateTrackCollections = [
"InDetTrackParticles"]
108 for currentFlags
in scheduledTrackingPasses:
110 if currentFlags.Tracking.ActiveConfig.storeTrackSeeds:
112 generatePixelSegments = currentFlags.Detector.EnableITkPixel
113 generateStripSegments = currentFlags.Detector.EnableITkStrip
116 if currentFlags.Tracking.ActiveConfig.extension
in [
"ActsConversion",
"ActsLargeRadius"]:
117 generatePixelSegments =
False
120 generateStripSegments =
False
122 if generatePixelSegments:
123 generateTrackCollections += [f
'SiSPSeedSegments{currentFlags.Tracking.ActiveConfig.extension}PixelTrackParticles']
124 if generateStripSegments:
125 generateTrackCollections += [f
'SiSPSeedSegments{currentFlags.Tracking.ActiveConfig.extension}StripTrackParticles']
126 if generatePixelSegments
and generateStripSegments:
127 generateTrackCollections += [f
'SiSPSeedSegments{currentFlags.Tracking.ActiveConfig.extension}TrackParticles']
130 if currentFlags.Tracking.ActiveConfig.storeSiSPSeededTracks:
131 generateTrackCollections += [f
'SiSPSeededTracks{currentFlags.Tracking.ActiveConfig.extension}TrackParticles']
136 if currentFlags.Acts.doAmbiguityResolution
and currentFlags.Tracking.ActiveConfig.storeSeparateContainer:
137 generateTrackCollections += [f
'InDet{currentFlags.Tracking.ActiveConfig.extension}TrackParticles']
139 print(
'Here is the list of generated track particle collections:')
140 for collection
in generateTrackCollections:
141 print(f
'- {collection}')
143 return generateTrackCollections