1 from __future__
import print_function
2 import FWCore.ParameterSet.Config
as cms
20 from Configuration.Eras.Modifier_run2_miniAOD_80XLegacy_cff
import run2_miniAOD_80XLegacy
21 from Configuration.Eras.Modifier_run2_nanoAOD_94X2016_cff
import run2_nanoAOD_94X2016
22 from Configuration.Eras.Modifier_run2_nanoAOD_94XMiniAODv1_cff
import run2_nanoAOD_94XMiniAODv1
23 from Configuration.Eras.Modifier_run2_nanoAOD_94XMiniAODv2_cff
import run2_nanoAOD_94XMiniAODv2
24 from Configuration.Eras.Modifier_run2_nanoAOD_102Xv1_cff
import run2_nanoAOD_102Xv1
25 from Configuration.Eras.Modifier_run2_nanoAOD_106Xv1_cff
import run2_nanoAOD_106Xv1
26 from Configuration.Eras.Modifier_run2_miniAOD_devel_cff
import run2_miniAOD_devel
27 from Configuration.Eras.Modifier_run2_tau_ul_2016_cff
import run2_tau_ul_2016
28 from Configuration.Eras.Modifier_run2_tau_ul_2018_cff
import run2_tau_ul_2018
30 nanoMetadata = cms.EDProducer(
"UniqueStringProducer",
32 tag = cms.string(
"untagged"),
36 linkedObjects = cms.EDProducer(
"PATObjectCrossLinker",
37 jets=cms.InputTag(
"finalJets"),
38 muons=cms.InputTag(
"finalMuons"),
39 electrons=cms.InputTag(
"finalElectrons"),
40 taus=cms.InputTag(
"finalTaus"),
41 photons=cms.InputTag(
"finalPhotons"),
44 simpleCleanerTable = cms.EDProducer(
"NanoAODSimpleCrossCleaner",
45 name=cms.string(
"cleanmask"),
46 doc=cms.string(
"simple cleaning mask with priority to leptons"),
47 jets=cms.InputTag(
"linkedObjects",
"jets"),
48 muons=cms.InputTag(
"linkedObjects",
"muons"),
49 electrons=cms.InputTag(
"linkedObjects",
"electrons"),
50 taus=cms.InputTag(
"linkedObjects",
"taus"),
51 photons=cms.InputTag(
"linkedObjects",
"photons"),
52 jetSel=cms.string(
"pt>15"),
53 muonSel=cms.string(
"track.isNonnull && isLooseMuon && isPFMuon && innerTrack.validFraction >= 0.49 && ( isGlobalMuon && globalTrack.normalizedChi2 < 3 && combinedQuality.chi2LocalPosition < 12 && combinedQuality.trkKink < 20 && segmentCompatibility >= 0.303 || segmentCompatibility >= 0.451 )"),
54 electronSel=cms.string(
""),
55 tauSel=cms.string(
""),
56 photonSel=cms.string(
""),
57 jetName=cms.string(
"Jet"),muonName=cms.string(
"Muon"),electronName=cms.string(
"Electron"),
58 tauName=cms.string(
"Tau"),photonName=cms.string(
"Photon")
61 btagSFdir=
"PhysicsTools/NanoAOD/data/btagSF/" 63 btagWeightTable = cms.EDProducer(
"BTagSFProducer",
64 src = cms.InputTag(
"linkedObjects",
"jets"),
65 cut = cms.string(
"pt > 25. && abs(eta) < 2.5"),
66 discNames = cms.vstring(
67 "pfCombinedInclusiveSecondaryVertexV2BJetTags",
68 "pfDeepCSVJetTags:probb+pfDeepCSVJetTags:probbb",
69 "pfCombinedMVAV2BJetTags" 71 discShortNames = cms.vstring(
76 weightFiles = cms.vstring(
77 btagSFdir+
"CSVv2_94XSF_V2_B_F.csv",
78 btagSFdir+
"DeepCSV_94XSF_V2_B_F.csv",
81 operatingPoints = cms.vstring(
"3",
"3",
"3"),
82 measurementTypesB = cms.vstring(
"iterativefit",
"iterativefit",
"iterativefit"),
83 measurementTypesC = cms.vstring(
"iterativefit",
"iterativefit",
"iterativefit"),
84 measurementTypesUDSG = cms.vstring(
"iterativefit",
"iterativefit",
"iterativefit"),
85 sysTypes = cms.vstring(
"central",
"central",
"central")
88 for modifier
in run2_miniAOD_80XLegacy, run2_nanoAOD_94X2016:
89 modifier.toModify(btagWeightTable,
90 cut = cms.string(
"pt > 25. && abs(eta) < 2.4"),
91 weightFiles = cms.vstring(
92 btagSFdir+
"CSVv2_Moriond17_B_H.csv",
94 btagSFdir+
"cMVAv2_Moriond17_B_H.csv" 99 genWeightsTable = cms.EDProducer(
"GenWeightsTableProducer",
100 genEvent = cms.InputTag(
"generator"),
101 genLumiInfoHeader = cms.InputTag(
"generator"),
102 lheInfo = cms.VInputTag(cms.InputTag(
"externalLHEProducer"), cms.InputTag(
"source")),
103 preferredPDFs = cms.VPSet(
104 cms.PSet( name = cms.string(
"PDF4LHC15_nnlo_30_pdfas"), lhaid = cms.uint32(91400) ),
105 cms.PSet( name = cms.string(
"NNPDF31_nnlo_hessian_pdfas"), lhaid = cms.uint32(306000) ),
106 cms.PSet( name = cms.string(
"NNPDF30_nlo_as_0118"), lhaid = cms.uint32(260000) ),
107 cms.PSet( name = cms.string(
"NNPDF30_lo_as_0130"), lhaid = cms.uint32(262000) ),
108 cms.PSet( name = cms.string(
"NNPDF30_nlo_nf_4_pdfas"), lhaid = cms.uint32(292000) ),
109 cms.PSet( name = cms.string(
"NNPDF30_nlo_nf_5_pdfas"), lhaid = cms.uint32(292200) ),
110 cms.PSet( name = cms.string(
"NNPDF31_lo_as_0130"), lhaid = cms.uint32(315200) ),
112 namedWeightIDs = cms.vstring(),
113 namedWeightLabels = cms.vstring(),
114 lheWeightPrecision = cms.int32(14),
115 maxPdfWeights = cms.uint32(150),
116 debug = cms.untracked.bool(
False),
118 lheInfoTable = cms.EDProducer(
"LHETablesProducer",
119 lheInfo = cms.VInputTag(cms.InputTag(
"externalLHEProducer"), cms.InputTag(
"source")),
120 precision = cms.int32(14),
121 storeLHEParticles = cms.bool(
True)
124 l1bits=cms.EDProducer(
"L1TriggerResultsConverter", src=cms.InputTag(
"gtStage2Digis"), legacyL1=cms.bool(
False),
125 storeUnprefireableBit=cms.bool(
True), src_ext=cms.InputTag(
"gtStage2Digis"))
126 (run2_miniAOD_80XLegacy | run2_nanoAOD_94X2016 | run2_nanoAOD_94XMiniAODv1 | run2_nanoAOD_94XMiniAODv2 | run2_nanoAOD_102Xv1).toModify(l1bits, storeUnprefireableBit=
False)
128 nanoSequenceCommon = cms.Sequence(
129 nanoMetadata + jetSequence + muonSequence + tauSequence + electronSequence+photonSequence+vertexSequence+
130 isoTrackSequence + jetLepSequence +
132 jetTables + muonTables + tauTables + electronTables + photonTables + globalTables +vertexTables+ metTables+simpleCleanerTable + isoTrackTables
134 nanoSequenceOnlyFullSim = cms.Sequence(triggerObjectTables + l1bits)
136 nanoSequence = cms.Sequence(nanoSequenceCommon + nanoSequenceOnlyFullSim)
138 nanoSequenceFS = cms.Sequence(genParticleSequence + particleLevelSequence + nanoSequenceCommon + jetMC + muonMC + electronMC + photonMC + tauMC + metMC + ttbarCatMCProducers + globalTablesMC + btagWeightTable + genWeightsTable + genParticleTables + particleLevelTables + lheInfoTable + ttbarCategoryTable )
140 nanoSequenceMC = nanoSequenceFS.copy()
141 nanoSequenceMC.insert(nanoSequenceFS.index(nanoSequenceCommon)+1,nanoSequenceOnlyFullSim)
144 for modifier
in run2_nanoAOD_94XMiniAODv1, run2_nanoAOD_94XMiniAODv2, run2_nanoAOD_102Xv1:
145 modifier.toModify(extraFlagsTable, variables= cms.PSet())
146 modifier.toModify(extraFlagsTable, variables =
dict(Flag_ecalBadCalibFilterV2 =
ExtVar(cms.InputTag(
"ecalBadCalibFilterNanoTagger"), bool, doc =
"Bad ECAL calib flag (updated xtal list)")))
149 import RecoTauTag.RecoTau.tools.runTauIdMVA
as tauIdConfig
151 updatedTauName =
"slimmedTausUpdated" 152 tauIdEmbedder = tauIdConfig.TauIDEmbedder(process, cms, debug =
False, updatedTauName = updatedTauName,
153 toKeep = [
"deepTau2017v2p1" ])
154 tauIdEmbedder.runTauID()
155 process.patTauMVAIDsSeq.insert(process.patTauMVAIDsSeq.index(getattr(process, updatedTauName)),
156 process.rerunMvaIsolationSequence)
161 _btagDiscriminators=[]
163 print(
"Updating process to run DeepCSV btag")
164 _btagDiscriminators += [
'pfDeepCSVJetTags:probb',
'pfDeepCSVJetTags:probbb',
'pfDeepCSVJetTags:probc']
166 print(
"Updating process to run DeepFlavour btag")
167 _btagDiscriminators += [
'pfDeepFlavourJetTags:probb',
'pfDeepFlavourJetTags:probbb',
'pfDeepFlavourJetTags:problepb',
'pfDeepFlavourJetTags:probc']
168 if len(_btagDiscriminators)==0:
return process
169 print(
"Will recalculate the following discriminators: "+
", ".
join(_btagDiscriminators))
172 jetSource = cms.InputTag(
'slimmedJets'),
173 jetCorrections = (
'AK4PFchs', cms.vstring([
'L1FastJet',
'L2Relative',
'L3Absolute',
'L2L3Residual']),
'None'),
174 btagDiscriminators = _btagDiscriminators,
175 postfix =
'WithDeepInfo',
177 process.load(
"Configuration.StandardSequences.MagneticField_cff")
178 process.jetCorrFactorsNano.src=
"selectedUpdatedPatJetsWithDeepInfo" 179 process.updatedJets.jetSource=
"selectedUpdatedPatJetsWithDeepInfo" 183 if addDeepMETProducer:
185 print(
"add DeepMET Producers")
186 process.load(
'RecoMET.METPUSubtraction.deepMETProducer_cfi')
187 process.deepMETsResolutionTune = process.deepMETProducer.clone()
188 process.deepMETsResponseTune = process.deepMETProducer.clone()
190 process.deepMETsResponseTune.graph_path = ResponseTune_Graph.value()
191 process.metTables += process.deepMetTables
194 from PhysicsTools.PatUtils.tools.runMETCorrectionsAndUncertainties
import runMetCorAndUncFromMiniAOD
198 nanoAOD_DeepMET_switch = cms.PSet(
199 nanoAOD_addDeepMET_switch = cms.untracked.bool(
True),
200 nanoAOD_produceDeepMET_switch = cms.untracked.bool(
False),
201 ResponseTune_Graph = cms.untracked.string(
'RecoMET/METPUSubtraction/data/deepmet/deepmet_resp_v1_2018.pb')
204 (~run2_miniAOD_devel).toModify(nanoAOD_DeepMET_switch, nanoAOD_produceDeepMET_switch = cms.untracked.bool(
True))
205 for modifier
in run2_miniAOD_80XLegacy, run2_nanoAOD_94X2016:
206 modifier.toModify(nanoAOD_DeepMET_switch, ResponseTune_Graph=cms.untracked.string(
"RecoMET/METPUSubtraction/data/deepmet/deepmet_resp_v1_2016.pb"))
207 if nanoAOD_DeepMET_switch.nanoAOD_addDeepMET_switch:
209 addDeepMETProducer=nanoAOD_DeepMET_switch.nanoAOD_produceDeepMET_switch,
210 ResponseTune_Graph=nanoAOD_DeepMET_switch.ResponseTune_Graph)
213 extractDeepMETs = nanoAOD_DeepMET_switch.nanoAOD_addDeepMET_switch
and not nanoAOD_DeepMET_switch.nanoAOD_produceDeepMET_switch
216 process.nanoSequenceCommon.insert(process.nanoSequenceCommon.index(process.jetSequence),cms.Sequence(process.fullPatMetSequence))
217 process.basicJetsForMetForT1METNano = process.basicJetsForMet.clone(
218 src = process.updatedJetsWithUserData.src,
220 type1JetPtThreshold = 0.0,
221 calcMuonSubtrRawPtAsValueMap = cms.bool(
True),
223 process.jetSequence.insert(process.jetSequence.index(process.updatedJetsWithUserData),cms.Sequence(process.basicJetsForMetForT1METNano))
224 process.updatedJetsWithUserData.userFloats.muonSubtrRawPt = cms.InputTag(
"basicJetsForMetForT1METNano:MuonSubtrRawPt")
225 process.corrT1METJetTable.src = process.finalJets.src
226 process.corrT1METJetTable.cut =
"pt<15 && abs(eta)<9.9" 227 for table
in process.jetTable, process.corrT1METJetTable:
228 table.variables.muonSubtrFactor =
Var(
"1-userFloat('muonSubtrRawPt')/(pt()*jecFactor('Uncorrected'))",float,doc=
"1-(muon-subtracted raw pt)/(raw pt)",precision=6)
229 process.metTables += process.corrT1METJetTable
240 for modname
in electron_id_modules_WorkingPoints_nanoAOD.modules:
242 process.electronSequence.insert(process.electronSequence.index(process.bitmapVIDForEle),process.egmGsfElectronIDSequence)
243 for modifier
in run2_miniAOD_80XLegacy, :
244 modifier.toModify(process.electronMVAValueMapProducer, srcMiniAOD =
"slimmedElectronsUpdated")
245 modifier.toModify(process.egmGsfElectronIDs, physicsObjectSrc =
"slimmedElectronsUpdated")
246 for modifier
in run2_nanoAOD_94XMiniAODv1,run2_nanoAOD_94XMiniAODv2,run2_nanoAOD_94X2016 ,run2_nanoAOD_102Xv1:
247 modifier.toModify(process.electronMVAValueMapProducer, srcMiniAOD =
"slimmedElectronsTo106X")
248 modifier.toModify(process.egmGsfElectronIDs, physicsObjectSrc =
"slimmedElectronsTo106X")
253 for modname
in photon_id_modules_WorkingPoints_nanoAOD.modules:
255 process.photonSequence.insert(process.photonSequence.index(bitmapVIDForPho),process.egmPhotonIDSequence)
256 for modifier
in run2_miniAOD_80XLegacy,run2_nanoAOD_94XMiniAODv1,run2_nanoAOD_94XMiniAODv2,run2_nanoAOD_94X2016 ,run2_nanoAOD_102Xv1:
257 modifier.toModify(process.photonMVAValueMapProducer, srcMiniAOD =
"slimmedPhotonsTo106X")
258 modifier.toModify(process.egmPhotonIDs, physicsObjectSrc =
"slimmedPhotonsTo106X")
262 _btagDiscriminators=[]
264 print(
"Updating process to run DeepCSV btag to AK8 jets")
265 _btagDiscriminators += [
'pfDeepCSVJetTags:probb',
'pfDeepCSVJetTags:probbb']
266 if addDeepBoostedJet:
267 print(
"Updating process to run DeepBoostedJet on datasets before 103X")
269 _btagDiscriminators += pfDeepBoostedJetTagsAll
271 print(
"Updating process to run ParticleNet before it's included in MiniAOD")
273 _btagDiscriminators += pfParticleNetJetTagsAll
275 print(
"Updating process to run DeepDoubleX on datasets before 104X")
276 _btagDiscriminators += [
'pfDeepDoubleBvLJetTags:probHbb', \
277 'pfDeepDoubleCvLJetTags:probHcc', \
278 'pfDeepDoubleCvBJetTags:probHcc', \
279 'pfMassIndependentDeepDoubleBvLJetTags:probHbb',
'pfMassIndependentDeepDoubleCvLJetTags:probHcc',
'pfMassIndependentDeepDoubleCvBJetTags:probHcc']
280 if len(_btagDiscriminators)==0:
return process
281 print(
"Will recalculate the following discriminators on AK8 jets: "+
", ".
join(_btagDiscriminators))
284 jetSource = cms.InputTag(
'slimmedJetsAK8'),
285 pvSource = cms.InputTag(
'offlineSlimmedPrimaryVertices'),
286 svSource = cms.InputTag(
'slimmedSecondaryVertices'),
288 jetCorrections = (jecPayload.value(), cms.vstring([
'L1FastJet',
'L2Relative',
'L3Absolute',
'L2L3Residual']),
'None'),
289 btagDiscriminators = _btagDiscriminators,
290 postfix=
'AK8WithDeepInfo',
293 process.jetCorrFactorsAK8.src=
"selectedUpdatedPatJetsAK8WithDeepInfo" 294 process.updatedJetsAK8.jetSource=
"selectedUpdatedPatJetsAK8WithDeepInfo" 297 from PhysicsTools.PatUtils.tools.runMETCorrectionsAndUncertainties
import runMetCorAndUncFromMiniAOD
301 fixEE2017Params = {
'userawPt':
True,
'ptThreshold':50.0,
'minEtaThreshold':2.65,
'maxEtaThreshold': 3.139},
302 postfix =
"FixEE2017")
303 process.nanoSequenceCommon.insert(process.nanoSequenceCommon.index(jetSequence),process.fullPatMetSequenceFixEE2017)
308 nanoAOD_addDeepInfo_switch = cms.PSet(
309 nanoAOD_addDeepBTag_switch = cms.untracked.bool(
False),
310 nanoAOD_addDeepFlavourTag_switch = cms.untracked.bool(
False),
312 run2_miniAOD_80XLegacy.toModify(nanoAOD_addDeepInfo_switch, nanoAOD_addDeepBTag_switch = cms.untracked.bool(
True))
313 for modifier
in run2_miniAOD_80XLegacy, run2_nanoAOD_94X2016, run2_nanoAOD_94XMiniAODv1, run2_nanoAOD_94XMiniAODv2:
314 modifier.toModify(nanoAOD_addDeepInfo_switch, nanoAOD_addDeepFlavourTag_switch = cms.untracked.bool(
True))
316 addDeepBTag=nanoAOD_addDeepInfo_switch.nanoAOD_addDeepBTag_switch,
317 addDeepFlavour=nanoAOD_addDeepInfo_switch.nanoAOD_addDeepFlavourTag_switch)
318 nanoAOD_addDeepInfoAK8_switch = cms.PSet(
319 nanoAOD_addDeepBTag_switch = cms.untracked.bool(
False),
320 nanoAOD_addDeepBoostedJet_switch = cms.untracked.bool(
True),
321 nanoAOD_addDeepDoubleX_switch = cms.untracked.bool(
True),
322 nanoAOD_addParticleNet_switch = cms.untracked.bool(
True),
323 jecPayload = cms.untracked.string(
'AK8PFPuppi')
326 run2_miniAOD_80XLegacy.toModify(nanoAOD_addDeepInfoAK8_switch,
327 nanoAOD_addDeepBTag_switch =
True,
328 nanoAOD_addDeepBoostedJet_switch =
False,
329 nanoAOD_addDeepDoubleX_switch =
False,
330 nanoAOD_addParticleNet_switch =
False,
331 jecPayload =
'AK8PFchs')
333 run2_miniAOD_devel.toModify(
334 nanoAOD_addDeepInfoAK8_switch,
335 nanoAOD_addDeepBoostedJet_switch =
False,
336 nanoAOD_addDeepDoubleX_switch =
False,
337 nanoAOD_addParticleNet_switch =
False,
340 addDeepBTag=nanoAOD_addDeepInfoAK8_switch.nanoAOD_addDeepBTag_switch,
341 addDeepBoostedJet=nanoAOD_addDeepInfoAK8_switch.nanoAOD_addDeepBoostedJet_switch,
342 addDeepDoubleX=nanoAOD_addDeepInfoAK8_switch.nanoAOD_addDeepDoubleX_switch,
343 addParticleNet=nanoAOD_addDeepInfoAK8_switch.nanoAOD_addParticleNet_switch,
344 jecPayload=nanoAOD_addDeepInfoAK8_switch.jecPayload)
345 addTauIds_switch = cms.PSet(
346 nanoAOD_addTauIds_switch = cms.untracked.bool(
True)
348 run2_miniAOD_80XLegacy.toModify(addTauIds_switch, nanoAOD_addTauIds_switch = cms.untracked.bool(
False))
349 ((run2_miniAOD_devel | run2_tau_ul_2016 | run2_tau_ul_2018) & \
350 (~(run2_nanoAOD_94X2016 | run2_nanoAOD_94XMiniAODv1 | run2_nanoAOD_94XMiniAODv2 | run2_nanoAOD_102Xv1 | run2_nanoAOD_106Xv1))).toModify(addTauIds_switch,
351 nanoAOD_addTauIds_switch = cms.untracked.bool(
False))
352 if addTauIds_switch.nanoAOD_addTauIds_switch:
359 for modifier
in run2_nanoAOD_94XMiniAODv1, run2_nanoAOD_94XMiniAODv2:
366 for modifier
in run2_nanoAOD_94XMiniAODv1, run2_nanoAOD_94XMiniAODv2:
371 _80x_sequence = nanoSequenceCommon.copy()
373 _80x_sequence.remove(isoTrackTables)
374 _80x_sequence.remove(isoTrackSequence)
376 _80x_sequence.insert(_80x_sequence.index(jetSequence), extraFlagsProducers)
377 _80x_sequence.insert(_80x_sequence.index(simpleCleanerTable)+1, extraFlagsTable)
379 run2_miniAOD_80XLegacy.toReplaceWith( nanoSequenceCommon, _80x_sequence)
381 _102x_sequence = nanoSequenceCommon.copy()
383 _102x_sequence.insert(_102x_sequence.index(jetSequence),extraFlagsProducers102x)
384 _102x_sequence.insert(_102x_sequence.index(simpleCleanerTable)+1,extraFlagsTable)
386 for modifier
in run2_nanoAOD_94XMiniAODv1, run2_nanoAOD_94XMiniAODv2, run2_nanoAOD_102Xv1:
387 modifier.toReplaceWith(nanoSequenceCommon, _102x_sequence)
def nanoAOD_addDeepInfo(process, addDeepBTag, addDeepFlavour)
def ExtVar(tag, valtype, compression=None, doc=None, mcOnly=False, precision=-1)
S & print(S &os, JobReport::InputFile const &f)
def nanoAOD_customizeMC(process)
def nanoAOD_activateVID(process)
def Var(expr, valtype, compression=None, doc=None, mcOnly=False, precision=-1)
def nanoAOD_customizeCommon(process)
def nanoAOD_recalibrateMETs(process, isData)
def nanoAOD_runMETfixEE2017(process, isData)
static std::string join(char **cmd)
def nanoAOD_addTauIds(process)
def nanoAOD_addDeepMET(process, addDeepMETProducer, ResponseTune_Graph)
def nanoAOD_addDeepInfoAK8(process, addDeepBTag, addDeepBoostedJet, addDeepDoubleX, addParticleNet, jecPayload)
def runMetCorAndUncFromMiniAOD(process, metType="PF", jetCollUnskimmed="slimmedJets", photonColl="slimmedPhotons", electronColl="slimmedElectrons", muonColl="slimmedMuons", tauColl="slimmedTaus", pfCandColl="packedPFCandidates", jetFlavor="AK4PFchs", jetCleaning="LepClean", isData=False, manualJetConfig=False, reclusterJets=None, jetSelection="pt>15 && abs(eta)<9.9", recoMetFromPFCs=None, jetCorLabelL3="ak4PFCHSL1FastL2L3Corrector", jetCorLabelRes="ak4PFCHSL1FastL2L3ResidualCorrector", CHS=False, reapplyJEC=True, jecUncFile="", computeMETSignificance=True, fixEE2017=False, fixEE2017Params=None, extractDeepMETs=False, postfix="")
def nanoAOD_customizeData(process)