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

Functions

 HION5SkimmingToolCfg (flags)
 HION5Thinning (flags)
 HION5KernelCfg (flags, name="HION5Kernel", **kwargs)
 HION5Cfg (flags)

Function Documentation

◆ HION5Cfg()

python.HION5.HION5Cfg ( flags)

Definition at line 177 of file HION5.py.

177def HION5Cfg(flags):
178 acc = ComponentAccumulator()
179
180 JetColl = flags.HeavyIon.HIJetPrefix
181
182 from DerivationFrameworkEGamma.PhotonsCPDetailedContent import PhotonsCPDetailedContent
183 from DerivationFrameworkEGamma.ElectronsCPDetailedContent import ExtraElectronShowerShapes,ExtraElectronGSFVar
184
185 from DerivationFrameworkPhys.TriggerListsHelper import TriggerListsHelper
186 HION5TriggerListsHelper = TriggerListsHelper(flags)
187
188 acc.merge(HION5KernelCfg(flags, name="HION5Kernel", StreamName="StreamDAOD_HION5", TriggerListsHelper = HION5TriggerListsHelper,))
189
190 # configure slimming
191 from OutputStreamAthenaPool.OutputStreamConfig import OutputStreamCfg
192 from xAODMetaDataCnv.InfileMetaDataConfig import SetupMetaDataForStreamCfg
193 from DerivationFrameworkCore.SlimmingHelper import SlimmingHelper
194 from DerivationFrameworkHI import ListSlimming
195
196 HION5SlimmingHelper = SlimmingHelper("HION5SlimmingHelper", NamesAndTypes = flags.Input.TypedCollections, flags = flags)
197 HION5SlimmingHelper.AppendToDictionary = {'EventInfo':'xAOD::EventInfo','EventInfoAux':'xAOD::EventAuxInfo',
198 'TruthEvents':'xAOD::TruthEventContainer','TruthEventsAux':'xAOD::TruthEventAuxContainer',
199 'MET_Truth':'xAOD::MissingETContainer','MET_TruthAux':'xAOD::MissingETAuxContainer',
200 'TruthLHEParticles':'xAOD::TruthParticleContainer', 'TruthLHEParticlesAux':'xAOD::TruthParticleAuxContainer',
201 'TruthElectrons':'xAOD::TruthParticleContainer','TruthElectronsAux':'xAOD::TruthParticleAuxContainer',
202 'TruthMuons':'xAOD::TruthParticleContainer','TruthMuonsAux':'xAOD::TruthParticleAuxContainer',
203 'TruthPhotons':'xAOD::TruthParticleContainer','TruthPhotonsAux':'xAOD::TruthParticleAuxContainer',
204 'TruthTaus':'xAOD::TruthParticleContainer','TruthTausAux':'xAOD::TruthParticleAuxContainer',
205 'TruthNeutrinos':'xAOD::TruthParticleContainer','TruthNeutrinosAux':'xAOD::TruthParticleAuxContainer',
206 'TruthBSM':'xAOD::TruthParticleContainer','TruthBSMAux':'xAOD::TruthParticleAuxContainer',
207 'TruthBoson':'xAOD::TruthParticleContainer','TruthBosonAux':'xAOD::TruthParticleAuxContainer',
208 'TruthBottom':'xAOD::TruthParticleContainer','TruthBottomAux':'xAOD::TruthParticleAuxContainer',
209 'TruthTop':'xAOD::TruthParticleContainer','TruthTopAux':'xAOD::TruthParticleAuxContainer',
210 'TruthForwardProtons':'xAOD::TruthParticleContainer','TruthForwardProtonsAux':'xAOD::TruthParticleAuxContainer',
211 'BornLeptons':'xAOD::TruthParticleContainer','BornLeptonsAux':'xAOD::TruthParticleAuxContainer',
212 'TruthBosonsWithDecayParticles':'xAOD::TruthParticleContainer','TruthBosonsWithDecayParticlesAux':'xAOD::TruthParticleAuxContainer',
213 'TruthBosonsWithDecayVertices':'xAOD::TruthVertexContainer','TruthBosonsWithDecayVerticesAux':'xAOD::TruthVertexAuxContainer',
214 'TruthBSMWithDecayParticles':'xAOD::TruthParticleContainer','TruthBSMWithDecayParticlesAux':'xAOD::TruthParticleAuxContainer',
215 'TruthBSMWithDecayVertices':'xAOD::TruthVertexContainer','TruthBSMWithDecayVerticesAux':'xAOD::TruthVertexAuxContainer',
216 'AntiKt4TruthDressedWZJets':'xAOD::JetContainer','AntiKt4TruthDressedWZJetsAux':'xAOD::JetAuxContainer',
217 'AntiKt10TruthSoftDropBeta100Zcut10Jets':'xAOD::JetContainer','AntiKt10TruthSoftDropBeta100Zcut10JetsAux':'xAOD::JetAuxContainer',
218 'MET_Track1000':'xAOD::MissingETContainer', 'MET_Track1000Aux':'xAOD::MissingETAuxContainer',
219 'MET_Track2000':'xAOD::MissingETContainer', 'MET_Track2000Aux':'xAOD::MissingETAuxContainer',
220 'MET_Track3000':'xAOD::MissingETContainer', 'MET_Track3000Aux':'xAOD::MissingETAuxContainer',
221 'MET_Track4000':'xAOD::MissingETContainer', 'MET_Track4000Aux':'xAOD::MissingETAuxContainer',
222 'MET_Track5000':'xAOD::MissingETContainer', 'MET_Track5000Aux':'xAOD::MissingETAuxContainer',
223 }
224 # Build track MET with ptCut in MeV and HItight Tracks
225 from DerivationFrameworkHI.TrackMET_config import Cfg_METTrack
226 met_ptCutList = [1000,2000,3000,4000,5000]
227
228 for ptCut in met_ptCutList:
229 acc.merge(Cfg_METTrack(flags, ptCut))
230
231 AllVariables = []
232 AllVariables += ListSlimming.HION5AllVariables(flags.Input.RunNumbers[0])
233 AllVariables += ListSlimming.HION5ExtraContainersTrigger()
234
235 # B-Tagging slimming content
236 from DerivationFrameworkFlavourTag import FtagBaseContent
237
238 if flags.Input.isMC:
239 # MC truth augmentation (charm, HF, standard truth nav links, PV) is handled by
240 # PhysAugmentationsHION7Cfg called in HION5KernelCfg — same as HION7/HION15.
241 AllVariables += ListSlimming.HION5AllTruthVariables()
242 if flags.HeavyIon.doHIBTagging:
243 # Add b-tagging truth slimming content
244 FtagBaseContent.add_truth_to_slimming_helper(HION5SlimmingHelper)
245
246 #Variables from FTAG
247 if flags.HeavyIon.doHIBTagging:
248 AllVariables += ListSlimming.HION7AllVarFromFTAG1()
249
250 HION5SlimmingHelper.SmartCollections = ListSlimming.HION5SmartCollections()
251 HION5SlimmingHelper.ExtraVariables = ListSlimming.HION5ExtraVariables()
252 HION5SlimmingHelper.ExtraVariables += PhotonsCPDetailedContent
253 HION5SlimmingHelper.ExtraVariables += ExtraElectronShowerShapes
254 HION5SlimmingHelper.ExtraVariables += ExtraElectronGSFVar
255
256 #Common Augmentation for FTAG and ExtraVariables
257 if flags.HeavyIon.doHIBTagging:
258 from DerivationFrameworkFlavourTag.FtagBaseContent import add_common_augmentation
259 add_common_augmentation(flags, acc, HION5SlimmingHelper, JetColl+"AntiKt4HIJets")
260 # Update AppendToDictionary
261 extra_AppendToDictionary = {}
262 FtagBaseContent.update_append_to_dictionary_in_slimming_helper(flags, HION5SlimmingHelper, extra_AppendToDictionary)
263 # Add ExtraVariables from B-tagging
264 HION5SlimmingHelper.ExtraVariables += ListSlimming.HION7ExtraVarForBtag(JetColl)
265 FtagBaseContent.add_extra_variables_to_slimming_helper(flags, HION5SlimmingHelper)
266
267 HION5SlimmingHelper.AllVariables = AllVariables
268
269 # Add egamma trigger objects
270 HION5SlimmingHelper.IncludeEGammaTriggerContent = True
271 # Add muon trigger objects
272 HION5SlimmingHelper.IncludeMuonTriggerContent = True
273
274 HION5ItemList = HION5SlimmingHelper.GetItemList()
275
276 #DF-prefixed jet containers with b-tagging info
277 HIJetRemovedBranches = ListSlimming.makeHIJetRemovedBranchList()
278 jet_var_str = '.-'.join([''] + HIJetRemovedBranches)
279
280 jetRlist = flags.HeavyIon.Jet.RValues # Default [0.2, 0.4]
281 for jetR in jetRlist:
282 output = ["xAOD::JetContainer#"+JetColl+"AntiKt"+str(jetR)+"HIJets",
283 "xAOD::JetAuxContainer#"+JetColl+"AntiKt"+str(jetR)+"HIJetsAux.-PseudoJet"+jet_var_str]
284 HION5ItemList += output
285
286 acc.merge(OutputStreamCfg(flags, "DAOD_HION5", ItemList=HION5ItemList, AcceptAlgs=["HION5Kernel"]))
287 acc.merge(SetupMetaDataForStreamCfg(flags, "DAOD_HION5", AcceptAlgs=["HION5Kernel"], createMetadata=[MetadataCategory.CutFlowMetaData]))
288
289 return acc

