ATLAS Offline Software
Loading...
Searching...
No Matches
python.TauCommonConfig Namespace Reference

Functions

 AddTauAugmentationCfg (flags, wp="GNTauVeryLoose", **kwargs)
 AddTauIDDecorationCfg (flags, **kwargs)
 AddTauIDDisplacedDecorationCfg (flags, **kwargs)
 AddMuonRemovalTauAODReRecoAlgCfg (flags, **kwargs)
 TauThinningCfg (flags, name, **kwargs)

Function Documentation

◆ AddMuonRemovalTauAODReRecoAlgCfg()

python.TauCommonConfig.AddMuonRemovalTauAODReRecoAlgCfg ( flags,
** kwargs )
Configure the MuonRM AOD tau building

Definition at line 161 of file TauCommonConfig.py.

161def AddMuonRemovalTauAODReRecoAlgCfg(flags, **kwargs):
162 """Configure the MuonRM AOD tau building"""
163
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")
173
174 # get tools from holder
175 import tauRec.TauToolHolder as tauTools
176 if "modificationTools" not in kwargs:
177 tools_mod = []
178 tools_mod.append( acc.popToolsAndMerge(tauTools.TauAODMuonRemovalCfg(flags)) )
179 for tool in tools_mod:
180 tool.inAOD = True
181 kwargs.setdefault("modificationTools", tools_mod)
182
183 if "officialTools" not in kwargs:
184 tools_after = []
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:
208 tool.inAOD = True
209 kwargs.setdefault("officialTools", tools_after)
210
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")
215 myTauAODRunnerAlg = TauAODRunnerAlg(
216 name = "MuonRemovalTauAODReRecoAlg",
217 **kwargs
218 )
219 acc.addEventAlgo(myTauAODRunnerAlg)
220 return acc
221
222
The implementation of the TauAODRunnerAlg, which is meant to run at AOD level.

◆ AddTauAugmentationCfg()

python.TauCommonConfig.AddTauAugmentationCfg ( flags,
wp = "GNTauVeryLoose",
** kwargs )

Definition at line 6 of file TauCommonConfig.py.

6def AddTauAugmentationCfg(flags, wp="GNTauVeryLoose", **kwargs):
7 kwargs.setdefault("TauContainerName", "TauJets")
8
9 acc = ComponentAccumulator()
10
11 # tau selection relies on RNN electron veto, we must decorate the fixed eveto WPs before applying tau selection
12 acc.merge(AddTauIDDecorationCfg(flags, TauContainerName=kwargs["TauContainerName"]))
13
14 from DerivationFrameworkTools.DerivationFrameworkToolsConfig import AsgSelectionToolWrapperCfg
15 from TauAnalysisTools.TauAnalysisToolsConfig import TauSelectionToolCfg
16
17 TauAugmentationTools = []
18
19 config = {
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",
24 }
25
26 TauSelector = acc.popToolsAndMerge(TauSelectionToolCfg(flags,
27 name = f'TauSelector{wp}',
28 ConfigPath = config[wp]))
29 acc.addPublicTool(TauSelector)
30
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)
37
38 CommonAugmentation = CompFactory.DerivationFramework.CommonAugmentation
39 acc.addEventAlgo(CommonAugmentation(f"Tau{wp}AugmentationKernel", AugmentationTools = TauAugmentationTools))
40 return acc
41

◆ AddTauIDDecorationCfg()

python.TauCommonConfig.AddTauIDDecorationCfg ( flags,
** kwargs )
Decorate tau ID scores and working points

Definition at line 42 of file TauCommonConfig.py.

