29 """Jet reconstruction needed for HIGG1D1"""
35 PrefixForHggCollection =
"Hgg"
36 HggVertexContainerName = PrefixForHggCollection+
"PrimaryVertices"
37 CustomPFJetContainerName =
"AntiKt4EMPFlowCustomVtxJets"
39 from JetRecConfig.StandardJetConstits
import stdInputExtDic, JetInputExternal,JetInputConstit, JetInputConstitSeq, JetConstitModifier, xAODType
40 from JetRecConfig.StandardSmallRJets
import AntiKt4EMPFlow
41 from JetRecConfig.JetDefinition
import JetDefinition
42 from JetRecTools
import JetRecToolsConfig
as jrtcfg
43 from JetMomentTools
import JetMomentToolsConfig
44 from JetRecConfig.StandardJetConstits
import stdConstitDic, stdContitModifDic
45 from JetRecConfig.StandardJetContext
import propFromContext, inputsFromContext
46 from JetRecConfig.JetInputConfig
import buildEventShapeAlg
49 jetContextName =
'CustomVtx'
50 context = ConfigFlags.Jet.Context[jetContextName]
52 def replaceItems(tup,orgName,newName):
54 for i, item
in enumerate(newList):
56 newList[i] = item.replace(orgName,newName)
57 print(
"Updated ", orgName,
" to ", newName )
59 print(
"Failed to update ", orgName,
" to ", newName )
62 def updateCalibSequence(tup):
64 if ConfigFlags.GeoModel.Run
is LHCPeriod.Run3:
65 rhoname =
"Kt4EMPFlowNeutEventShape"
67 rhoname =
"Kt4EMPFlowCustomVtxEventShape"
69 for i, item
in enumerate(newList):
71 calibspecs = item.split(
":")
72 calib, calibcontext, data_type = calibspecs[:3]
75 calibseq = calibspecs[3]
76 pvname = HggVertexContainerName
77 finalCalibString = f
"CalibCustomVtx:{calibcontext}:{data_type}:{calibseq}:{rhoname}:{pvname}"
78 if len(calibspecs)>6: finalCalibString = f
"{finalCalibString}:{calibspecs[6]}"
79 newList[i] = finalCalibString
80 print(finalCalibString)
82 print(
"Failed to update calib sequence" )
87 modsCustomVtx = AntiKt4EMPFlow.modifiers
88 modsCustomVtx = updateCalibSequence(modsCustomVtx)
89 modsCustomVtx = replaceItems(modsCustomVtx,
"TrackMoments",
"TrackMomentsCustomVtx")
90 modsCustomVtx = replaceItems(modsCustomVtx,
"TrackSumMoments",
"TrackSumMomentsCustomVtx")
91 modsCustomVtx = replaceItems(modsCustomVtx,
"JVF",
"JVFCustomVtx")
92 modsCustomVtx = replaceItems(modsCustomVtx,
"JVT",
"JVTCustomVtx")
93 modsCustomVtx = replaceItems(modsCustomVtx,
"Charge",
"ChargeCustomVtx")
95 ghostCustomVtx = AntiKt4EMPFlow.ghostdefs
98 stdConstitDic[
"TrackCustomVtx"] = JetInputConstit(
"TrackCustomVtx", xAODType.TrackParticle,
"JetSelectedTracksCustomVtx" )
101 stdConstitDic[
"GPFlowCustomVtx"] = JetInputConstitSeq(
"GPFlowCustomVtx", xAODType.FlowElement,[
"CorrectPFOCustomVtx",
"CHSCustomVtx"] ,
'GlobalParticleFlowObjects',
'CHSGCustomVtxParticleFlowObjects',
104 stdContitModifDic[
"CorrectPFOCustomVtx"] = JetConstitModifier(
"CorrectPFOCustomVtx",
"CorrectPFOTool",
107 WeightPFOTool= CompFactory.getComp(
"CP::WeightPFOTool")(
"weightPFO") )
110 stdContitModifDic[
"CHSCustomVtx"] = JetConstitModifier(
"CHSCustomVtx",
"ChargedHadronSubtractionTool",
114 UseTrackToVertexTool=
True,
119 AntiKt4EMPFlowCustomVtx = JetDefinition(
"AntiKt",0.4,stdConstitDic.GPFlowCustomVtx,
121 context = jetContextName,
122 ghostdefs = ghostCustomVtx,
123 modifiers = modsCustomVtx+(
"JetPtAssociation",
"QGTaggingCustomVtx",
"fJVTCustomVtx",
"NNJVTCustomVtx",
"CaloEnergiesClus",
"JetPileupLabel"),
127 def getUsedInVertexFitTrackDecoratorAlgCustomVtx(jetdef, jetmod):
128 """ Create the alg to decorate the used-in-fit information for AMVF """
129 context = jetdef._contextDic
131 from InDetUsedInFitTrackDecoratorTool.UsedInVertexFitTrackDecoratorConfig
import getUsedInVertexFitTrackDecoratorAlg
133 vertexDeco=
'TTVA_AMVFVertices_forHiggs',
134 weightDeco=
'TTVA_AMVFWeights_forHiggs')
139 stdInputExtDic[context[
'Vertices']] = JetInputExternal( context[
'Vertices'], xAODType.Vertex )
141 stdInputExtDic[
"JetSelectedTracksCustomVtx"] = JetInputExternal(
"JetSelectedTracksCustomVtx", xAODType.TrackParticle,
142 prereqs= [ f
"input:{context['Tracks']}" ],
143 algoBuilder =
lambda jdef,_ : jrtcfg.getTrackSelAlg(jdef, trackSelOpt=
False,
144 DecorDeps=[
"TTVA_AMVFWeights_forHiggs",
"TTVA_AMVFVertices_forHiggs"] )
147 stdInputExtDic[
"JetTrackUsedInFitDecoCustomVtx"] = JetInputExternal(
"JetTrackUsedInFitDecoCustomVtx", xAODType.TrackParticle,
148 prereqs= [ f
"input:{context['Tracks']}" ,
149 f
"input:{context['Vertices']}"],
150 algoBuilder = getUsedInVertexFitTrackDecoratorAlgCustomVtx
153 stdInputExtDic[
"JetTrackVtxAssocCustomVtx"] = JetInputExternal(
"JetTrackVtxAssocCustomVtx", xAODType.TrackParticle,
154 algoBuilder =
lambda jdef,_ : jrtcfg.getJetTrackVtxAlg(jdef._contextDic, algname=
"jetTVACustomVtx",
155 WorkingPoint=
"Nonprompt_All_MaxWeight",
156 AMVFVerticesDeco=
'TTVA_AMVFVertices_forHiggs',
157 AMVFWeightsDeco=
'TTVA_AMVFWeights_forHiggs'),
158 prereqs = [
"input:JetTrackUsedInFitDecoCustomVtx", f
"input:{context['Vertices']}" ] )
160 stdInputExtDic[
"EventDensityCustomVtx"] = JetInputExternal(
"EventDensityCustomVtx",
"EventShape", algoBuilder = buildEventShapeAlg,
161 containername =
lambda jetdef, _ :
"Kt4"+jetdef.inputdef.label+
"CustomVtxEventShape",
162 prereqs =
lambda jetdef : [
"input:"+jetdef.inputdef.name] )
164 from JetRecConfig.StandardJetMods
import stdJetModifiers
165 from JetRecConfig.JetDefinition
import JetModifier
166 from JetCalibTools
import JetCalibToolsConfig
168 stdJetModifiers.update(
170 CalibCustomVtx = JetModifier(
"JetCalibrationTool",
"jetcalib_jetcoll_calibseqCustomVtx",
171 createfn=JetCalibToolsConfig.getJetCalibToolFromString,
175 JVFCustomVtx = JetModifier(
"JetVertexFractionTool",
"jvfCustomVtx",
177 modspec =
"CustomVtx",
178 prereqs = [
"input:JetTrackVtxAssocCustomVtx",
"mod:TrackMomentsCustomVtx", f
"input:{context['Vertices']}"] ,
179 JetContainer = CustomPFJetContainerName),
181 JVTCustomVtx = JetModifier(
"JetVertexTaggerTool",
"jvtCustomVtx",
183 modspec =
"CustomVtx",
184 prereqs = [
"mod:JVFCustomVtx" ],JetContainer = CustomPFJetContainerName),
186 NNJVTCustomVtx = JetModifier(
"JetVertexNNTagger",
"nnjvtCustomVtx",
188 prereqs = [
"mod:JVFCustomVtx" ],JetContainer = CustomPFJetContainerName),
190 OriginSetPVCustomVtx = JetModifier(
"JetOriginCorrectionTool",
"origin_setpvCustomVtx",
191 modspec =
"CustomVtx",
192 prereqs = [
"mod:JVFCustomVtx" ],JetContainer = CustomPFJetContainerName, OnlyAssignPV=
True),
194 TrackMomentsCustomVtx = JetModifier(
"JetTrackMomentsTool",
"trkmomsCustomVtx",
196 modspec =
"CustomVtx",
197 prereqs = [
"input:JetTrackVtxAssocCustomVtx",
"ghost:Track" ],JetContainer = CustomPFJetContainerName),
199 TrackSumMomentsCustomVtx = JetModifier(
"JetTrackSumMomentsTool",
"trksummomsCustomVtx",
201 modspec =
"CustomVtx",
202 prereqs = [
"input:JetTrackVtxAssocCustomVtx",
"ghost:Track" ],JetContainer = CustomPFJetContainerName),
204 ChargeCustomVtx = JetModifier(
"JetChargeTool",
"jetchargeCustomVtx",
205 prereqs = [
"ghost:Track" ]),
208 QGTaggingCustomVtx = JetModifier(
"JetQGTaggerVariableTool",
"qgtaggingCustomVtx",
210 modspec =
"CustomVtx",
211 prereqs =
lambda _,jdef :
212 [
"input:JetTrackVtxAssocCustomVtx",
"mod:TrackMomentsCustomVtx"] +
213 ([
"mod:JetPtAssociation"]
if not jdef._cflags.Input.isMC
else []),
214 JetContainer = CustomPFJetContainerName),
216 fJVTCustomVtx = JetModifier(
"JetForwardPFlowJvtTool",
"fJVTCustomVtx",
218 modspec =
"CustomVtx",
219 prereqs = [
"input:JetTrackVtxAssocCustomVtx",
"input:EventDensityCustomVtx",f
"input:{context['Vertices']}",
"mod:NNJVTCustomVtx"],
220 JetContainer = CustomPFJetContainerName),
223 from JetRecConfig.JetRecConfig
import JetRecCfg
225 acc.merge(
JetRecCfg(ConfigFlags,AntiKt4EMPFlowCustomVtx))