6def RecoSteering(flags):
8 Generates configuration of the reconstructions
10 from AthenaCommon.Logging
import logging
11 log = logging.getLogger(
"RecoSteering")
12 from AthenaConfiguration.MainServicesConfig
import MainServicesCfg
13 acc = MainServicesCfg(flags)
16 acc.flagPerfmonDomain(
'IO')
17 if flags.Input.Format
is Format.BS:
18 from ByteStreamCnvSvc.ByteStreamConfig
import ByteStreamReadCfg
19 acc.merge(ByteStreamReadCfg(flags))
21 if flags.Reco.EnableBeamSpotDecoration:
22 from xAODEventInfoCnv.xAODEventInfoCnvConfig
import (
23 EventInfoBeamSpotDecoratorAlgCfg)
24 acc.merge(EventInfoBeamSpotDecoratorAlgCfg(flags))
26 from LumiBlockComps.LumiBlockMuWriterConfig
import LumiBlockMuWriterCfg
27 acc.merge(LumiBlockMuWriterCfg(flags))
28 log.info(
"---------- Configured BS reading")
30 from AthenaPoolCnvSvc.PoolReadConfig
import PoolReadCfg
31 acc.merge(PoolReadCfg(flags))
33 if "EventInfo" not in flags.Input.Collections:
34 from xAODEventInfoCnv.xAODEventInfoCnvConfig
import (
36 acc.merge(EventInfoCnvAlgCfg(flags))
37 log.info(
"---------- Configured POOL reading")
39 acc.flagPerfmonDomain(
'Truth')
40 if (flags.Input.isMC
or flags.Overlay.DataOverlay)
and flags.Input.Format!=Format.BS:
42 if flags.Output.doGEN_AOD2xAOD:
43 from xAODTruthCnv.xAODTruthCnvConfig
import GEN_AOD2xAODCfg
44 acc.merge(GEN_AOD2xAODCfg(flags))
45 log.info(
"---------- Configured AODtoxAOD Truth Conversion")
47 if flags.Overlay.DataOverlay:
48 from OutputStreamAthenaPool.OutputStreamConfig
import addToAOD
49 acc.merge(addToAOD(flags, [f
'xAOD::VertexContainer#{flags.Overlay.BkgPrefix}PrimaryVertices',
50 f
'xAOD::VertexAuxContainer#{flags.Overlay.BkgPrefix}PrimaryVerticesAux.x.y.z']))
57 if not flags.Overlay.DataOverlay:
58 from JetRecConfig.JetRecoSteering
import addTruthPileupJetsToOutputCfg
59 acc.merge(addTruthPileupJetsToOutputCfg(flags))
60 log.info(
"---------- Configured Truth pileup jet writing")
63 acc.flagPerfmonDomain(
'Trigger')
64 if flags.Reco.EnableTrigger:
65 from TriggerJobOpts.TriggerRecoConfig
import TriggerRecoCfg
66 acc.merge(TriggerRecoCfg(flags))
67 log.info(
"---------- Configured trigger data decoding")
70 acc.flagPerfmonDomain(
'Calo')
71 if flags.Detector.EnableCalo:
72 from CaloRec.CaloRecoConfig
import CaloRecoCfg
73 acc.merge(CaloRecoCfg(flags))
74 log.info(
"---------- Configured calorimeter reconstruction")
77 acc.flagPerfmonDomain(
'ID')
78 if flags.Reco.EnableTracking:
79 if flags.Reco.EnableTrackOverlay:
80 from TrackOverlayRec.TrackOverlayRecoConfig
import TrackOverlayRecoCfg
81 acc.merge(TrackOverlayRecoCfg(flags))
83 from InDetConfig.TrackRecoConfig
import InDetTrackRecoCfg
84 acc.merge(InDetTrackRecoCfg(flags))
86 log.info(
"---------- Configured tracking")
89 acc.flagPerfmonDomain(
'HI')
90 if flags.Reco.EnableHI:
91 from HIRecConfig.HIRecConfig
import HIRecCfg
92 acc.merge(HIRecCfg(flags))
93 log.info(
"---------- Configured Heavy Ion reconstruction")
96 acc.flagPerfmonDomain(
'HGTD')
97 if flags.Reco.EnableHGTDExtension:
98 from HGTD_Config.HGTD_RecoConfig
import HGTD_RecoCfg
99 acc.merge(HGTD_RecoCfg(flags))
100 log.info(
"---------- Configured HGTD track extension")
103 acc.flagPerfmonDomain(
'Muon')
104 if flags.Detector.EnableMuon:
105 from MuonConfig.MuonReconstructionConfig
import MuonReconstructionCfg
106 acc.merge(MuonReconstructionCfg(flags))
107 log.info(
"---------- Configured muon tracking")
110 acc.flagPerfmonDomain(
'EGamma')
111 if flags.Reco.EnableEgamma:
112 from egammaConfig.egammaSteeringConfig
import EGammaSteeringCfg
113 acc.merge(EGammaSteeringCfg(flags))
114 log.info(
"---------- Configured e/gamma")
118 acc.flagPerfmonDomain(
'CaloExtension')
119 if flags.Reco.EnableCaloExtension:
120 from TrackToCalo.CaloExtensionBuilderAlgCfg
import (
121 CaloExtensionBuilderCfg)
122 acc.merge(CaloExtensionBuilderCfg(flags))
123 log.info(
"---------- Configured track calorimeter extension builder")
126 acc.flagPerfmonDomain(
'CombinedMuon')
127 if flags.Reco.EnableCombinedMuon:
128 from MuonCombinedConfig.MuonCombinedReconstructionConfig
import (
129 MuonCombinedReconstructionCfg)
130 acc.merge(MuonCombinedReconstructionCfg(flags))
131 log.info(
"---------- Configured combined muon reconstruction")
135 acc.flagPerfmonDomain(
'TrackCellAssociation')
136 if flags.Reco.EnableTrackCellAssociation:
137 from TrackParticleAssociationAlgs.TrackParticleAssociationAlgsConfig
import (
138 TrackParticleCellAssociationCfg)
139 acc.merge(TrackParticleCellAssociationCfg(flags))
140 log.info(
"---------- Configured track particle-cell association")
143 acc.flagPerfmonDomain(
'PFlow')
144 if flags.Reco.EnablePFlow:
145 from eflowRec.PFRun3Config
import PFCfg
146 acc.merge(
PFCfg(flags))
147 log.info(
"---------- Configured particle flow")
150 acc.flagPerfmonDomain(
'Isolation')
151 if flags.Reco.EnableIsolation:
152 from IsolationAlgs.IsolationSteeringConfig
import IsolationSteeringCfg
153 acc.merge(IsolationSteeringCfg(flags))
154 log.info(
"---------- Configured isolation")
157 acc.flagPerfmonDomain(
'Jets')
158 if flags.Reco.EnableJet:
159 from JetRecConfig.JetRecoSteering
import JetRecoSteeringCfg
160 acc.merge(JetRecoSteeringCfg(flags))
161 log.info(
"---------- Configured Jets")
164 acc.flagPerfmonDomain(
'FTag')
165 if flags.Reco.EnableBTagging:
166 from BTagging.BTagConfig
import BTagRecoSplitCfg
167 acc.merge(BTagRecoSplitCfg(flags))
168 log.info(
"---------- Configured btagging")
171 acc.flagPerfmonDomain(
'Tau')
172 if flags.Reco.EnableTau:
173 from tauRec.TauConfig
import TauReconstructionCfg
174 acc.merge(TauReconstructionCfg(flags))
175 log.info(
"---------- Configured tau reconstruction")
177 if flags.Reco.EnablePFlow:
178 from eflowRec.PFRun3Config
import PFTauFELinkCfg
179 acc.merge(PFTauFELinkCfg(flags))
180 log.info(
"---------- Configured particle flow tau FE linking")
182 acc.flagPerfmonDomain(
'Jets')
183 if flags.Reco.EnableGlobalFELinking:
187 from eflowRec.PFCfg
import PFGlobalFlowElementLinkingCfg
188 acc.merge(PFGlobalFlowElementLinkingCfg(flags))
189 log.info(
"---------- Configured particle flow global linking")
192 acc.flagPerfmonDomain(
'MET')
193 if flags.Reco.EnableMet:
194 from METReconstruction.METRecCfg
import METCfg
195 acc.merge(METCfg(flags))
196 log.info(
"---------- Configured MET")
199 acc.flagPerfmonDomain(
'CaloRings')
200 if flags.Reco.EnableCaloRinger:
201 from CaloRingerAlgs.CaloRingerAlgsConfig
import CaloRingerSteeringCfg
202 acc.merge(CaloRingerSteeringCfg(flags))
203 log.info(
"---------- Configured Calo Rings")
206 acc.flagPerfmonDomain(
'AFP')
207 if flags.Detector.EnableAFP:
208 from ForwardRec.AFPRecConfig
import AFPRecCfg
209 acc.merge(AFPRecCfg(flags))
210 log.info(
"---------- Configured AFP reconstruction")
213 acc.flagPerfmonDomain(
'Lucid')
214 if flags.Detector.EnableLucid:
215 from ForwardRec.LucidRecConfig
import LucidRecCfg
216 acc.merge(LucidRecCfg(flags))
217 log.info(
"---------- Configured Lucid reconstruction")
220 acc.flagPerfmonDomain(
'ZDC')
221 if flags.Reco.EnableZDC:
222 from ZdcRec.ZdcRecConfig
import ZdcRecCfg
223 acc.merge(ZdcRecCfg(flags))
224 log.info(
"---------- Configured ZDC reconstruction")
227 acc.flagPerfmonDomain(
'DQM')
228 if flags.DQ.doMonitoring:
229 from AthenaMonitoring.AthenaMonitoringCfg
import (
230 AthenaMonitoringCfg, AthenaMonitoringPostprocessingCfg)
231 acc.merge(AthenaMonitoringCfg(flags))
232 if flags.DQ.doPostProcessing:
233 acc.merge(AthenaMonitoringPostprocessingCfg(flags))
234 log.info(
"---------- Configured DQ monitoring")
237 acc.flagPerfmonDomain(
'PostProcessing')
238 if flags.Reco.EnablePostProcessing:
240 log.info(
"---------- Configured post-processing")
243 if flags.Overlay.DataOverlay:
245 if flags.Overlay.DataOverlayConditions:
246 from PyJobTransforms.TransformUtils
import executeFromFragment
247 executeFromFragment(flags.Overlay.DataOverlayConditions, flags, acc)
250 acc.flagPerfmonDomain(
'IO')
251 from xAODMetaDataCnv.InfileMetaDataConfig
import SetupMetaDataForStreamCfg
252 from OutputStreamAthenaPool.OutputStreamConfig
import outputStreamName
254 if flags.Output.doWriteESD:
256 from TrkEventCnvTools.TrkEventCnvToolsConfig
import (
257 TrkEventCnvSuperToolCfg)
258 acc.merge(TrkEventCnvSuperToolCfg(flags))
261 SetupMetaDataForStreamCfg(
265 MetadataCategory.ByteStreamMetaData,
266 MetadataCategory.LumiBlockMetaData,
267 MetadataCategory.TruthMetaData,
268 MetadataCategory.IOVMetaData,
272 log.info(
"ESD ItemList: %s", acc.getEventAlgo(
273 outputStreamName(
"ESD")).ItemList)
274 log.info(
"ESD MetadataItemList: %s", acc.getEventAlgo(
275 outputStreamName(
"ESD")).MetadataItemList)
276 log.info(
"---------- Configured ESD writing")
278 if flags.Output.doWriteAOD:
281 SetupMetaDataForStreamCfg(
285 MetadataCategory.ByteStreamMetaData,
286 MetadataCategory.LumiBlockMetaData,
287 MetadataCategory.TruthMetaData,
288 MetadataCategory.IOVMetaData,
292 log.info(
"AOD ItemList: %s", acc.getEventAlgo(
293 outputStreamName(
"AOD")).ItemList)
294 log.info(
"AOD MetadataItemList: %s", acc.getEventAlgo(
295 outputStreamName(
"AOD")).MetadataItemList)
296 log.info(
"---------- Configured AOD writing")
298 if flags.Output.doJiveXML:
299 from JiveXML.JiveXMLConfig
import AlgoJiveXMLCfg
300 acc.merge(AlgoJiveXMLCfg(flags))
301 log.info(
"---------- Configured JiveXML writing")
307 acc = ComponentAccumulator()
308 if flags.Reco.PostProcessing.ThinNegativeClusters:
309 from ThinningUtils.ThinNegativeEnergyCaloClustersConfig
import (
310 ThinNegativeEnergyCaloClustersCfg)
311 acc.merge(ThinNegativeEnergyCaloClustersCfg(flags))
312 if flags.Reco.PostProcessing.TRTAloneThinning:
313 from ThinningUtils.ThinTRTStandaloneConfig
import (
314 ThinTRTStandaloneCfg)
315 acc.merge(ThinTRTStandaloneCfg(flags))
316 if flags.Reco.PostProcessing.InDetForwardTrackParticleThinning:
317 from ThinningUtils.ThinInDetForwardTrackParticlesConfig
import (
318 ThinInDetForwardTrackParticlesCfg)
319 acc.merge(ThinInDetForwardTrackParticlesCfg(flags))
320 if flags.Reco.PostProcessing.GeantTruthThinning:
321 from ThinningUtils.ThinGeantTruthConfig
import (
323 acc.merge(ThinGeantTruthCfg(flags))
326 if flags.Tracking.thinInDetClustersOnTrack:
327 from ThinningUtils.ThinInDetClustersConfig
import (
328 ThinInDetClustersCfg)
329 acc.merge(ThinInDetClustersCfg(flags))
331 if flags.Output.doWriteAOD
and flags.Reco.HIMode
in [HIMode.UPC, HIMode.HIP]:
332 from HIGlobal.RecordExtraInfoConfig
import addMBTS, addSpacePoints
333 acc.merge(addMBTS(flags))
334 if flags.Reco.HIMode
is HIMode.UPC:
335 acc.merge(addSpacePoints(flags))