ATLAS Offline Software
Loading...
Searching...
No Matches
MuonConfigFlags Namespace Reference

Classes

class  GeoTrfCacheMode
class  MMClusterBuilderEnum

Functions

 _muonAlignMode (flags)
 createMuonConfigFlags ()

Function Documentation

◆ _muonAlignMode()

MuonConfigFlags._muonAlignMode ( flags)
protected

Definition at line 37 of file MuonConfigFlags.py.

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

◆ createMuonConfigFlags()

MuonConfigFlags.createMuonConfigFlags ( )

Definition at line 48 of file MuonConfigFlags.py.

48def createMuonConfigFlags():
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, type = GeoTrfCacheMode)
63
64
66 mcf.addFlag("Muon.trackGeometryActiveMaterial", True)
67
69 mcf.addFlag("Muon.trackGeometryPassiveMaterial", True)
70 # 1. Digitization
71 mcf.addFlag("Muon.doFastMMDigitization", False)
72 mcf.addFlag("Muon.doFastsTGCDigitization",True)
73
74
75 mcf.addFlag("Muon.setupTruthAlgorithms", lambda prevFlags: prevFlags.Muon.usePhaseIIGeoSetup and \
76 prevFlags.Input.isMC and \
77 not prevFlags.Trigger.doHLT)
78 # 2. Reco MuonRecFlags
79
80
82 try:
83
84 from TrkConfig.TrkConfigFlags import TrackingComponent
85 mcf.addFlag("Muon.scheduleActsReco", lambda prevFlags: prevFlags.Muon.usePhaseIIGeoSetup and \
86 prevFlags.Tracking.recoChain[0] in [TrackingComponent.ActsChain , TrackingComponent.ActsLegacyChain ])
87 except ImportError:
88 mcf.addFlag("Muon.scheduleActsReco", False)
89
90
91 mcf.addFlag("Muon.enableMLBucketFilter", False)
92
93 mcf.addFlag("Muon.doMSVertex", True) # Run MS vertex (arXiv:1311.7070)
94 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.
95 mcf.addFlag("Muon.enableErrorTuning",True) # turn on error tuning to account for misalignments
96 mcf.addFlag("Muon.useLooseErrorTuning",False)
97 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.
98 mcf.addFlag("Muon.useAlignmentCorrections",True) # Apply alignment corrections to MuonGeoModel. The corrections are read from a COOL database
99
100 mcf.addFlag("Muon.makePRDs",True) # Disable when e.g. re-running from ESD
101
102 mcf.addFlag("Muon.enableNRPC", lambda prevFlags: prevFlags.Detector.GeometryRPC and \
103 prevFlags.Muon.usePhaseIIGeoSetup )
104 # MuonStandaloneFlags.py
105 mcf.addFlag("Muon.printSummary", False) # Print out a summary for each event at each reco stage
106 mcf.addFlag("Muon.segmentOrigin", "Muon") # Can be 'Muon','TruthTracking'
107 # reconstructionMode - I think this is a complete duplication of global.BeamType. Dropping.
108 mcf.addFlag("Muon.strategy", []) # CutSeedsOnTracks, CombineSegInStation, DynamicSeeding, PreferOutsideIn, AllowOneSharedHit, DoRefinement, DoAmbiSolving
109 mcf.addFlag("Muon.straightLineFitMomentum", 2000.0 )
110 #mcf.addFlag("Muon.doSegmentsOnly", True) # Also in MuonRecFlags ... redundant in both?
111 mcf.addFlag("Muon.Chi2NDofCut", 20.0 ) # chi-squared per degree of freedom cut in fitter.
112 mcf.addFlag("Muon.enableCurvedSegmentFinding", False ) # TODO I think this one could possibly be removed, since it really is a Tool level configuration.
113 mcf.addFlag("Muon.updateSegmentSecondCoordinate", lambda prevFlags : prevFlags.Beam.Type is BeamType.Collisions) # Do not use for cosmics or singlebeam
114
115 mcf.addFlag("Muon.useSegmentMatching", lambda prevFlags : prevFlags.Beam.Type is BeamType.Collisions) # Do not use for cosmics or singlebeam
116 mcf.addFlag("Muon.useTrackSegmentMatching", True )
117 mcf.addFlag("Muon.runCommissioningChain", lambda prevFlags: ( False and (prevFlags.Detector.EnableMM or prevFlags.Detector.EnablesTGC) \
118 and prevFlags.Beam.Type is BeamType.Collisions) )
119
120 mcf.addFlag("Muon.applyMMPassivation", lambda prevFlags: prevFlags.Detector.EnableMM and not prevFlags.Common.isOnline and (prevFlags.Common.Project is not Project.AthSimulation \
121 and (prevFlags.Common.ProductionStep not in [ProductionStep.Simulation, ProductionStep.FastChain] or prevFlags.Overlay.DataOverlay)))
122 # CalibFlags
123 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
124 mcf.addFlag("Muon.Calib.fitAnalyticRt", False) #Toggle whether the look-up R-t tables shall undergo an intermediate polynomial fit
125
126 mcf.addFlag("Muon.Calib.readMDTCalibFromBlob", True) # Read mdt tube calibration from blob-folders
127 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)
128 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)
129
130 mcf.addFlag("Muon.Calib.applySigPropUncert", lambda prevFlags: prevFlags.Muon.usePhaseIIGeoSetup )
131 mcf.addFlag("Muon.Calib.useMLRt", True) # use ML-RT functions from COOL
132 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
133 mcf.addFlag("Muon.Calib.mdtCalibrationSource", "MDT") # Source for MDT t0s and rts
134 mcf.addFlag("Muon.Calib.mdtPropagationSpeedBeta", lambda prevFlags : 1.0 if prevFlags.Input.isMC else 0.85) #
135
136 mcf.addFlag("Muon.Calib.CscPedFromLocalFile", False)
137 mcf.addFlag("Muon.Calib.CscNoiseFromLocalFile", False)
138 mcf.addFlag("Muon.Calib.CscPSlopeFromLocalFile", False)
139 mcf.addFlag("Muon.Calib.CscStatusFromLocalFile", False)
140 mcf.addFlag("Muon.Calib.CscRmsFromLocalFile", False)
141 mcf.addFlag("Muon.Calib.CscF001FromLocalFile", False)
142 mcf.addFlag("Muon.Calib.CscT0BaseFromLocalFile", False)
143 mcf.addFlag("Muon.Calib.CscT0PhaseFromLocalFile", False)
144
145 mcf.addFlag("Muon.Calib.EventTag", "MoMu")
146
147 # Choose the (MDT) calibration mode.
148 # 'ntuple' : write standard calibration ntuple (up to segments)
149 # 'trackNtuple' : write standard ntuple + tracks
150 # 'regionNtuple' : write one ntuple per calibration region
151 # 't0Classic' : do classic t0 calibration
152 # 't0MT' : do MT t0 calibration
153 # 'rtClassic' : do classic rt calibration
154 # 'rtAnalytic' : do analytic rt calibration
155 mcf.addFlag("Muon.Calib.mdtMode", "ntuple")
156
157
158 # 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
159 # do not apply NSW T0 calibration if we are running online or MC or a RUN4 geometry, keep only for 23 or 24
160 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 )
161 mcf.addFlag("Muon.Calib.applysTgcT0Correction", lambda prevFlags: prevFlags.GeoModel.Run<LHCPeriod.Run4 and not prevFlags.Common.isOnline and not prevFlags.Input.isMC and False)
162 mcf.addFlag("Muon.Calib.applyMmBFieldCalib", True)
163
164 # Muon Align flags
165
166 mcf.addFlag("Muon.Align.UseALines", lambda prevFlags: (_muonAlignMode(prevFlags)))
167 mcf.addFlag("Muon.Align.UseBLines", lambda prevFlags: prevFlags.Muon.Align.UseALines)
168 mcf.addFlag("Muon.Align.UseILines", lambda prevFlags: (_muonAlignMode(prevFlags)) and \
169 prevFlags.Detector.GeometryCSC and 'HLT' not in prevFlags.IOVDb.GlobalTag)
170 mcf.addFlag("Muon.Align.UseAsBuilt", lambda prevFlags: (_muonAlignMode(prevFlags)) and not \
171 (prevFlags.IOVDb.DatabaseInstance == 'COMP200' or \
172 'HLT' in prevFlags.IOVDb.GlobalTag or prevFlags.Common.isOnline) )
173 mcf.addFlag("Muon.Align.UsesTGCAsBuild", lambda prevFlags: (_muonAlignMode(prevFlags)) and not prevFlags.Common.isOnline and prevFlags.GeoModel.Run == LHCPeriod.Run3)
174
175 # Muon Trigger Flags
176 mcf.addFlag("Muon.MuonTrigger", False)
177 mcf.addFlag("Muon.SAMuonTrigger", False)
178 mcf.addFlag("Muon.disableNSWForL2SA", True)
179
180 mcf.addFlag("Muon.enableAlignment",lambda flags: (flags.Common.Project is not Project.AthSimulation \
181 and not (flags.Common.ProductionStep in [ProductionStep.Simulation, ProductionStep.FastChain] or flags.Overlay.DataOverlay)))
182 mcf.addFlag("Muon.enableTrigIDtrackReuse", False)
183 # configuration of the DESDM_MCP output format
184
185 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.
186 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.
187
188 # configuration to write out RPC RDO for trigger timing calibration
189 mcf.addFlag("Muon.doWriteRpcRDO", True)
190
191 mcf.addFlag("Muon.writeSDOs", lambda prevFlags : prevFlags.Output.doWriteESD and prevFlags.Input.isMC)
192
193 # configure the MM cluster reco method that is used in the cluster calibration step
194 #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
195 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)
196
197 mcf.addFlag("Muon.writexAODPRD", lambda prevFlags: prevFlags.Muon.usePhaseIIGeoSetup) # Output new xAOD format from convertors (to be removed once the old format is deprecated)
198 # 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
199 mcf.addFlag("Muon.useMdtDcsData", lambda prevFlags : not prevFlags.Common.isOnline and prevFlags.Detector.GeometryMDT)
200
201
202 # TODO - add configuration for above
203
204 return mcf
205