18 """Configure the derivation framework driving algorithm (kernel) for PHYS"""
19 acc = ComponentAccumulator()
21 from TrkConfig.VertexFindingFlags
import VertexSortingSetup
22 if flags.Tracking.PriVertex.sortingSetup
is VertexSortingSetup.GNNSorting:
23 from DerivationFrameworkPhys.GNNVertexConfig
import GNNVertexCfg
24 acc.merge(GNNVertexCfg(flags))
27 from DerivationFrameworkPhys.PhysCommonConfig
import PhysCommonAugmentationsCfg
28 acc.merge(PhysCommonAugmentationsCfg(
30 TriggerListsHelper = kwargs[
'TriggerListsHelper']
35 nametag = name.replace(
'Kernel',
'')
37 'TrackParticleThinningToolName' : nametag+
"TrackParticleThinningTool",
38 'MuonTPThinningToolName' : nametag+
"MuonTPThinningTool",
39 'TauJetThinningToolName' : nametag+
"TauJetThinningTool",
40 'TauJets_MuonRMThinningToolName' : nametag+
"TauJets_MuonRMThinningTool",
41 'DiTauThinningToolName' : nametag+
"DiTauThinningTool",
42 'DiTauTPThinningToolName' : nametag+
"DiTauTPThinningTool",
43 'DiTauLowPtThinningToolName' : nametag+
"DiTauLowPtThinningTool",
44 'DiTauLowPtTPThinningToolName' : nametag+
"DiTauLowPtTPThinningTool",
47 if flags.Tau.TauEleRM_isAvailable:
48 thinningToolsArgs[
'TauJets_EleRMThinningToolName'] = nametag+
"TauJets_EleRMThinningTool"
50 from DerivationFrameworkPhys.PhysCommonThinningConfig
import PhysCommonThinningCfg
51 acc.merge(PhysCommonThinningCfg(flags, StreamName = kwargs[
'StreamName'], **thinningToolsArgs))
54 for key
in thinningToolsArgs:
55 thinningTools.append(acc.getPublicTool(thinningToolsArgs[key]))
58 DerivationKernel = CompFactory.DerivationFramework.DerivationKernel
59 acc.addEventAlgo(DerivationKernel(name, ThinningTools = thinningTools))
63def PHYSCoreCfg(flags, name_tag='PHYS', StreamName='StreamDAOD_PHYS', TriggerListsHelper=None, addExtraVariables=None):
65 if TriggerListsHelper
is None:
66 from DerivationFrameworkPhys.TriggerListsHelper
import TriggerListsHelper
67 TriggerListsHelper = TriggerListsHelper(flags)
69 acc = ComponentAccumulator()
72 from DerivationFrameworkHiggs.HiggsPhysContent
import HiggsAugmentationAlgsCfg
73 acc.merge(HiggsAugmentationAlgsCfg(flags))
77 from IsolationSelection.IsolationSelectionConfig
import IsoCloseByAlgsCfg
78 acc.merge(IsoCloseByAlgsCfg(flags, isPhysLite =
False, stream_name = StreamName))
81 from LeptonTaggers.LeptonTaggersConfig
import DecoratePLITAlgsCfg
82 acc.merge(DecoratePLITAlgsCfg(flags))
87 from DerivationFrameworkMCTruth.HFClassificationCommonConfig
import HFClassificationCommonCfg
88 acc.merge(HFClassificationCommonCfg(flags))
93 from OutputStreamAthenaPool.OutputStreamConfig
import OutputStreamCfg
94 from xAODMetaDataCnv.InfileMetaDataConfig
import SetupMetaDataForStreamCfg
95 from DerivationFrameworkCore.SlimmingHelper
import SlimmingHelper
97 PHYSSlimmingHelper =
SlimmingHelper(name_tag+
"SlimmingHelper", NamesAndTypes = flags.Input.TypedCollections, flags = flags)
98 PHYSSlimmingHelper.SmartCollections = [
"EventInfo",
103 "InDetTrackParticles",
105 "AntiKt4EMPFlowJets",
106 "MET_Baseline_AntiKt4EMTopo",
107 "MET_Baseline_AntiKt4EMPFlow",
112 "AntiKt10UFOCSSKSoftDropBeta100Zcut10Jets",
113 "AntiKtVR30Rmax4Rmin02PV0TrackJets",
115 if flags.Tau.TauEleRM_isAvailable:
116 PHYSSlimmingHelper.SmartCollections.append(
"TauJets_EleRM")
118 excludedVertexAuxData =
"-vxTrackAtVertex.-MvfFitInfo.-isInitialized.-VTAV"
120 StaticContent += [
"xAOD::VertexContainer#SoftBVrtClusterTool_Tight_Vertices"]
121 StaticContent += [
"xAOD::VertexAuxContainer#SoftBVrtClusterTool_Tight_VerticesAux." + excludedVertexAuxData]
122 StaticContent += [
"xAOD::VertexContainer#SoftBVrtClusterTool_Medium_Vertices"]
123 StaticContent += [
"xAOD::VertexAuxContainer#SoftBVrtClusterTool_Medium_VerticesAux." + excludedVertexAuxData]
124 StaticContent += [
"xAOD::VertexContainer#SoftBVrtClusterTool_Loose_Vertices"]
125 StaticContent += [
"xAOD::VertexAuxContainer#SoftBVrtClusterTool_Loose_VerticesAux." + excludedVertexAuxData]
127 PHYSSlimmingHelper.StaticContent = StaticContent
130 PHYSSlimmingHelper.ExtraVariables += [
"AntiKt4EMTopoJets.DFCommonJets_QGTagger_truthjet_nCharged.DFCommonJets_QGTagger_truthjet_pt.DFCommonJets_QGTagger_truthjet_eta.DFCommonJets_QGTagger_NTracks.DFCommonJets_QGTagger_TracksWidth.DFCommonJets_QGTagger_TracksC1.ConeExclBHadronsFinal.ConeExclCHadronsFinal.GhostBHadronsFinal.GhostCHadronsFinal.GhostBHadronsFinalCount.GhostBHadronsFinalPt.GhostCHadronsFinalCount.GhostCHadronsFinalPt.IsoFixedCone5PtPUsub",
131 "AntiKt4EMPFlowJets.DFCommonJets_QGTagger_truthjet_nCharged.DFCommonJets_QGTagger_truthjet_pt.DFCommonJets_QGTagger_truthjet_eta.DFCommonJets_QGTagger_NTracks.DFCommonJets_QGTagger_TracksWidth.DFCommonJets_QGTagger_TracksC1.ConeExclBHadronsFinal.ConeExclCHadronsFinal.GhostBHadronsFinal.GhostCHadronsFinal.GhostBHadronsFinalCount.GhostBHadronsFinalPt.GhostCHadronsFinalCount.GhostCHadronsFinalPt.isJvtHS.isJvtPU.IsoFixedCone5PtPUsub",
132 "TruthPrimaryVertices.t.x.y.z",
133 "InDetTrackParticles.TTVA_AMVFVertices.TTVA_AMVFWeights.eProbabilityHT.numberOfTRTHits.numberOfTRTOutliers",
134 "EventInfo.GenFiltHT.GenFiltMET.GenFiltHTinclNu.GenFiltPTZ.GenFiltFatJ.HF_Classification.HF_SimpleClassification",
135 "TauJets.dRmax.etOverPtLeadTrk",
136 "TauJets_MuonRM.dRmax.etOverPtLeadTrk",
137 "HLT_xAOD__TrigMissingETContainer_TrigEFMissingET.ex.ey",
138 "HLT_xAOD__TrigMissingETContainer_TrigEFMissingET_mht.ex.ey",
139 "HLT_AnomDet_ComboHypo.adScore"]
141 if addExtraVariables:
142 PHYSSlimmingHelper.ExtraVariables += addExtraVariables
144 if flags.Tau.TauEleRM_isAvailable:
145 PHYSSlimmingHelper.ExtraVariables += [
"TauJets_EleRM.dRmax.etOverPtLeadTrk"]
148 from LeptonTaggers.LeptonTaggersConfig
import GetExtraPLITVariablesForDxAOD
149 PHYSSlimmingHelper.ExtraVariables += GetExtraPLITVariablesForDxAOD()
152 PHYSSlimmingHelper.ExtraVariables += [
"AntiKt10UFOCSSKSoftDropBeta100Zcut10Jets.R10TruthLabel_R22v1_TruthJetMass",
153 "AntiKt10UFOCSSKSoftDropBeta100Zcut10Jets.R10TruthLabel_R22v1_TruthJetPt",
154 "AntiKt10UFOCSSKSoftDropBeta100Zcut10Jets.R10TruthLabel_R22v1_TruthGroomedJetMass",
155 "AntiKt10UFOCSSKSoftDropBeta100Zcut10Jets.R10TruthLabel_R22v1_TruthGroomedJetPt",
156 "AntiKt10UFOCSSKSoftDropBeta100Zcut10Jets.R10WZTruthLabel_R22v1_TruthJetMass",
157 "AntiKt10UFOCSSKSoftDropBeta100Zcut10Jets.R10WZTruthLabel_R22v1_TruthJetPt",
158 "AntiKt10UFOCSSKSoftDropBeta100Zcut10Jets.R10WZTruthLabel_R22v1_TruthGroomedJetMass",
159 "AntiKt10UFOCSSKSoftDropBeta100Zcut10Jets.R10WZTruthLabel_R22v1_TruthGroomedJetPt"]
164 from DerivationFrameworkMCTruth.MCTruthCommonConfig
import addTruth3ContentToSlimmerTool
165 addTruth3ContentToSlimmerTool(PHYSSlimmingHelper)
166 PHYSSlimmingHelper.AllVariables += [
'TruthLHEParticles',
'InTimeAntiKt4TruthJets',
'OutOfTimeAntiKt4TruthJets']
167 PHYSSlimmingHelper.ExtraVariables += [
"Electrons.TruthLink",
170 "AntiKt4TruthDressedWZJets.IsoFixedCone5Pt.HFHadronOriginID",
171 "TruthHFWithDecayParticles.prodVtxLink.prodVtxLink.prodVtxLink.decayVtxLink.decayVtxLink.decayVtxLink.parentLinks.childLinks.m.px.py.pz.e.pdgId.Classification.uid.classifierParticleOrigin.classifierParticleType.classifierParticleOutCome.status",
172 "TruthHFWithDecayVertices.incomingParticleLinks.outgoingParticleLinks.uid.status.x.y.z.t",
173 "TruthCharm.prodVtxLink.prodVtxLink.prodVtxLink.decayVtxLink.decayVtxLink.decayVtxLink.parentLinks.childLinks.m.px.py.pz.e.pdgId.Classification.uid.classifierParticleOrigin.classifierParticleType.classifierParticleOutCome.status.barcode.polarizationPhi.polarizationTheta",
174 "TruthPileupParticles.prodVtxLink.prodVtxLink.prodVtxLink.decayVtxLink.decayVtxLink.decayVtxLink.m.px.py.pz.e.pdgId.Classification.uid.classifierParticleOrigin.classifierParticleType.classifierParticleOutCome.status.barcode.PVz.pileupEventNumber.parentHadronID"]
176 from DerivationFrameworkMCTruth.MCTruthCommonConfig
import AddTauAndDownstreamParticlesCfg
177 acc.merge(AddTauAndDownstreamParticlesCfg(flags))
178 PHYSSlimmingHelper.ExtraVariables += [
"TruthTausWithDecayParticles.prodVtxLink.prodVtxLink.prodVtxLink.decayVtxLink.decayVtxLink.decayVtxLink.m.px.py.pz.e.pdgId.Classification.uid.classifierParticleOrigin.classifierParticleType.classifierParticleOutCome.status",
179 "TruthTausWithDecayVertices.incomingParticleLinks.outgoingParticleLinks.uid.status.x.y.z.t"]
182 from DerivationFrameworkHiggs.HiggsPhysContent
import setupHiggsSlimmingVariables
183 setupHiggsSlimmingVariables(flags, PHYSSlimmingHelper)
186 PHYSSlimmingHelper.AllVariables += [
'AFPSiHitContainer',
'AFPToFHitContainer' ]
189 PHYSSlimmingHelper.AppendToDictionary.update({
'MET_Core_AntiKt4EMPFlowHR':
'xAOD::MissingETContainer',
'MET_Core_AntiKt4EMPFlowHRAux':
'xAOD::MissingETAuxContainer',
190 'METAssoc_AntiKt4EMPFlowHR':
'xAOD::MissingETAssociationMap',
'METAssoc_AntiKt4EMPFlowHRAux':
'xAOD::MissingETAuxAssociationMap'})
192 PHYSSlimmingHelper.AllVariables += [
'METAssoc_AntiKt4EMPFlowHR']
194 PHYSSlimmingHelper.ExtraVariables += [
'Muons.UEcorr_Pt',
'Electrons.UEcorr_Pt',
'MET_Core_AntiKt4EMPFlowHR.name.mpx.mpy.sumet.source']
197 PHYSSlimmingHelper.IncludeTriggerNavigation =
False
198 PHYSSlimmingHelper.IncludeJetTriggerContent =
False
199 PHYSSlimmingHelper.IncludeMuonTriggerContent =
False
200 PHYSSlimmingHelper.IncludeEGammaTriggerContent =
False
201 PHYSSlimmingHelper.IncludeTauTriggerContent =
False
202 PHYSSlimmingHelper.IncludeEtMissTriggerContent =
False
203 PHYSSlimmingHelper.IncludeBJetTriggerContent =
False
204 PHYSSlimmingHelper.IncludeBPhysTriggerContent =
False
205 PHYSSlimmingHelper.IncludeMinBiasTriggerContent =
False
207 PHYSSlimmingHelper.IncludeBJetTriggerByYearContent =
True
211 if flags.Trigger.EDMVersion == 2:
212 from DerivationFrameworkPhys.TriggerMatchingCommonConfig
import AddRun2TriggerMatchingToSlimmingHelper
213 AddRun2TriggerMatchingToSlimmingHelper(SlimmingHelper = PHYSSlimmingHelper,
214 OutputContainerPrefix =
"TrigMatch_",
215 TriggerList = TriggerListsHelper.Run2TriggerNamesTau)
216 AddRun2TriggerMatchingToSlimmingHelper(SlimmingHelper = PHYSSlimmingHelper,
217 OutputContainerPrefix =
"TrigMatch_",
218 TriggerList = TriggerListsHelper.Run2TriggerNamesNoTau)
220 if flags.Trigger.EDMVersion == 3
or (flags.Trigger.EDMVersion == 2
and flags.Trigger.doEDMVersionConversion):
221 from TrigNavSlimmingMT.TrigNavSlimmingMTConfig
import AddRun3TrigNavSlimmingCollectionsToSlimmingHelper
222 AddRun3TrigNavSlimmingCollectionsToSlimmingHelper(PHYSSlimmingHelper)
225 from Campaigns.Utils
import getDataYear
226 if getDataYear(flags) >= 2024:
228 from DerivationFrameworkPhys.TriggerMatchingCommonConfig
import AddjFexRoIsToSlimmingHelper
229 AddjFexRoIsToSlimmingHelper(SlimmingHelper = PHYSSlimmingHelper)
230 elif getDataYear(flags) >= 2015:
232 from DerivationFrameworkPhys.TriggerMatchingCommonConfig
import AddLegacyL1JetRoIsToSlimmingHelper
233 AddLegacyL1JetRoIsToSlimmingHelper(SlimmingHelper = PHYSSlimmingHelper)
236 PHYSItemList = PHYSSlimmingHelper.GetItemList()
237 acc.merge(OutputStreamCfg(flags,
"DAOD_"+name_tag, ItemList=PHYSItemList, AcceptAlgs=[name_tag+
"Kernel"]))
238 acc.merge(SetupMetaDataForStreamCfg(flags,
"DAOD_"+name_tag, AcceptAlgs=[name_tag+
"Kernel"], createMetadata=[MetadataCategory.CutFlowMetaData, MetadataCategory.TruthMetaData]))