CMS 3D CMS Logo

nano_cff.py
Go to the documentation of this file.
1 from __future__ import print_function
2 import FWCore.ParameterSet.Config as cms
23 from PhysicsTools.NanoAOD.met_cff import *
31 
32 nanoMetadata = cms.EDProducer("UniqueStringProducer",
33  strings = cms.PSet(
34  tag = cms.string("untagged"),
35  )
36 )
37 
38 linkedObjects = cms.EDProducer("PATObjectCrossLinker",
39  jets=cms.InputTag("finalJetsPuppi"),
40  muons=cms.InputTag("finalMuons"),
41  electrons=cms.InputTag("finalElectrons"),
42  lowPtElectrons=cms.InputTag("finalLowPtElectrons"),
43  taus=cms.InputTag("finalTaus"),
44  boostedTaus=cms.InputTag("finalBoostedTaus"),
45  photons=cms.InputTag("finalPhotons"),
46  vertices=cms.InputTag("slimmedSecondaryVertices")
47 )
48 
49 # Switch to AK4 CHS jets for Run-2
50 run2_nanoAOD_ANY.toModify(
51  linkedObjects, jets="finalJets"
52 )
53 
54 # boosted taus don't exist in 122X MINI
55 run3_nanoAOD_122.toModify(
56  linkedObjects, boostedTaus=None,
57 )
58 
59 lhcInfoTable = cms.EDProducer("LHCInfoProducer")
60 
61 nanoTableTaskCommon = cms.Task(
62  cms.Task(nanoMetadata),
63  jetPuppiTask, jetPuppiForMETTask, jetAK8Task,
64  extraFlagsProducersTask, muonTask, tauTask, boostedTauTask,
65  electronTask , lowPtElectronTask, photonTask,
66  vertexTask, isoTrackTask, jetAK8LepTask, # must be after all the leptons
67  softActivityTask,
68  cms.Task(linkedObjects),
69  jetPuppiTablesTask, jetAK8TablesTask,
70  muonTablesTask, fsrTablesTask, tauTablesTask, boostedTauTablesTask,
71  electronTablesTask, lowPtElectronTablesTask, photonTablesTask,
72  globalTablesTask, vertexTablesTask, metTablesTask, extraFlagsTableTask,
73  isoTrackTablesTask,softActivityTablesTask
74 )
75 
76 # Replace AK4 Puppi with AK4 CHS for Run-2
77 _nanoTableTaskCommonRun2 = nanoTableTaskCommon.copy()
78 _nanoTableTaskCommonRun2.replace(jetPuppiTask, jetTask)
79 _nanoTableTaskCommonRun2.replace(jetPuppiForMETTask, jetForMETTask)
80 _nanoTableTaskCommonRun2.replace(jetPuppiTablesTask, jetTablesTask)
81 run2_nanoAOD_ANY.toReplaceWith(
82  nanoTableTaskCommon, _nanoTableTaskCommonRun2
83 )
84 
85 nanoSequenceCommon = cms.Sequence(nanoTableTaskCommon)
86 
87 nanoSequenceOnlyFullSim = cms.Sequence(triggerObjectTablesTask)
88 nanoSequenceOnlyData = cms.Sequence(cms.Sequence(protonTablesTask) + lhcInfoTable)
89 
90 nanoSequence = cms.Sequence(nanoSequenceCommon + nanoSequenceOnlyData + nanoSequenceOnlyFullSim)
91 
92 nanoTableTaskFS = cms.Task(
93  genParticleTask, particleLevelTask, jetMCTask, muonMCTask, electronMCTask, lowPtElectronMCTask, photonMCTask,
94  tauMCTask, boostedTauMCTask,
95  metMCTable, ttbarCatMCProducersTask, globalTablesMCTask, ttbarCategoryTableTask,
96  genWeightsTableTask, genVertexTablesTask, genParticleTablesTask, genProtonTablesTask, particleLevelTablesTask
97 )
98 
99 nanoSequenceFS = cms.Sequence(nanoSequenceCommon + cms.Sequence(nanoTableTaskFS))
100 
101 # GenVertex only stored in newer MiniAOD
102 nanoSequenceMC = nanoSequenceFS.copy()
103 nanoSequenceMC.insert(nanoSequenceFS.index(nanoSequenceCommon)+1,nanoSequenceOnlyFullSim)
104 
105 # modifier which adds new tauIDs (currently only deepTauId2017v2p1 is being added)
106 import RecoTauTag.RecoTau.tools.runTauIdMVA as tauIdConfig
107 def nanoAOD_addTauIds(process, idsToRun=[]):
108  if idsToRun: #no-empty list of tauIDs to run
109  updatedTauName = "slimmedTausUpdated"
110  tauIdEmbedder = tauIdConfig.TauIDEmbedder(process, debug = False,
111  updatedTauName = updatedTauName,
112  postfix = "ForNano",
113  toKeep = idsToRun)
114  tauIdEmbedder.runTauID()
115  process.finalTaus.src = updatedTauName
116  #remember to adjust the selection and tables with added IDs
117 
118  process.tauTask.add( process.rerunMvaIsolationTaskForNano , process.patTauMVAIDsTask )
119 
120  return process
121 
122 def nanoAOD_addBoostedTauIds(process, idsToRun=[]):
123  if idsToRun: #no-empty list of tauIDs to run
124  updatedBoostedTauName = "slimmedTausBoostedNewID"
125  boostedTauIdEmbedder = tauIdConfig.TauIDEmbedder(process, debug = False,
126  originalTauName = "slimmedTausBoosted",
127  updatedTauName = updatedBoostedTauName,
128  postfix = "BoostedForNano",
129  toKeep = idsToRun)
130  boostedTauIdEmbedder.runTauID()
131  process.finalBoostedTaus.src = updatedBoostedTauName
132  #remember to adjust the selection and tables with added IDs
133 
134  process.boostedTauTask.add( process.rerunMvaIsolationTaskBoostedForNano, getattr(process, updatedBoostedTauName))
135 
136  return process
137 
138 def nanoAOD_addPNetToTaus(process, addPNetInfo=False, runPNetCHSAK4=False):
139  if addPNetInfo:
140  originalTauName = process.finalTaus.src.value()
141  updatedTauName = originalTauName+'WithPNet'
142  jetCollection = "updatedJets"
143  process.load('RecoBTag.ONNXRuntime.pfParticleNetFromMiniAODAK4_cff')
144  pnetTagName = "pfParticleNetFromMiniAODAK4CHSCentralJetTag"
145  pnetDiscriminators = [];
146  for tag in getattr(process,pnetTagName+"s").flav_names.value():
147  pnetDiscriminators.append(pnetTagName+"s:"+tag)
148 
149  # Define "hybridTau" producer
150  from PhysicsTools.PatAlgos.patTauHybridProducer_cfi import patTauHybridProducer
151  setattr(process, updatedTauName, patTauHybridProducer.clone(
152  src = originalTauName,
153  jetSource = jetCollection,
154  dRMax = 0.4,
155  jetPtMin = 15,
156  jetEtaMax = 2.5,
157  pnetLabel = pnetTagName+"s",
158  pnetScoreNames = pnetDiscriminators,
159  tauScoreMin = -1,
160  vsJetMin = 0.05,
161  checkTauScoreIsBest = False,
162  chargeAssignmentProbMin = 0.2,
163  addGenJetMatch = False,
164  genJetMatch = ""
165  ))
166  process.finalTaus.src = updatedTauName
167 
168  # run PNet for CHS AK4 jets if requested
169  if runPNetCHSAK4:
170  from PhysicsTools.NanoAOD.jetsAK4_CHS_cff import nanoAOD_addDeepInfoAK4CHS
171  process = nanoAOD_addDeepInfoAK4CHS(process,
172  addDeepBTag = False,
173  addDeepFlavour = False,
174  addParticleNet = True
175  )
176 
177  #remember to adjust the selection and tables with added IDs
178 
179  process.tauTask.add(process.jetTask, getattr(process, updatedTauName))
180 
181  return process
182 
184 def nanoAOD_activateVID(process):
185 
186  switchOnVIDElectronIdProducer(process,DataFormat.MiniAOD,electronTask)
187  for modname in electron_id_modules_WorkingPoints_nanoAOD.modules:
188  setupAllVIDIdsInModule(process,modname,setupVIDElectronSelection)
189 
190  process.electronTask.add( process.egmGsfElectronIDTask )
191 
192  switchOnVIDPhotonIdProducer(process,DataFormat.MiniAOD,photonTask) # do not call this to avoid resetting photon IDs in VID, if called before inside makePuppiesFromMiniAOD
193  for modname in photon_id_modules_WorkingPoints_nanoAOD.modules:
194  setupAllVIDIdsInModule(process,modname,setupVIDPhotonSelection)
195 
196  process.photonTask.add( process.egmPhotonIDTask )
197 
198  return process
199 
201 
202  process = nanoAOD_activateVID(process)
203 
204  run2_nanoAOD_106Xv2.toModify(
205  nanoAOD_addDeepInfoAK4CHS_switch, nanoAOD_addParticleNet_switch=True,
206  nanoAOD_addRobustParTAK4Tag_switch=True,
207  )
208 
209  # This function is defined in jetsAK4_Puppi_cff.py
210  process = nanoAOD_addDeepInfoAK4(process,
211  addParticleNet=nanoAOD_addDeepInfoAK4_switch.nanoAOD_addParticleNet_switch,
212  addRobustParTAK4=nanoAOD_addDeepInfoAK4_switch.nanoAOD_addRobustParTAK4Tag_switch
213  )
214 
215  # This function is defined in jetsAK4_CHS_cff.py
216  process = nanoAOD_addDeepInfoAK4CHS(process,
217  addDeepBTag=nanoAOD_addDeepInfoAK4CHS_switch.nanoAOD_addDeepBTag_switch,
218  addDeepFlavour=nanoAOD_addDeepInfoAK4CHS_switch.nanoAOD_addDeepFlavourTag_switch,
219  addParticleNet=nanoAOD_addDeepInfoAK4CHS_switch.nanoAOD_addParticleNet_switch,
220  addRobustParTAK4=nanoAOD_addDeepInfoAK4CHS_switch.nanoAOD_addRobustParTAK4Tag_switch
221  )
222 
223  # This function is defined in jetsAK8_cff.py
224  process = nanoAOD_addDeepInfoAK8(process,
225  addDeepBTag=nanoAOD_addDeepInfoAK8_switch.nanoAOD_addDeepBTag_switch,
226  addDeepBoostedJet=nanoAOD_addDeepInfoAK8_switch.nanoAOD_addDeepBoostedJet_switch,
227  addDeepDoubleX=nanoAOD_addDeepInfoAK8_switch.nanoAOD_addDeepDoubleX_switch,
228  addDeepDoubleXV2=nanoAOD_addDeepInfoAK8_switch.nanoAOD_addDeepDoubleXV2_switch,
229  addParticleNetMassLegacy=nanoAOD_addDeepInfoAK8_switch.nanoAOD_addParticleNetMassLegacy_switch,
230  addParticleNet=nanoAOD_addDeepInfoAK8_switch.nanoAOD_addParticleNet_switch,
231  jecPayload=nanoAOD_addDeepInfoAK8_switch.jecPayload
232  )
233 
234  nanoAOD_tau_switch = cms.PSet(
235  idsToAdd = cms.vstring(),
236  runPNetAK4 = cms.bool(False),
237  addPNet = cms.bool(True)
238  )
239  (run2_nanoAOD_106Xv2 | run3_nanoAOD_122).toModify(
240  nanoAOD_tau_switch, idsToAdd = ["deepTau2018v2p5"]
241  ).toModify(
242  process, lambda p : nanoAOD_addTauIds(p, nanoAOD_tau_switch.idsToAdd.value())
243  )
244  # Add PNet info to taus
245  # enable rerun of PNet for CHS jets for early run3 eras
246  # (it is rerun for run2 within jet tasks while is not needed for newer
247  # run3 eras as it is present in miniAOD)
248  (run3_nanoAOD_122 | run3_nanoAOD_124).toModify(
249  nanoAOD_tau_switch, runPNetAK4 = True
250  )
251  nanoAOD_addPNetToTaus(process,
252  addPNetInfo = nanoAOD_tau_switch.addPNet.value(),
253  runPNetCHSAK4 = nanoAOD_tau_switch.runPNetAK4.value()
254  )
255  nanoAOD_boostedTau_switch = cms.PSet(
256  idsToAdd = cms.vstring()
257  )
258  run2_nanoAOD_106Xv2.toModify(
259  nanoAOD_boostedTau_switch, idsToAdd = ["2017v2", "dR0p32017v2", "newDM2017v2","againstEle2018"]
260  ).toModify(
261  process, lambda p : nanoAOD_addBoostedTauIds(p, nanoAOD_boostedTau_switch.idsToAdd.value())
262  )
263 
264  return process
265 
266 
268  pdgSelection="?(abs(pdgId) == 11|| abs(pdgId)==13 || abs(pdgId)==15 ||abs(pdgId)== 12 || abs(pdgId)== 14 || abs(pdgId)== 16|| abs(pdgId)== 24|| pdgId== 23)"
269  # Keep precision same as default RECO for selected particles
270  ptPrecision="{}?{}:{}".format(pdgSelection, CandVars.pt.precision.value(),genParticleTable.variables.pt.precision.value())
271  process.genParticleTable.variables.pt.precision=cms.string(ptPrecision)
272  phiPrecision="{} ? {} : {}".format(pdgSelection, CandVars.phi.precision.value(), genParticleTable.variables.phi.precision.value())
273  process.genParticleTable.variables.phi.precision=cms.string(phiPrecision)
274  etaPrecision="{} ? {} : {}".format(pdgSelection, CandVars.eta.precision.value(), genParticleTable.variables.eta.precision.value())
275  process.genParticleTable.variables.eta.precision=cms.string(etaPrecision)
276  return process
277 
279  process.nanoTableTaskCommon.add(process.l1TablesTask)
280  process = setL1NanoToReduced(process)
281  return process
282 
284  process.nanoTableTaskCommon.add(process.l1TablesTask)
285  return process
286 
287 
290 
def switchOnVIDElectronIdProducer(process, dataFormat, task=None)
Electrons.
Definition: vid_id_tools.py:66
def nanoL1TrigObjCustomizeFull(process)
Definition: nano_cff.py:283
def nanoAOD_addDeepInfoAK4(process, addParticleNet, addRobustParTAK4=False)
muon DPG NANO flavour sequences and customize functions
def setupAllVIDIdsInModule(process, id_module_name, setupFunction, patProducer=None, addUserData=True, task=None)
Definition: vid_id_tools.py:49
def nanoAOD_activateVID(process)
Definition: nano_cff.py:184
def nanoWmassGenCustomize(process)
increasing the precision of selected GenParticles.
Definition: nano_cff.py:267
def nanoAOD_customizeCommon(process)
Definition: nano_cff.py:200
def nanoAOD_addDeepInfoAK4CHS(process, addDeepBTag, addDeepFlavour, addParticleNet, addRobustParTAK4=False)
def nanoAOD_addTauIds(process, idsToRun=[])
Definition: nano_cff.py:107
def nanoAOD_addDeepInfoAK8(process, addDeepBTag, addDeepBoostedJet, addDeepDoubleX, addDeepDoubleXV2, addParticleNetMassLegacy, addParticleNet, jecPayload)
Definition: jetsAK8_cff.py:218
def nanoAOD_addBoostedTauIds(process, idsToRun=[])
Definition: nano_cff.py:122
def switchOnVIDPhotonIdProducer(process, dataFormat, task=None)
Photons.
def nanoL1TrigObjCustomize(process)
Definition: nano_cff.py:278
def nanoAOD_addPNetToTaus(process, addPNetInfo=False, runPNetCHSAK4=False)
Definition: nano_cff.py:138
def setL1NanoToReduced(process)
Definition: l1trig_cff.py:159