◆ HION5KernelCfg()

python.HION5.HION5KernelCfg ( flags,
name = "HION5Kernel",
** kwargs )
Configure the derivation framework driving algorithm (kernel)
for HION5

Definition at line 101 of file HION5.py.

101def HION5KernelCfg(flags, name="HION5Kernel", **kwargs):
102 """Configure the derivation framework driving algorithm (kernel)
103 for HION5"""
104 acc = ComponentAccumulator()
105
106 # added: DF-prefixed jet collection
107 JetColl = flags.HeavyIon.HIJetPrefix
108 JetKey = JetColl + 'AntiKt4HIJets'
109
110 # Schedule extra jets collections
111 from JetRecConfig.StandardSmallRJets import AntiKt4PV0Track
112 from JetRecConfig.JetRecConfig import JetRecCfg
113 jetList = [AntiKt4PV0Track]
114 for jd in jetList:
115 acc.merge(JetRecCfg(flags, jd))
116
117 # Common augmentations: reuse the same common MC/reco setup as other HION derivations
118 # (same pattern as HION15, which imports PhysAugmentationsHION7Cfg from HION7)
119 from DerivationFrameworkHI.HION7 import PhysAugmentationsHION7Cfg
120 acc.merge(PhysAugmentationsHION7Cfg(flags))
121
122 # HIJetRec configuration with DF-prefixed jet collection names
123 # moved here from HION5Cfg to mirror getDFJets pattern in HION7KernelCfg
124 from HIJetRec.HIJetRecConfigCA import HIJetRecCfg
125 acc.merge(HIJetRecCfg(flags))
126
127 # B-Tagging for HI jets — must be after HIJetRecCfg so DFAntiKt4HIJets exists
128 if flags.HeavyIon.doHIBTagging:
129 from BTagging.FlavorTaggingConfig import FlavorTaggingCfg
130 acc.merge(FlavorTaggingCfg(flags, JetColl+"AntiKt4HIJets"))
131 from BTagging.TrackLeptonConfig import TrackLeptonDecorationCfg
132 acc.merge(TrackLeptonDecorationCfg(flags))
133
134 # skimming -- must come BEFORE algOR so HION5Sequence is created first
135 skimmingTool = acc.getPrimaryAndMerge(HION5SkimmingToolCfg(flags))
136
137 # jet cleaning
138 # Decorate if jet passes OR and save decoration DFCommonJets_passOR
139 # Use modified OR that does not check overlaps with taus
140 from AssociationUtils.AssociationUtilsConfig import OverlapRemovalToolCfg
141
142 outputLabel = "DFCommonJets_passOR_HI"
143 bJetLabel = "" # default
144 tauLabel = "" # workaround for missing taus
145 tauKey = "" # workaround for missing taus
146 orTool = acc.popToolsAndMerge(
147 OverlapRemovalToolCfg(
148 flags, outputLabel=outputLabel, bJetLabel=bJetLabel, doTaus=False
149 )
150 )
151 algOR = CompFactory.OverlapRemovalGenUseAlg(
152 "OverlapRemovalGenUseAlg",
153 OverlapLabel=outputLabel,
154 OverlapRemovalTool=orTool,
155 JetKey = JetKey,
156 TauKey=tauKey,
157 TauLabel=tauLabel,
158 BJetLabel=bJetLabel,
159 )
160 acc.addEventAlgo(algOR, sequenceName="HION5Sequence")
161
162 # Thinning
163 thinningTool = acc.getPrimaryAndMerge(HION5Thinning(flags))
164
165 # setup the kernel
166 acc.addEventAlgo(
167 CompFactory.DerivationFramework.DerivationKernel(
168 name,
169 SkimmingTools = [skimmingTool],
170 ThinningTools = [thinningTool],
171 AugmentationTools = [],
172 ),
173 sequenceName="HION5Sequence")
174
175 return acc
176

