ATLAS Offline Software
Loading...
Searching...
No Matches
MuonConfigFlags.py
Go to the documentation of this file.
1# Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
2
3from AthenaConfiguration.AthConfigFlags import AthConfigFlags
4from AthenaConfiguration.Enums import BeamType, LHCPeriod, ProductionStep, Project, FlagEnum
5
6import re
7
8# Some comments from Ed about existing flags
9# MuonCnvExample
10# - MuonCnvFlags - not sure we need this - it really only configures single properties of the various cablings - we can just do this directly.
11# - MuonCalibFlags - looks like we need this
12
13class GeoTrfCacheMode(FlagEnum):
14
16 SlopyCache = 1
17
21 ActsSlopyALineCond = 2
22
24 SplitCache = 3
25
28 ActsSplitALineCond = 4
29
30 FullCacheCond = 5
31
32class MMClusterBuilderEnum(FlagEnum):
33 """Flag values for Muon.MMClusterCalibRecoTool"""
34 Centroid = "Centroid"
35 ClusterTimeProjection = "ClusterTimeProjection"
36
37def _muonAlignMode(flags):
38 # Small function that determines if the alignment flags should be true or false
39 # follows the logic in https://acode-browser1.usatlas.bnl.gov/lxr/source/athena/MuonSpectrometer/MuonReconstruction/MuonRecExample/python/MuonAlignFlags.py
40 problematic_tags = ['COMCOND-HLT[A-C]-00[01]-00', 'COMCOND-ES1C-00[01]-00', 'COMCOND-REPC-001', 'COMCOND-SIM-01-00']
41 if any(re.match(tag,flags.IOVDb.DatabaseInstance) for tag in problematic_tags):
42 return False
43 elif flags.Input.isMC or not flags.Muon.enableAlignment:
44 return False
45 else:
46 return True
47
49 mcf=AthConfigFlags()
50
51 # stages of processing
52 # 0. Geometry
53
54
55 from AthenaConfiguration.AutoConfigFlags import DetDescrInfo
56
57 mcf.addFlag("Muon.usePhaseIIGeoSetup",lambda prevFlags : prevFlags.Detector.GeometryMuon and
58 DetDescrInfo(prevFlags.GeoModel.AtlasVersion,
59 prevFlags.GeoModel.SQLiteDB ,
60 prevFlags.GeoModel.SQLiteDBFullPath)["Muon"]["useR4Plugin"] )
61
62 mcf.addFlag("Muon.AlignedGeoTrfCacheMode", GeoTrfCacheMode.FullCacheCond)
63 # 1. Digitization
64 mcf.addFlag("Muon.doFastMMDigitization", False)
65 mcf.addFlag("Muon.doFastsTGCDigitization",False)
66
67
68 # 2. Reco MuonRecFlags
69
70
72 try:
73
74 from TrkConfig.TrkConfigFlags import TrackingComponent
75 mcf.addFlag("Muon.scheduleActsReco", lambda prevFlags: prevFlags.Muon.usePhaseIIGeoSetup and \
76 prevFlags.Tracking.recoChain[0] in [TrackingComponent.ActsChain , TrackingComponent.ActsLegacyChain ])
77 except ImportError:
78 mcf.addFlag("Muon.scheduleActsReco", False)
79
80
81 mcf.addFlag("Muon.enableMLBucketFilter", False)
82
83 mcf.addFlag("Muon.doMSVertex", True) # Run MS vertex (arXiv:1311.7070)
84 mcf.addFlag("Muon.doSegmentT0Fit",lambda prevFlags : prevFlags.Beam.Type is not BeamType.Collisions) # Fit MDT segments using a variable t0. Used for cosmics and single beam to compensate for large errors on the trigger time.
85 mcf.addFlag("Muon.enableErrorTuning",True) # turn on error tuning to account for misalignments
86 mcf.addFlag("Muon.useLooseErrorTuning",False)
87 mcf.addFlag("Muon.useTGCPriorNextBC",False) # Use TGC measurements from Prior and Next Bunch Crossings. These measurements are available in the real data since somewhere in 2008.
88 mcf.addFlag("Muon.useAlignmentCorrections",True) # Apply alignment corrections to MuonGeoModel. The corrections are read from a COOL database
89
90 mcf.addFlag("Muon.makePRDs",True) # Disable when e.g. re-running from ESD
91
92 mcf.addFlag("Muon.enableNRPC", lambda prevFlags: prevFlags.Detector.GeometryRPC and \
93 prevFlags.Muon.usePhaseIIGeoSetup )
94 # MuonStandaloneFlags.py
95 mcf.addFlag("Muon.printSummary", False) # Print out a summary for each event at each reco stage
96 mcf.addFlag("Muon.segmentOrigin", "Muon") # Can be 'Muon','TruthTracking'
97 # reconstructionMode - I think this is a complete duplication of global.BeamType. Dropping.
98 mcf.addFlag("Muon.strategy", []) # CutSeedsOnTracks, CombineSegInStation, DynamicSeeding, PreferOutsideIn, AllowOneSharedHit, DoRefinement, DoAmbiSolving
99 mcf.addFlag("Muon.straightLineFitMomentum", 2000.0 )
100 #mcf.addFlag("Muon.doSegmentsOnly", True) # Also in MuonRecFlags ... redundant in both?
101 mcf.addFlag("Muon.Chi2NDofCut", 20.0 ) # chi-squared per degree of freedom cut in fitter.
102 mcf.addFlag("Muon.enableCurvedSegmentFinding", False ) # TODO I think this one could possibly be removed, since it really is a Tool level configuration.
103 mcf.addFlag("Muon.updateSegmentSecondCoordinate", lambda prevFlags : prevFlags.Beam.Type is BeamType.Collisions) # Do not use for cosmics or singlebeam
104
105 mcf.addFlag("Muon.useSegmentMatching", lambda prevFlags : prevFlags.Beam.Type is BeamType.Collisions) # Do not use for cosmics or singlebeam
106 mcf.addFlag("Muon.useTrackSegmentMatching", True )
107 mcf.addFlag("Muon.runCommissioningChain", lambda prevFlags: ( False and (prevFlags.Detector.EnableMM or prevFlags.Detector.EnablesTGC) \
108 and prevFlags.Beam.Type is BeamType.Collisions) )
109
110 mcf.addFlag("Muon.applyMMPassivation", lambda prevFlags: prevFlags.Detector.EnableMM and not prevFlags.Common.isOnline and (prevFlags.Common.Project is not Project.AthSimulation \
111 and (prevFlags.Common.ProductionStep not in [ProductionStep.Simulation, ProductionStep.FastChain] or prevFlags.Overlay.DataOverlay)))
112 # CalibFlags
113 mcf.addFlag("Muon.Calib.readMdtJSON", lambda prevFlags: prevFlags.GeoModel.Run > LHCPeriod.Run3 and prevFlags.Muon.usePhaseIIGeoSetup) # Toggle whether the calibration constants are read from the JSON format. Enabled by default for a Run4 geometry read by the muon phase II geometry setup
114 mcf.addFlag("Muon.Calib.fitAnalyticRt", False) #Toggle whether the look-up R-t tables shall undergo an intermediate polynomial fit
115
116 mcf.addFlag("Muon.Calib.readMDTCalibFromBlob", True) # Read mdt tube calibration from blob-folders
117 mcf.addFlag("Muon.Calib.correctMdtRtForBField", lambda prevFlags : (prevFlags.Input.isMC is False and prevFlags.Beam.Type is BeamType.Collisions)) # Apply B-field correction to drift times only for collision data (as done in https://acode-browser1.usatlas.bnl.gov/lxr/source/athena/MuonSpectrometer/MuonCnv/MuonCnvExample/python/MuonCalibFlags.py#0028)
118 mcf.addFlag("Muon.Calib.correctMdtRtForTimeSlewing", lambda prevFlags : prevFlags.Input.isMC is False) # Apply time slewing correction to drift time only for data (as done in https://acode-browser1.usatlas.bnl.gov/lxr/source/athena/MuonSpectrometer/MuonCnv/MuonCnvExample/python/MuonCalibFlags.py#0028)
119
120 mcf.addFlag("Muon.Calib.applySigPropUncert", lambda prevFlags: prevFlags.Muon.usePhaseIIGeoSetup )
121 mcf.addFlag("Muon.Calib.useMLRt", True) # use ML-RT functions from COOL
122 mcf.addFlag("Muon.Calib.applyRtScaling", False) # TODO - apparently not needed, but currently used in MuonCalibConfig. Set false to match https://acode-browser1.usatlas.bnl.gov/lxr/source/athena/MuonSpectrometer/MuonCnv/MuonCnvExample/python/MuonCalibFlags.py#0072
123 mcf.addFlag("Muon.Calib.mdtCalibrationSource", "MDT") # Source for MDT t0s and rts
124 mcf.addFlag("Muon.Calib.mdtPropagationSpeedBeta", lambda prevFlags : 1.0 if prevFlags.Input.isMC else 0.85) #
125
126 mcf.addFlag("Muon.Calib.CscPedFromLocalFile", False)
127 mcf.addFlag("Muon.Calib.CscNoiseFromLocalFile", False)
128 mcf.addFlag("Muon.Calib.CscPSlopeFromLocalFile", False)
129 mcf.addFlag("Muon.Calib.CscStatusFromLocalFile", False)
130 mcf.addFlag("Muon.Calib.CscRmsFromLocalFile", False)
131 mcf.addFlag("Muon.Calib.CscF001FromLocalFile", False)
132 mcf.addFlag("Muon.Calib.CscT0BaseFromLocalFile", False)
133 mcf.addFlag("Muon.Calib.CscT0PhaseFromLocalFile", False)
134
135 mcf.addFlag("Muon.Calib.EventTag", "MoMu")
136
137 # Choose the (MDT) calibration mode.
138 # 'ntuple' : write standard calibration ntuple (up to segments)
139 # 'trackNtuple' : write standard ntuple + tracks
140 # 'regionNtuple' : write one ntuple per calibration region
141 # 't0Classic' : do classic t0 calibration
142 # 't0MT' : do MT t0 calibration
143 # 'rtClassic' : do classic rt calibration
144 # 'rtAnalytic' : do analytic rt calibration
145 mcf.addFlag("Muon.Calib.mdtMode", "ntuple")
146
147
148 # for now the T0 calibration in the NSW should be disabled by default until a final calibration is available. Introducing the flags anyhow to allow for studies of the calibration
149 # do not apply NSW T0 calibration if we are running online or MC or a RUN4 geometry, keep only for 23 or 24
150 mcf.addFlag("Muon.Calib.applyMmT0Correction", lambda prevFlags: prevFlags.GeoModel.Run==LHCPeriod.Run3 and prevFlags.Input.DataYear != 2022 and not prevFlags.Common.isOnline and not prevFlags.Input.isMC )
151 mcf.addFlag("Muon.Calib.applysTgcT0Correction", lambda prevFlags: prevFlags.GeoModel.Run<LHCPeriod.Run4 and not prevFlags.Common.isOnline and not prevFlags.Input.isMC and False)
152 mcf.addFlag("Muon.Calib.applyMmBFieldCalib", True)
153
154 # Muon Align flags
155
156 mcf.addFlag("Muon.Align.UseALines", lambda prevFlags: (_muonAlignMode(prevFlags)))
157 mcf.addFlag("Muon.Align.UseBLines", lambda prevFlags: prevFlags.Muon.Align.UseALines)
158 mcf.addFlag("Muon.Align.UseILines", lambda prevFlags: (_muonAlignMode(prevFlags)) and \
159 prevFlags.Detector.GeometryCSC and 'HLT' not in prevFlags.IOVDb.GlobalTag)
160 mcf.addFlag("Muon.Align.UseAsBuilt", lambda prevFlags: (_muonAlignMode(prevFlags)) and not \
161 (prevFlags.IOVDb.DatabaseInstance == 'COMP200' or \
162 'HLT' in prevFlags.IOVDb.GlobalTag or prevFlags.Common.isOnline) )
163 mcf.addFlag("Muon.Align.UsesTGCAsBuild", lambda prevFlags: (_muonAlignMode(prevFlags)) and not prevFlags.Common.isOnline and prevFlags.GeoModel.Run == LHCPeriod.Run3)
164
165 # Muon Trigger Flags
166 mcf.addFlag("Muon.MuonTrigger", False)
167 mcf.addFlag("Muon.SAMuonTrigger", False)
168 mcf.addFlag("Muon.disableNSWForL2SA", True)
169
170 mcf.addFlag("Muon.enableAlignment",lambda flags: (flags.Common.Project is not Project.AthSimulation \
171 and not (flags.Common.ProductionStep in [ProductionStep.Simulation, ProductionStep.FastChain] or flags.Overlay.DataOverlay)))
172 mcf.addFlag("Muon.enableTrigIDtrackReuse", False)
173 # configuration of the DESDM_MCP output format
174
175 mcf.addFlag("Muon.DESDM_MCP.doAlignmentFormat", False) # Flag to stear the DESDM_MCP format which switches to a looser event selection for toroid off runs used for alignment.
176 mcf.addFlag("Muon.DESDM_MCP.doExtendedAlignmentContent", False) # Flag to enable electron, photon and jet containers in DESDM_MCP for dedicate studies of the toroid off data.
177
178 # configuration to write out RPC RDO for trigger timing calibration
179 mcf.addFlag("Muon.doWriteRpcRDO", True)
180
181 mcf.addFlag("Muon.writeSDOs", lambda prevFlags : prevFlags.Output.doWriteESD and prevFlags.Input.isMC)
182
183 # configure the MM cluster reco method that is used in the cluster calibration step
184 #Use charge weighted only for trigger and 2022 where not sure if the t0 calibrations that we have are ok dor the commissioning phase of the NSW in 2022
185 mcf.addFlag("Muon.MMClusterCalibRecoTool", lambda prevFlags: MMClusterBuilderEnum.Centroid if (prevFlags.Common.isOnline or prevFlags.Input.DataYear == 2022 or prevFlags.Beam.Type is not BeamType.Collisions) else MMClusterBuilderEnum.ClusterTimeProjection, type=MMClusterBuilderEnum)
186
187 mcf.addFlag("Muon.writexAODPRD", lambda prevFlags: prevFlags.Muon.usePhaseIIGeoSetup) # Output new xAOD format from convertors (to be removed once the old format is deprecated)
188 # use the MDT DCS data to determine if a chamber is alive or not. This is used in the hole search and the region selector. Needs to be false if the job is running online or is the reconstruction of the MDT calib stream
189 mcf.addFlag("Muon.useMdtDcsData", lambda prevFlags : not prevFlags.Common.isOnline and prevFlags.Detector.GeometryMDT)
190
191
192 # TODO - add configuration for above
193
194 return mcf
195