42def AddTauIDDecorationCfg(flags, **kwargs):
43 """Decorate tau ID scores and working points"""
44
45 #kwargs.setdefault("evetoFix", True)
46 #kwargs.setdefault("GNNTauID", True)
47 tauContainerKey = kwargs.setdefault("TauContainerName", "TauJets")
48 #kwargs.setdefault("prefix", kwargs['TauContainerName'])
49
50 acc = ComponentAccumulator()
51
52 import tauRec.TauToolHolder as tauTools
53 tools = []
54 doEvetoWP = False
55 scoreNames = []
56 WPNames = []
57
58 #def cacheToolProperties(tool):
59 # doEvetoWP = tool.UseAbsEta
60 # scoreName = [tool.ScoreName] if tools[-1].ScoreName != "RNNEleScore" else []
61 # wpName = tool.DecorWPNames
62
63 if kwargs.pop('evetoFix', True):
64 tools.append( acc.popToolsAndMerge(tauTools.TauWPDecoratorEleRNNCfg(flags)) )
65 # Cache tool properties
66 doEvetoWP |= tools[-1].UseAbsEta
67 # The original RNNEleScore should not be overriden
68 if tools[-1].ScoreName != "RNNEleScore": scoreNames.append(tools[-1].ScoreName)
69 scoreNames.append(tools[-1].NewScoreName)
70 WPNames += tools[-1].DecorWPNames
71
72 if kwargs.pop('GNNTauID', True):
73 # vertex-corrected clusters must be rebuilt for tau ID
74 tools.append( acc.popToolsAndMerge(tauTools.TauVertexedClusterDecoratorCfg(flags)) )
75 # Add in GNTau!
76 # evaluate GNTau score for v0prune model
77 tools.append( acc.popToolsAndMerge(tauTools.TauGNNEvaluatorCfg(flags,0,applyLooseTrackSel=True)) )
78 # evaluate GNTau score for v1trunc model
79 tools.append( acc.popToolsAndMerge(tauTools.TauGNNEvaluatorCfg(flags,1,applyLooseTrackSel=True)) )
80 # set WPs decision for v0prune model
81 tools.append( acc.popToolsAndMerge(tauTools.TauWPDecoratorGNNCfg(flags,0)) )
82 # Cache tool properties
83 doEvetoWP |= tools[-1].UseAbsEta
84 # The original RNNEleScore should not be overriden
85 if tools[-1].ScoreName != "RNNEleScore": scoreNames.append(tools[-1].ScoreName)
86 scoreNames.append(tools[-1].NewScoreName)
87 WPNames += tools[-1].DecorWPNames
88
89 # set WPs decision for v1trunc model
90 tools.append( acc.popToolsAndMerge(tauTools.TauWPDecoratorGNNCfg(flags,1)) )
91 # Cache tool properties
92 doEvetoWP |= tools[-1].UseAbsEta
93 # The original RNNEleScore should not be overriden
94 if tools[-1].ScoreName != "RNNEleScore": scoreNames.append(tools[-1].ScoreName)
95 scoreNames.append(tools[-1].NewScoreName)
96 WPNames += tools[-1].DecorWPNames
97
98 if tools:
99 kwargs.setdefault("DoEvetoWP", doEvetoWP)
100 kwargs.setdefault("ScoreDecorationKeys", scoreNames)
101 kwargs.setdefault("WPDecorationKeys", WPNames)
102
103 for tool in tools:
104 acc.addPublicTool(tool)
105 kwargs.setdefault("TauIDTools", tools)
106
107 TauIDDecoratorWrapper = CompFactory.DerivationFramework.TauIDDecoratorWrapper
108 TauIDDecoratorKernel = CompFactory.DerivationFramework.CommonAugmentation
109
110 prefix = kwargs.pop('prefix', tauContainerKey)
111 tauIDDecoratorWrapper = TauIDDecoratorWrapper(name = f"{prefix}_TauIDDecoratorWrapper",
112 **kwargs)
113 print("PXQW TauIDDecoratorsWrapper: " + str(tauIDDecoratorWrapper))
114 acc.addPublicTool(tauIDDecoratorWrapper)
115 acc.addEventAlgo(TauIDDecoratorKernel(name = f"{prefix}_TauIDDecorKernel",
116 AugmentationTools = [tauIDDecoratorWrapper]))
117
118 return acc
119
120# Attach displaced Tau ID scores
void print(char *figname, TCanvas *c1)

◆ AddTauIDDisplacedDecorationCfg()

python.TauCommonConfig.AddTauIDDisplacedDecorationCfg ( flags,
** kwargs )
Decorate displaced tau ID scores and working points. Follows AddTauIDDisplacedDecorationCfg()

Definition at line 121 of file TauCommonConfig.py.

121def AddTauIDDisplacedDecorationCfg(flags, **kwargs):
122 """Decorate displaced tau ID scores and working points. Follows AddTauIDDisplacedDecorationCfg()"""
123 tauContainerKey = kwargs.setdefault("TauContainerName", "TauJetsLRT")
124
125 flags_TauLRT = flags.cloneAndReplace("Tau.ActiveConfig", "Tau.TauLRT")
126
127 acc = ComponentAccumulator()
128
129 scoreNames = []
130
131 import tauRec.TauToolHolder as tauTools
132 tool_prompt = acc.popToolsAndMerge(tauTools.TauGNNEvaluatorCfg(flags,0,applyLooseTrackSel=True))
133 scoreNames += ["GNTauScore_v0prune"]
134
135 tool_displaced = acc.popToolsAndMerge(tauTools.TauGNNDisplacedEvaluatorCfg(flags_TauLRT, tauContainerName=tauContainerKey))
136 scoreNames += ["GNdTauScore", "GNdTauProbTau", "GNdTauProbJet"]
137
138 kwargs.setdefault("ScoreDecorationKeys", scoreNames)
139 kwargs.setdefault("WPDecorationKeys", [])
140
141 acc.addPublicTool(tool_prompt)
142 acc.addPublicTool(tool_displaced)
143 kwargs.setdefault("TauIDTools", [tool_prompt, tool_displaced])
144
145 tauIDDecoratorWrapper = CompFactory.DerivationFramework.TauIDDecoratorWrapper(
146 name = f"{tauContainerKey}_TauIDDisplacedDecoratorWrapper",
147 **kwargs,
148 )
149 acc.addPublicTool(tauIDDecoratorWrapper)
150
151 prefix = kwargs.pop('prefix', tauContainerKey)
152 acc.addEventAlgo(
153 CompFactory.DerivationFramework.CommonAugmentation(
154 name = f"{prefix}_TauDisplacedIDDecorKernel",
155 AugmentationTools = [tauIDDecoratorWrapper],
156 )
157 )
158 return acc
159
160# TauJets_MuonRM steering

◆ TauThinningCfg()

python.TauCommonConfig.TauThinningCfg ( flags,
name,
** kwargs )
configure tau thinning

Definition at line 223 of file TauCommonConfig.py.

223def TauThinningCfg(flags, name, **kwargs):
224 """configure tau thinning"""
225
226 acc = ComponentAccumulator()
227 TauThinningTool = CompFactory.DerivationFramework.TauThinningTool
228 acc.addPublicTool(TauThinningTool(name, **kwargs), primary=True)
229 return acc