ATLAS Offline Software
Loading...
Searching...
No Matches
ActsConfigFlags.py
Go to the documentation of this file.
1# Copyright (C) 2002-2026 CERN for the benefit of the ATLAS collaboration
2
3from AthenaConfiguration.AthConfigFlags import AthConfigFlags
4from AthenaConfiguration.Enums import FlagEnum
5
6class SeedingStrategy(FlagEnum):
7 GridTriplet = "GridTriplet"
8 Gbts = "Gbts"
9 GbtsFtf = "GbtsFtf"
10 F150 = "F150"
11
13 Greedy = "GreedySolver"
14 ScoreBased = "ScoreBasedAmbiguitySolver"
15
16# Define the Ambiguity resolution strategy modes
17# OUTSIDE_TF : run the ambiguity resolution in a separate algorithm
18# END_OF_TF : run the ambiguity resolution at the end of the track finding, on the track candidate container
19# DURING_TF : remove the tracks that share too many hits during track finding, when deciding good candidates
20class AmbiguitySolverMode(FlagEnum):
21 OUTSIDE_TF = 0
22 END_OF_TF = 1
23 DURING_TF = 2
24
25# Define the Pixel cluster calibration error strategy modes (the errors that will be used for filtering)
26# CALIBRATED : load the calibration constants from database
27# PITCH : if we used broad clusters during clustering (so the error is the cluster width) rescale it by the number of pixels
28# to assign the pitch as error to the cluster
29class PixelErrorStrategy(FlagEnum):
30 CALIBRATED = 0
31 PITCH = 1
32
33# Define the Strip clustering errors assigned to the measurements during clustering
34# These errors will be used during track finding
35# PITCH : assign the pitch as cluster error
36# WIDTH : use the cluster width as cluster error
37# TUNED : use an error 1.05 x pitch for 1strip clusters, a 0.27 x width for 2strip clusters and width for >=3strip clusters
39 PITCH = 0
40 WIDTH = 1
41 TUNED = 2
42
43# Define the Strip cluster calibration error strategy modes (the errors that will be used for filtering)
44# CLUSTERING : Use directly the clustering errors
45# PITCH : if we used broad clusters during clustering (so the error is the cluster width) rescale it by the number of pixels
46# to assign the pitch as error to the cluster
47class StripErrorStrategy(FlagEnum):
48 CLUSTERING = 0
49 PITCH = 1
50
51class TrackFitterType(FlagEnum):
52 KalmanFitter = 'KalmanFitter' # default ACTS fitter to choose
53 GaussianSumFitter = 'GaussianSumFitter' # new experimental implementation
54 GlobalChiSquareFitter = 'GlobalChiSquareFitter' # new experimental implementation
55
56# Flag for pixel calibration strategy during track finding
57# - use cluster as is (Uncalibrated)
58# - perform AnalogueClustering either before selecting
59# measurements for extending tracks (AnalogueClustering)
60# - or only apply the AnalogueClustering to selected measurements
61# (AnalogueClusteringAfterSelection)
63 Uncalibrated = "Uncalibrated"
64 AnalogueClustering = "AnalogueClustering"
65 AnalogueClusteringAfterSelection = "AnalogueClusteringAfterSelection"
66
67# Flag for strip calibration strategy during track finding
68# - use cluster as is (Uncalibrated)
69# - use strip pitch / sqrt(12) as error either before selecting
70# measurements for extending tracks (DigitalCalibration)
71# - or only apply it to selected measurements (DigitalCalibrationAfterSelection)
73 Uncalibrated = "Uncalibrated"
74 DigitalCalibration = "DigitalCalibration"
75 DigitalCalibrationAfterSelection = "DigitalCalibrationAfterSelection"
76
78 actscf = AthConfigFlags()
79
80 # General Flags
81 actscf.addFlag('Acts.EDM.PersistifyClusters', lambda pcf: pcf.Acts.EDM.PersistifySpacePoints)
82 actscf.addFlag('Acts.EDM.PersistifySpacePoints', False)
83 actscf.addFlag('Acts.EDM.PersistifyTracks', False)
84 actscf.addFlag('Acts.useCache', False)
85
86 # Scheduling
87 from InDetConfig.ITkActsHelpers import primaryPassUsesActs
88 actscf.addFlag('Acts.doITkConversion', lambda pcf: (
89 pcf.Detector.EnableCalo and primaryPassUsesActs(pcf)))
90 actscf.addFlag('Acts.doLargeRadius', False)
91 actscf.addFlag('Acts.doLowPt', False)
92
93 # Geometry Flags
94
95 # MaterialSource can be:
96 # a path to a local JSON file
97 # 'Default' : material map source is evaluated from the geometry tag
98 # 'None' : no material map is provided
99 actscf.addFlag('Acts.TrackingGeometry.MaterialSource', 'Default')
100 actscf.addFlag('Acts.TrackingGeometry.MaterialCalibrationFolder', 'ACTS/MaterialMaps/ITk')
101 actscf.addFlag('Acts.TrackingGeometry.MaterialFileExtension', '')
102 actscf.addFlag('Acts.TrackingGeometry.UseBlueprint', False)
103 actscf.addFlag('Acts.TrackingGeometry.ObjDebugOutput', False)
104
105
106 actscf.addFlag('Acts.TrackingGeometry.InsertITkPassiveMaterialLayers', False)
107 actscf.addFlag('Acts.TrackingGeometry.PassiveITkInnerPixelBarrelLayerRadii', [70.])
108 actscf.addFlag('Acts.TrackingGeometry.PassiveITkInnerPixelBarrelLayerHalflengthZ', [240.])
109 actscf.addFlag('Acts.TrackingGeometry.PassiveITkInnerPixelBarrelLayerThickness', [1.])
110 actscf.addFlag('Acts.TrackingGeometry.PassiveITkOuterPixelBarrelLayerRadii', [195., 260.])
111 actscf.addFlag('Acts.TrackingGeometry.PassiveITkOuterPixelBarrelLayerHalflengthZ', [370., 370.])
112 actscf.addFlag('Acts.TrackingGeometry.PassiveITkOuterPixelBarrelLayerThickness', [1., 1.])
113 actscf.addFlag('Acts.TrackingGeometry.PassiveITkStripBarrelLayerRadii', [480., 665., 880.])
114 actscf.addFlag('Acts.TrackingGeometry.PassiveITkStripBarrelLayerHalflengthZ', [1370., 1370., 1370.])
115 actscf.addFlag('Acts.TrackingGeometry.PassiveITkStripBarrelLayerThickness', [1., 1., 1.])
116
117 # Monitoring
118 actscf.addFlag('Acts.doMonitoring', False)
119 actscf.addFlag('Acts.doAnalysis', False)
120 actscf.addFlag('Acts.doAnalysisNtuples', lambda pcf: pcf.Acts.doAnalysis)
121 actscf.addFlag('Acts.Clusters.doAnalysis', lambda pcf: pcf.Acts.doAnalysis)
122 actscf.addFlag('Acts.SpacePoints.doAnalysis', lambda pcf: pcf.Acts.doAnalysis)
123 actscf.addFlag('Acts.Seeds.doAnalysis', lambda pcf: pcf.Acts.doAnalysis)
124 actscf.addFlag('Acts.Tracks.doAnalysis', lambda pcf: pcf.Acts.doAnalysis)
125 actscf.addFlag('Acts.Particles.doAnalysis', lambda pcf: pcf.Acts.doAnalysis)
126 actscf.addFlag('Acts.storeTrackStateInfo', False)
127 actscf.addFlag('Acts.doTruthInspection', False)
128
129 # Cluster
130 actscf.addFlag("Acts.Clusters.UseWeightedPosition", False)
131 actscf.addFlag("Acts.Clusters.RetrieveChargeInformation", lambda pcf: not pcf.Tracking.doPixelDigitalClustering)
132 actscf.addFlag("Acts.Clusters.StripClusteringErrorMode", StripClusteringErrorMode.PITCH,type=StripClusteringErrorMode)
133 actscf.addFlag("Acts.Clusters.UsePixelBroadErrors", False)
134
135 # SpacePoint
136 actscf.addFlag('Acts.SpacePoints.useBeamSpotConstraintStrips', True)
137
138 # Seeding
139 actscf.addFlag("Acts.SeedingStrategy", SeedingStrategy.GridTriplet, type=SeedingStrategy) # Define Seeding Strategy
140
141 # Track finding
142 actscf.addFlag('Acts.PixelCalibrationStrategy', PixelCalibrationStrategy.Uncalibrated, type=PixelCalibrationStrategy)
143 actscf.addFlag('Acts.StripCalibrationStrategy', StripCalibrationStrategy.Uncalibrated, type=StripCalibrationStrategy)
144 actscf.addFlag('Acts.doRotCorrection', True)
145 actscf.addFlag('Acts.doPrintTrackStates', False)
146 actscf.addFlag('Acts.skipDuplicateSeeds', True)
147 actscf.addFlag('Acts.doTwoWayCKF', True) # run CKF twice, first with forward propagation with smoothing, then with backward propagation
148 actscf.addFlag('Acts.useStripSeedsFirst', False) # switch order of seed collections
149 actscf.addFlag('Acts.useHGTDClusterInTrackFinding', False) # use HGTD cluster in track finding
150 actscf.addFlag('Acts.branchStopperMeasCutReduce', 2)
151 actscf.addFlag('Acts.branchStopperAbsEtaMeasCut', 1.2)
152 actscf.addFlag('Acts.forceTrackOnSeed', lambda pcf: not(pcf.Acts.SeedingStrategy is SeedingStrategy.GbtsFtf and
153 pcf.Acts.PixelCalibrationStrategy is PixelCalibrationStrategy.AnalogueClusteringAfterSelection)) # forceTrackOnSeed does not seem to work with GBTS seeds and analogue cluster calibration
154
155 # Ambiguity resolution
156 actscf.addFlag('Acts.doAmbiguityResolution', True)
157 actscf.addFlag('Acts.AmbiguitySolverStrategy', AmbiguitySolverStrategy.Greedy, type=AmbiguitySolverStrategy) # Define Ambiguity Solver Strategy
158 actscf.addFlag('Acts.AmbiguitySolverMode', lambda pcf: AmbiguitySolverMode.OUTSIDE_TF if pcf.Acts.doAmbiguityResolution else AmbiguitySolverMode.DURING_TF, type=AmbiguitySolverMode)
159
160 # Calibrations
161 actscf.addFlag('Acts.OnTrackCalibration.performCovarianceCalibration', True) # perform calibration of covariance during on track analogue cluster calibration
162
163 # Track fitting
164 actscf.addFlag('Acts.writeTrackCollection', False) # save to file (ESD, AOD) the Resolved and Refitted track collections
165 actscf.addFlag('Acts.fitFromPRD', False) # Acts.writeTrackCollection needs to be True for either cases. If Acts.fitFromPRD is False, fit from ROT; else, fit from PRD
166 actscf.addFlag('Acts.trackFitterType', TrackFitterType.KalmanFitter, type=TrackFitterType) # Define Tracking algorithm for refitting
167
168 # GSF specific flags
169 actscf.addFlag("Acts.GsfRefitLegacyTrk", False) # Refit Legacy tracks using ACTS GSF
170 actscf.addFlag("Acts.GsfRefitActs", False) # Refit ACTS tracks using ACTS GSF
171 actscf.addFlag("Acts.GsfMaxComponents", 12)
172 actscf.addFlag("Acts.GsfComponentMergeMethod", 'MaxWeight')
173 actscf.addFlag("Acts.GsfDirectNavigation", False)
174 actscf.addFlag("Acts.GsfOutlierChi2Cut", 1e4) # Effectively no cut. Compatible with legacy
175
176 # Decorations
177 actscf.addFlag('Acts.decoratePRD.sdoSiHit', lambda pcf: pcf.Tracking.doTIDE_AmbiTrackMonitoring)
178
179 return actscf