◆ HION5SkimmingToolCfg()

python.HION5.HION5SkimmingToolCfg ( flags)
Configure the example skimming tool

Definition at line 10 of file HION5.py.

10def HION5SkimmingToolCfg(flags):
11 """Configure the example skimming tool"""
12 acc = ComponentAccumulator()
13
14 # added: DF-prefixed jet containers to ExtraData
15 JetColl = flags.HeavyIon.HIJetPrefix
16
17 ExtraData = []
18 ExtraData += ['xAOD::MuonContainer/Muons']
19 ExtraData += ['xAOD::ElectronContainer/Electrons']
20 ExtraData += ['xAOD::PhotonContainer/Photons']
21 ExtraData += ['xAOD::TrackParticleContainer/InDetTrackParticles']
22 ExtraData += ['xAOD::JetContainer/'+JetColl+'AntiKt2HIJets']
23 ExtraData += ['xAOD::JetContainer/'+JetColl+'AntiKt4HIJets']
24
25 acc.addSequence( seqAND("HION5Sequence") )
26 acc.getSequence("HION5Sequence").ExtraDataForDynamicConsumers = ExtraData
27 acc.getSequence("HION5Sequence").ProcessDynamicDataDependencies = True
28 filterList = []
29
30 req_electrons = 'count( ( Electrons.pt > 15*GeV ) && ( abs(Electrons.eta) < 2.5) )>0'
31 req_muons = 'count( Muons.DFCommonMuonPassPreselection && (Muons.pt > 15*GeV) && ( abs(Muons.eta) < 2.7))>0'
32 req_photons = 'count( Photons.DFCommonPhotonsIsEMLoose && (Photons.pt > 30*GeV) ) > 0'
33 req_total = '(' + req_electrons + ' || ' + req_muons + ' || ' + req_photons + ')'
34 from DerivationFrameworkTools.DerivationFrameworkToolsConfig import (
35 xAODStringSkimmingToolCfg)
36 HION5StringSkimmingTool = acc.addPublicTool(acc.getPrimaryAndMerge(
37 xAODStringSkimmingToolCfg(flags, name = "HION5StringSkimmingTool",
38 expression = req_total)))
39 filterList += [HION5StringSkimmingTool]
40
41 from DerivationFrameworkHI import ListTriggers
42 triggers = ListTriggers.HION5SkimmingTriggers()
43 HION5TriggerSkimmingTool = CompFactory.DerivationFramework.TriggerSkimmingTool(
44 name = "HION5TriggerSkimmingTool", TriggerListOR = triggers)
45 acc.addPublicTool(HION5TriggerSkimmingTool)
46 filterList += [HION5TriggerSkimmingTool]
47
48 HION5SkimmingTool = CompFactory.DerivationFramework.FilterCombinationAND(
49 name="HION5SkimmingTool", FilterList=filterList)
50 acc.addPublicTool(HION5SkimmingTool, primary = True)
51 return acc
52

