11 """Configure the example skimming tool"""
12 acc = ComponentAccumulator()
15 JetColl = flags.HeavyIon.HIJetPrefix
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']
25 acc.addSequence( seqAND(
"HION5Sequence") )
26 acc.getSequence(
"HION5Sequence").ExtraDataForDynamicConsumers = ExtraData
27 acc.getSequence(
"HION5Sequence").ProcessDynamicDataDependencies =
True
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]
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]
48 HION5SkimmingTool = CompFactory.DerivationFramework.FilterCombinationAND(
49 name=
"HION5SkimmingTool", FilterList=filterList)
50 acc.addPublicTool(HION5SkimmingTool, primary =
True)
54 from DerivationFrameworkInDet.InDetToolsConfig
import TrackParticleThinningCfg,JetTrackParticleThinningCfg
55 acc = ComponentAccumulator()
58 JetColl = flags.HeavyIon.HIJetPrefix
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
68 if isOxygenOxygenCollision:
71 track_thinning_expression = f
"InDetTrackParticles.pt > {pTCut}*GeV"
72 TrackParticleThinningTool = acc.getPrimaryAndMerge(TrackParticleThinningCfg(
74 name =
"PHYSTrackParticleThinningTool",
75 StreamName =
"StreamDAOD_HION5",
76 SelectionString = track_thinning_expression,
77 InDetTrackParticlesKey =
"InDetTrackParticles"))
79 AntiKt2HIJetsThinningTool = acc.getPrimaryAndMerge(JetTrackParticleThinningCfg(
81 name =
"AntiKt2HIJetsThinningTool",
82 StreamName =
"StreamDAOD_HION5",
83 JetKey = JetColl+
"AntiKt2HIJets",
84 SelectionString = JetColl+
"AntiKt2HIJets.pt > 15*GeV",
85 InDetTrackParticlesKey =
"InDetTrackParticles"))
87 AntiKt4HIJetsThinningTool = acc.getPrimaryAndMerge(JetTrackParticleThinningCfg(
89 name =
"AntiKt4HIJetsThinningTool",
90 StreamName =
"StreamDAOD_HION5",
91 JetKey = JetColl+
"AntiKt4HIJets",
92 SelectionString = JetColl+
"AntiKt4HIJets.pt > 15*GeV",
93 InDetTrackParticlesKey =
"InDetTrackParticles"))
95 acc.addPublicTool(TrackParticleThinningTool,primary =
True)
96 acc.addPublicTool(AntiKt2HIJetsThinningTool)
97 acc.addPublicTool(AntiKt4HIJetsThinningTool)
102 """Configure the derivation framework driving algorithm (kernel)
104 acc = ComponentAccumulator()
107 JetColl = flags.HeavyIon.HIJetPrefix
108 JetKey = JetColl +
'AntiKt4HIJets'
111 from JetRecConfig.StandardSmallRJets
import AntiKt4PV0Track
112 from JetRecConfig.JetRecConfig
import JetRecCfg
114 jetList = [AntiKt4PV0Track]
116 acc.merge(JetRecCfg(flags, jd))
120 from DerivationFrameworkHI.HION7
import PhysAugmentationsHION7Cfg
121 acc.merge(PhysAugmentationsHION7Cfg(flags))
126 from AssociationUtils.AssociationUtilsConfig
import OverlapRemovalToolCfg
128 outputLabel =
"DFCommonJets_passOR_HI"
132 orTool = acc.popToolsAndMerge(
133 OverlapRemovalToolCfg(
134 flags, outputLabel=outputLabel, bJetLabel=bJetLabel, doTaus=
False
137 algOR = CompFactory.OverlapRemovalGenUseAlg(
138 "OverlapRemovalGenUseAlg",
139 OverlapLabel=outputLabel,
140 OverlapRemovalTool=orTool,
146 acc.addEventAlgo(algOR)
156 CompFactory.DerivationFramework.DerivationKernel(
158 SkimmingTools = [skimmingTool],
159 ThinningTools = [thinningTool],
160 AugmentationTools = [],
166 acc = ComponentAccumulator()
170 JetColl = flags.HeavyIon.HIJetPrefix
171 from HIJetRec.HIJetRecConfigCA
import HIJetRecCfg
172 acc.merge(HIJetRecCfg(flags))
175 if flags.HeavyIon.doHIBTagging:
176 from BTagging.FlavorTaggingConfig
import FlavorTaggingCfg
177 acc.merge(FlavorTaggingCfg(flags, JetColl+
"AntiKt4HIJets"))
178 from BTagging.TrackLeptonConfig
import TrackLeptonDecorationCfg
179 acc.merge(TrackLeptonDecorationCfg(flags))
181 from DerivationFrameworkEGamma.PhotonsCPDetailedContent
import PhotonsCPDetailedContent
182 from DerivationFrameworkEGamma.ElectronsCPDetailedContent
import ExtraElectronShowerShapes,ExtraElectronGSFVar
184 from DerivationFrameworkPhys.TriggerListsHelper
import TriggerListsHelper
185 HION5TriggerListsHelper = TriggerListsHelper(flags)
187 acc.merge(
HION5KernelCfg(flags, name=
"HION5Kernel", StreamName=
"StreamDAOD_HION5", TriggerListsHelper = HION5TriggerListsHelper,))
190 from OutputStreamAthenaPool.OutputStreamConfig
import OutputStreamCfg
191 from xAODMetaDataCnv.InfileMetaDataConfig
import SetupMetaDataForStreamCfg
192 from DerivationFrameworkCore.SlimmingHelper
import SlimmingHelper
193 from DerivationFrameworkHI
import ListSlimming
195 HION5SlimmingHelper =
SlimmingHelper(
"HION5SlimmingHelper", NamesAndTypes = flags.Input.TypedCollections, flags = flags)
196 HION5SlimmingHelper.AppendToDictionary = {
'EventInfo':
'xAOD::EventInfo',
'EventInfoAux':
'xAOD::EventAuxInfo',
197 'TruthEvents':
'xAOD::TruthEventContainer',
'TruthEventsAux':
'xAOD::TruthEventAuxContainer',
198 'MET_Truth':
'xAOD::MissingETContainer',
'MET_TruthAux':
'xAOD::MissingETAuxContainer',
199 'TruthLHEParticles':
'xAOD::TruthParticleContainer',
'TruthLHEParticlesAux':
'xAOD::TruthParticleAuxContainer',
200 'TruthElectrons':
'xAOD::TruthParticleContainer',
'TruthElectronsAux':
'xAOD::TruthParticleAuxContainer',
201 'TruthMuons':
'xAOD::TruthParticleContainer',
'TruthMuonsAux':
'xAOD::TruthParticleAuxContainer',
202 'TruthPhotons':
'xAOD::TruthParticleContainer',
'TruthPhotonsAux':
'xAOD::TruthParticleAuxContainer',
203 'TruthTaus':
'xAOD::TruthParticleContainer',
'TruthTausAux':
'xAOD::TruthParticleAuxContainer',
204 'TruthNeutrinos':
'xAOD::TruthParticleContainer',
'TruthNeutrinosAux':
'xAOD::TruthParticleAuxContainer',
205 'TruthBSM':
'xAOD::TruthParticleContainer',
'TruthBSMAux':
'xAOD::TruthParticleAuxContainer',
206 'TruthBoson':
'xAOD::TruthParticleContainer',
'TruthBosonAux':
'xAOD::TruthParticleAuxContainer',
207 'TruthBottom':
'xAOD::TruthParticleContainer',
'TruthBottomAux':
'xAOD::TruthParticleAuxContainer',
208 'TruthTop':
'xAOD::TruthParticleContainer',
'TruthTopAux':
'xAOD::TruthParticleAuxContainer',
209 'TruthForwardProtons':
'xAOD::TruthParticleContainer',
'TruthForwardProtonsAux':
'xAOD::TruthParticleAuxContainer',
210 'BornLeptons':
'xAOD::TruthParticleContainer',
'BornLeptonsAux':
'xAOD::TruthParticleAuxContainer',
211 'TruthBosonsWithDecayParticles':
'xAOD::TruthParticleContainer',
'TruthBosonsWithDecayParticlesAux':
'xAOD::TruthParticleAuxContainer',
212 'TruthBosonsWithDecayVertices':
'xAOD::TruthVertexContainer',
'TruthBosonsWithDecayVerticesAux':
'xAOD::TruthVertexAuxContainer',
213 'TruthBSMWithDecayParticles':
'xAOD::TruthParticleContainer',
'TruthBSMWithDecayParticlesAux':
'xAOD::TruthParticleAuxContainer',
214 'TruthBSMWithDecayVertices':
'xAOD::TruthVertexContainer',
'TruthBSMWithDecayVerticesAux':
'xAOD::TruthVertexAuxContainer',
215 'AntiKt4TruthDressedWZJets':
'xAOD::JetContainer',
'AntiKt4TruthDressedWZJetsAux':
'xAOD::JetAuxContainer',
216 'AntiKt10TruthSoftDropBeta100Zcut10Jets':
'xAOD::JetContainer',
'AntiKt10TruthSoftDropBeta100Zcut10JetsAux':
'xAOD::JetAuxContainer',
217 'MET_Track1000':
'xAOD::MissingETContainer',
'MET_Track1000Aux':
'xAOD::MissingETAuxContainer',
218 'MET_Track2000':
'xAOD::MissingETContainer',
'MET_Track2000Aux':
'xAOD::MissingETAuxContainer',
219 'MET_Track3000':
'xAOD::MissingETContainer',
'MET_Track3000Aux':
'xAOD::MissingETAuxContainer',
220 'MET_Track4000':
'xAOD::MissingETContainer',
'MET_Track4000Aux':
'xAOD::MissingETAuxContainer',
221 'MET_Track5000':
'xAOD::MissingETContainer',
'MET_Track5000Aux':
'xAOD::MissingETAuxContainer',
224 from DerivationFrameworkHI.TrackMET_config
import Cfg_METTrack
225 met_ptCutList = [1000,2000,3000,4000,5000]
227 for ptCut
in met_ptCutList:
228 acc.merge(Cfg_METTrack(flags, ptCut))
231 AllVariables += ListSlimming.HION5AllVariables(flags.Input.RunNumbers[0])
232 AllVariables += ListSlimming.HION5ExtraContainersTrigger()
235 from DerivationFrameworkFlavourTag
import FtagBaseContent
240 AllVariables += ListSlimming.HION5AllTruthVariables()
241 if flags.HeavyIon.doHIBTagging:
243 FtagBaseContent.add_truth_to_slimming_helper(HION5SlimmingHelper)
246 if flags.HeavyIon.doHIBTagging:
247 AllVariables += ListSlimming.HION7AllVarFromFTAG1()
249 HION5SlimmingHelper.SmartCollections = ListSlimming.HION5SmartCollections()
250 HION5SlimmingHelper.ExtraVariables = ListSlimming.HION5ExtraVariables()
251 HION5SlimmingHelper.ExtraVariables += PhotonsCPDetailedContent
252 HION5SlimmingHelper.ExtraVariables += ExtraElectronShowerShapes
253 HION5SlimmingHelper.ExtraVariables += ExtraElectronGSFVar
256 if flags.HeavyIon.doHIBTagging:
257 from DerivationFrameworkFlavourTag.FtagBaseContent
import add_common_augmentation
258 add_common_augmentation(flags, acc, HION5SlimmingHelper, JetColl+
"AntiKt4HIJets")
260 extra_AppendToDictionary = {}
261 FtagBaseContent.update_append_to_dictionary_in_slimming_helper(flags, HION5SlimmingHelper, extra_AppendToDictionary)
263 HION5SlimmingHelper.ExtraVariables += ListSlimming.HION7ExtraVarForBtag(JetColl)
264 FtagBaseContent.add_extra_variables_to_slimming_helper(flags, HION5SlimmingHelper)
266 HION5SlimmingHelper.AllVariables = AllVariables
269 HION5SlimmingHelper.IncludeEGammaTriggerContent =
True
271 HION5SlimmingHelper.IncludeMuonTriggerContent =
True
273 HION5ItemList = HION5SlimmingHelper.GetItemList()
276 HIJetRemovedBranches = ListSlimming.makeHIJetRemovedBranchList()
277 jet_var_str =
'.-'.join([
''] + HIJetRemovedBranches)
279 jetRlist = flags.HeavyIon.Jet.RValues
280 for jetR
in jetRlist:
281 output = [
"xAOD::JetContainer#"+JetColl+
"AntiKt"+
str(jetR)+
"HIJets",
282 "xAOD::JetAuxContainer#"+JetColl+
"AntiKt"+
str(jetR)+
"HIJetsAux.-PseudoJet"+jet_var_str]
283 HION5ItemList += output
285 acc.merge(OutputStreamCfg(flags,
"DAOD_HION5", ItemList=HION5ItemList, AcceptAlgs=[
"HION5Kernel"]))
286 acc.merge(SetupMetaDataForStreamCfg(flags,
"DAOD_HION5", AcceptAlgs=[
"HION5Kernel"], createMetadata=[MetadataCategory.CutFlowMetaData]))