7 kwargs.setdefault(
"TauContainerName",
"TauJets")
9 acc = ComponentAccumulator()
14 from DerivationFrameworkTools.DerivationFrameworkToolsConfig
import AsgSelectionToolWrapperCfg
15 from TauAnalysisTools.TauAnalysisToolsConfig
import TauSelectionToolCfg
17 TauAugmentationTools = []
20 "GNTauVeryLoose" :
"TauAnalysisAlgorithms/tau_selection_gntau_veryloose_noeleid.conf",
21 "GNTauLoose" :
"TauAnalysisAlgorithms/tau_selection_gntau_loose_noeleid.conf",
22 "GNTauMedium" :
"TauAnalysisAlgorithms/tau_selection_gntau_medium_noeleid.conf",
23 "GNTauTight" :
"TauAnalysisAlgorithms/tau_selection_gntau_tight_noeleid.conf",
26 TauSelector = acc.popToolsAndMerge(TauSelectionToolCfg(flags,
27 name = f
'TauSelector{wp}',
28 ConfigPath = config[wp]))
29 acc.addPublicTool(TauSelector)
31 TauWrapper = acc.getPrimaryAndMerge(AsgSelectionToolWrapperCfg(flags,
32 name = f
"Tau{wp}Wrapper",
33 AsgSelectionTool = TauSelector,
34 StoreGateEntryName = f
"DFTau{wp}",
35 ContainerName = kwargs[
"TauContainerName"]))
36 TauAugmentationTools.append(TauWrapper)
38 CommonAugmentation = CompFactory.DerivationFramework.CommonAugmentation
39 acc.addEventAlgo(CommonAugmentation(f
"Tau{wp}AugmentationKernel", AugmentationTools = TauAugmentationTools))
43 """Decorate tau ID scores and working points"""
47 tauContainerKey = kwargs.setdefault(
"TauContainerName",
"TauJets")
50 acc = ComponentAccumulator()
52 import tauRec.TauToolHolder
as tauTools
63 if kwargs.pop(
'evetoFix',
True):
64 tools.append( acc.popToolsAndMerge(tauTools.TauWPDecoratorEleRNNCfg(flags)) )
66 doEvetoWP |= tools[-1].UseAbsEta
68 if tools[-1].ScoreName !=
"RNNEleScore": scoreNames.append(tools[-1].ScoreName)
69 scoreNames.append(tools[-1].NewScoreName)
70 WPNames += tools[-1].DecorWPNames
72 if kwargs.pop(
'GNNTauID',
True):
74 tools.append( acc.popToolsAndMerge(tauTools.TauVertexedClusterDecoratorCfg(flags)) )
77 tools.append( acc.popToolsAndMerge(tauTools.TauGNNEvaluatorCfg(flags,0,applyLooseTrackSel=
True)) )
79 tools.append( acc.popToolsAndMerge(tauTools.TauGNNEvaluatorCfg(flags,1,applyLooseTrackSel=
True)) )
81 tools.append( acc.popToolsAndMerge(tauTools.TauWPDecoratorGNNCfg(flags,0)) )
83 doEvetoWP |= tools[-1].UseAbsEta
85 if tools[-1].ScoreName !=
"RNNEleScore": scoreNames.append(tools[-1].ScoreName)
86 scoreNames.append(tools[-1].NewScoreName)
87 WPNames += tools[-1].DecorWPNames
90 tools.append( acc.popToolsAndMerge(tauTools.TauWPDecoratorGNNCfg(flags,1)) )
92 doEvetoWP |= tools[-1].UseAbsEta
94 if tools[-1].ScoreName !=
"RNNEleScore": scoreNames.append(tools[-1].ScoreName)
95 scoreNames.append(tools[-1].NewScoreName)
96 WPNames += tools[-1].DecorWPNames
99 kwargs.setdefault(
"DoEvetoWP", doEvetoWP)
100 kwargs.setdefault(
"ScoreDecorationKeys", scoreNames)
101 kwargs.setdefault(
"WPDecorationKeys", WPNames)
104 acc.addPublicTool(tool)
105 kwargs.setdefault(
"TauIDTools", tools)
107 TauIDDecoratorWrapper = CompFactory.DerivationFramework.TauIDDecoratorWrapper
108 TauIDDecoratorKernel = CompFactory.DerivationFramework.CommonAugmentation
110 prefix = kwargs.pop(
'prefix', tauContainerKey)
111 tauIDDecoratorWrapper = TauIDDecoratorWrapper(name = f
"{prefix}_TauIDDecoratorWrapper",
113 print(
"PXQW TauIDDecoratorsWrapper: " + str(tauIDDecoratorWrapper))
114 acc.addPublicTool(tauIDDecoratorWrapper)
115 acc.addEventAlgo(TauIDDecoratorKernel(name = f
"{prefix}_TauIDDecorKernel",
116 AugmentationTools = [tauIDDecoratorWrapper]))
122 """Decorate displaced tau ID scores and working points. Follows AddTauIDDisplacedDecorationCfg()"""
123 tauContainerKey = kwargs.setdefault(
"TauContainerName",
"TauJetsLRT")
125 flags_TauLRT = flags.cloneAndReplace(
"Tau.ActiveConfig",
"Tau.TauLRT")
127 acc = ComponentAccumulator()
131 import tauRec.TauToolHolder
as tauTools
132 tool_prompt = acc.popToolsAndMerge(tauTools.TauGNNEvaluatorCfg(flags,0,applyLooseTrackSel=
True))
133 scoreNames += [
"GNTauScore_v0prune"]
135 tool_displaced = acc.popToolsAndMerge(tauTools.TauGNNDisplacedEvaluatorCfg(flags_TauLRT, tauContainerName=tauContainerKey))
136 scoreNames += [
"GNdTauScore",
"GNdTauProbTau",
"GNdTauProbJet"]
138 kwargs.setdefault(
"ScoreDecorationKeys", scoreNames)
139 kwargs.setdefault(
"WPDecorationKeys", [])
141 acc.addPublicTool(tool_prompt)
142 acc.addPublicTool(tool_displaced)
143 kwargs.setdefault(
"TauIDTools", [tool_prompt, tool_displaced])
145 tauIDDecoratorWrapper = CompFactory.DerivationFramework.TauIDDecoratorWrapper(
146 name = f
"{tauContainerKey}_TauIDDisplacedDecoratorWrapper",
149 acc.addPublicTool(tauIDDecoratorWrapper)
151 prefix = kwargs.pop(
'prefix', tauContainerKey)
153 CompFactory.DerivationFramework.CommonAugmentation(
154 name = f
"{prefix}_TauDisplacedIDDecorKernel",
155 AugmentationTools = [tauIDDecoratorWrapper],
162 """Configure the MuonRM AOD tau building"""
164 acc = ComponentAccumulator()
165 inputTauJets = kwargs.setdefault(
"Key_tauContainer",
"TauJets")
166 kwargs.setdefault(
"Key_tauOutputContainer",
"TauJets_MuonRM")
167 kwargs.setdefault(
"Key_pi0OutputContainer",
"TauFinalPi0s_MuonRM")
168 kwargs.setdefault(
"Key_neutralPFOOutputContainer",
"TauNeutralParticleFlowObjects_MuonRM")
169 kwargs.setdefault(
"Key_chargedPFOOutputContainer",
"TauChargedParticleFlowObjects_MuonRM")
170 kwargs.setdefault(
"Key_hadronicPFOOutputContainer",
"TauHadronicParticleFlowObjects_MuonRM")
171 kwargs.setdefault(
"Key_tauTrackOutputContainer",
"TauTracks_MuonRM")
172 kwargs.setdefault(
"Key_vertexOutputContainer",
"TauSecondaryVertices_MuonRM")
175 import tauRec.TauToolHolder
as tauTools
176 if "modificationTools" not in kwargs:
178 tools_mod.append( acc.popToolsAndMerge(tauTools.TauAODMuonRemovalCfg(flags)) )
179 for tool
in tools_mod:
181 kwargs.setdefault(
"modificationTools", tools_mod)
183 if "officialTools" not in kwargs:
185 tools_after.append( acc.popToolsAndMerge(tauTools.TauVertexedClusterDecoratorCfg(flags)) )
186 tools_after.append( acc.popToolsAndMerge(tauTools.TauTrackRNNClassifierCfg(flags)) )
187 tools_after.append( acc.popToolsAndMerge(tauTools.EnergyCalibrationLCCfg(flags)) )
188 tools_after.append( acc.popToolsAndMerge(tauTools.TauCommonCalcVarsCfg(flags)) )
189 tools_after.append( acc.popToolsAndMerge(tauTools.TauSubstructureCfg(flags)) )
190 tools_after.append( acc.popToolsAndMerge(tauTools.Pi0ClusterCreatorCfg(flags)) )
191 tools_after.append( acc.popToolsAndMerge(tauTools.Pi0ClusterScalerCfg(flags)) )
192 tools_after.append( acc.popToolsAndMerge(tauTools.Pi0ScoreCalculatorCfg(flags)) )
193 tools_after.append( acc.popToolsAndMerge(tauTools.Pi0SelectorCfg(flags)) )
194 tools_after.append( acc.popToolsAndMerge(tauTools.TauVertexVariablesCfg(flags)) )
195 import PanTauAlgs.JobOptions_Main_PanTau
as pantau
196 tools_after.append( acc.popToolsAndMerge(pantau.PanTauCfg(flags)) )
197 tools_after.append( acc.popToolsAndMerge(tauTools.TauCombinedTESCfg(flags)) )
198 tools_after.append( acc.popToolsAndMerge(tauTools.MvaTESVariableDecoratorCfg(flags)) )
199 tools_after[-1].EventShapeKey =
''
200 tools_after.append( acc.popToolsAndMerge(tauTools.MvaTESEvaluatorCfg(flags)) )
201 tools_after.append( acc.popToolsAndMerge(tauTools.TauIDVarCalculatorCfg(flags)) )
202 tools_after.append( acc.popToolsAndMerge(tauTools.TauJetRNNEvaluatorCfg(flags,applyLooseTrackSel=
True)) )
203 tools_after.append( acc.popToolsAndMerge(tauTools.TauWPDecoratorJetRNNCfg(flags)) )
204 tools_after.append( acc.popToolsAndMerge(tauTools.TauEleRNNEvaluatorCfg(flags,applyLooseTrackSel=
True )) )
205 tools_after.append( acc.popToolsAndMerge(tauTools.TauWPDecoratorEleRNNCfg(flags)) )
206 tools_after.append( acc.popToolsAndMerge(tauTools.TauDecayModeNNClassifierCfg(flags)) )
207 for tool
in tools_after:
209 kwargs.setdefault(
"officialTools", tools_after)
211 kwargs.setdefault(
"ExtraInputs",
212 [ (
'xAOD::TauJetContainer' ,
"StoreGateSvc+{baseName}.truthJetLink".format(baseName = inputTauJets)),
213 (
'xAOD::TauJetContainer' ,
"StoreGateSvc+{baseName}.truthParticleLink".format(baseName = inputTauJets)) ] )
214 TauAODRunnerAlg=CompFactory.getComp(
"TauAODRunnerAlg")
216 name =
"MuonRemovalTauAODReRecoAlg",
219 acc.addEventAlgo(myTauAODRunnerAlg)