◆ HION5Thinning()

python.HION5.HION5Thinning ( flags)

Definition at line 53 of file HION5.py.

53def HION5Thinning(flags):
54 from DerivationFrameworkInDet.InDetToolsConfig import TrackParticleThinningCfg,JetTrackParticleThinningCfg
55 acc = ComponentAccumulator()
56
57 # added: DF-prefixed jet collection names
58 JetColl = flags.HeavyIon.HIJetPrefix
59
60 # find collision type
61 from CoolConvUtilities.ParticleTypeUtil import getTypeForRun
62 info=getTypeForRun(flags.Input.RunNumbers[0])
63 isOxygenOxygenCollision = False
64 if (info.getBeam1Type() == 8) or (info.getBeam2Type() == 8):
65 isOxygenOxygenCollision = True
66
67 pTCut = 0.9
68 if isOxygenOxygenCollision:
69 pTCut = 0.5
70
71 track_thinning_expression = f"InDetTrackParticles.pt > {pTCut}*GeV"
72 TrackParticleThinningTool = acc.getPrimaryAndMerge(TrackParticleThinningCfg(
73 flags,
74 name = "PHYSTrackParticleThinningTool",
75 StreamName = "StreamDAOD_HION5",
76 SelectionString = track_thinning_expression,
77 InDetTrackParticlesKey = "InDetTrackParticles"))
78
79 AntiKt2HIJetsThinningTool = acc.getPrimaryAndMerge(JetTrackParticleThinningCfg(
80 flags,
81 name = "AntiKt2HIJetsThinningTool",
82 StreamName = "StreamDAOD_HION5",
83 JetKey = JetColl+"AntiKt2HIJets",
84 SelectionString = JetColl+"AntiKt2HIJets.pt > 15*GeV",
85 InDetTrackParticlesKey = "InDetTrackParticles"))
86
87 AntiKt4HIJetsThinningTool = acc.getPrimaryAndMerge(JetTrackParticleThinningCfg(
88 flags,
89 name = "AntiKt4HIJetsThinningTool",
90 StreamName = "StreamDAOD_HION5",
91 JetKey = JetColl+"AntiKt4HIJets",
92 SelectionString = JetColl+"AntiKt4HIJets.pt > 15*GeV",
93 InDetTrackParticlesKey = "InDetTrackParticles"))
94
95 acc.addPublicTool(TrackParticleThinningTool,primary = True)
96 acc.addPublicTool(AntiKt2HIJetsThinningTool)
97 acc.addPublicTool(AntiKt4HIJetsThinningTool)
98
99 return acc
100