1 import FWCore.ParameterSet.Config
as cms
6 process.patMuons.isoDeposits = cms.PSet()
7 process.patElectrons.isoDeposits = cms.PSet()
8 process.patTaus.isoDeposits = cms.PSet()
9 process.patPhotons.isoDeposits = cms.PSet()
11 process.patMuons.embedTrack =
True
12 process.patMuons.embedCombinedMuon =
True
13 process.patMuons.embedMuonBestTrack =
True
14 process.patMuons.embedStandAloneMuon =
True
15 process.patMuons.embedPickyMuon =
False
16 process.patMuons.embedTpfmsMuon =
False
17 process.patMuons.embedDytMuon =
False
20 process.patElectrons.embedGsfElectronCore =
False
21 process.patElectrons.embedSuperCluster =
False
22 process.patElectrons.embedPflowSuperCluster =
False
23 process.patElectrons.embedSeedCluster =
False
24 process.patElectrons.embedBasicClusters =
False
25 process.patElectrons.embedPreshowerClusters =
False
26 process.patElectrons.embedPflowBasicClusters =
False
27 process.patElectrons.embedPflowPreshowerClusters =
False
28 process.patElectrons.embedRecHits =
False
29 process.patElectrons.electronSource = cms.InputTag(
"reducedEgamma",
"reducedGedGsfElectrons")
30 process.patElectrons.electronIDSources = cms.PSet(
33 eidRobustLoose = cms.InputTag(
"reducedEgamma",
"eidRobustLoose"),
34 eidRobustTight = cms.InputTag(
"reducedEgamma",
"eidRobustTight"),
35 eidLoose = cms.InputTag(
"reducedEgamma",
"eidLoose"),
36 eidTight = cms.InputTag(
"reducedEgamma",
"eidTight"),
37 eidRobustHighEnergy = cms.InputTag(
"reducedEgamma",
"eidRobustHighEnergy"),
39 process.patElectrons.addPFClusterIso = cms.bool(
True)
40 process.patElectrons.ecalPFClusterIsoMap = cms.InputTag(
"reducedEgamma",
"eleEcalPFClusIso")
41 process.patElectrons.hcalPFClusterIsoMap = cms.InputTag(
"reducedEgamma",
"eleHcalPFClusIso")
43 process.elPFIsoDepositChargedPAT.src = cms.InputTag(
"reducedEgamma",
"reducedGedGsfElectrons")
44 process.elPFIsoDepositChargedAllPAT.src = cms.InputTag(
"reducedEgamma",
"reducedGedGsfElectrons")
45 process.elPFIsoDepositNeutralPAT.src = cms.InputTag(
"reducedEgamma",
"reducedGedGsfElectrons")
46 process.elPFIsoDepositGammaPAT.src = cms.InputTag(
"reducedEgamma",
"reducedGedGsfElectrons")
47 process.elPFIsoDepositPUPAT.src = cms.InputTag(
"reducedEgamma",
"reducedGedGsfElectrons")
49 process.patPhotons.embedSuperCluster =
False
50 process.patPhotons.embedSeedCluster =
False
51 process.patPhotons.embedBasicClusters =
False
52 process.patPhotons.embedPreshowerClusters =
False
53 process.patPhotons.embedRecHits =
False
54 process.patPhotons.addPFClusterIso = cms.bool(
True)
55 process.patPhotons.ecalPFClusterIsoMap = cms.InputTag(
"reducedEgamma",
"phoEcalPFClusIso")
56 process.patPhotons.hcalPFClusterIsoMap = cms.InputTag(
"reducedEgamma",
"phoHcalPFClusIso")
57 process.patPhotons.photonSource = cms.InputTag(
"reducedEgamma",
"reducedGedPhotons")
58 process.patPhotons.electronSource = cms.InputTag(
"reducedEgamma",
"reducedGedGsfElectrons")
59 process.patPhotons.photonIDSources = cms.PSet(
60 PhotonCutBasedIDLoose = cms.InputTag(
'reducedEgamma',
61 'PhotonCutBasedIDLoose'),
62 PhotonCutBasedIDTight = cms.InputTag(
'reducedEgamma',
63 'PhotonCutBasedIDTight')
66 process.phPFIsoDepositChargedPAT.src = cms.InputTag(
"reducedEgamma",
"reducedGedPhotons")
67 process.phPFIsoDepositChargedAllPAT.src = cms.InputTag(
"reducedEgamma",
"reducedGedPhotons")
68 process.phPFIsoDepositNeutralPAT.src = cms.InputTag(
"reducedEgamma",
"reducedGedPhotons")
69 process.phPFIsoDepositGammaPAT.src = cms.InputTag(
"reducedEgamma",
"reducedGedPhotons")
70 process.phPFIsoDepositPUPAT.src = cms.InputTag(
"reducedEgamma",
"reducedGedPhotons")
72 process.selectedPatJets.cut = cms.string(
"pt > 10")
73 process.selectedPatMuons.cut = cms.string(
"pt > 5 || isPFMuon || (pt > 3 && (isGlobalMuon || isStandAloneMuon || numberOfMatches > 0 || muonID('RPCMuLoose')))")
74 process.selectedPatElectrons.cut = cms.string(
"")
75 process.selectedPatTaus.cut = cms.string(
"pt > 18. && tauID('decayModeFindingNewDMs')> 0.5")
76 process.selectedPatPhotons.cut = cms.string(
"")
80 from PhysicsTools.PatAlgos.slimming.applySubstructure_cff
import applySubstructure
85 from PhysicsTools.PatAlgos.tools.trigTools
import switchOnTriggerStandAlone
87 process.patTrigger.packTriggerPathNames = cms.bool(
True)
92 from PhysicsTools.PatUtils.tools.runMETCorrectionsAndUncertainties
import runMetCorAndUncForMiniAODProduction
94 jetCollUnskimmed=
"patJets")
97 from PhysicsTools.PatAlgos.tools.metTools
import addMETCollection
98 addMETCollection(process,
99 labelName =
"patCaloMet",
100 metSource =
"caloMetM"
104 process.noHFCands = cms.EDFilter(
"GenericPFCandidateSelector",
105 src=cms.InputTag(
"particleFlow"),
106 cut=cms.string(
"abs(pdgId)!=1 && abs(pdgId)!=2 && abs(eta)<3.0")
109 pfCandColl=cms.InputTag(
"noHFCands"),
110 recoMetFromPFCs=
True,
111 jetSelection=
"pt>15 && abs(eta)<3.",
115 process.load(
'PhysicsTools.PatAlgos.slimming.slimmedMETs_cfi')
116 process.slimmedMETsNoHF = process.slimmedMETs.clone()
117 process.slimmedMETsNoHF.src = cms.InputTag(
"patMETsNoHF")
118 process.slimmedMETsNoHF.rawVariation = cms.InputTag(
"patPFMetNoHF")
119 process.slimmedMETsNoHF.t1Uncertainties = cms.InputTag(
"patPFMetT1%sNoHF")
120 process.slimmedMETsNoHF.t01Variation = cms.InputTag(
"patPFMetT0pcT1NoHF")
121 process.slimmedMETsNoHF.t1SmearedVarsAndUncs = cms.InputTag(
"patPFMetT1Smear%sNoHF")
122 process.slimmedMETsNoHF.tXYUncForRaw = cms.InputTag(
"patPFMetTxyNoHF")
123 process.slimmedMETsNoHF.tXYUncForT1 = cms.InputTag(
"patPFMetT1TxyNoHF")
124 process.slimmedMETsNoHF.tXYUncForT01 = cms.InputTag(
"patPFMetT0pcT1TxyNoHF")
125 process.slimmedMETsNoHF.tXYUncForT1Smear = cms.InputTag(
"patPFMetT1SmearTxyNoHF")
126 process.slimmedMETsNoHF.tXYUncForT01Smear = cms.InputTag(
"patPFMetT0pcT1SmearTxyNoHF")
127 del process.slimmedMETsNoHF.caloMET
132 if not hasattr( process,
'pfImpactParameterTagInfos' ):
133 process.load(
'RecoBTag.ImpactParameter.pfImpactParameterTagInfos_cfi')
134 if not hasattr( process,
'pfSecondaryVertexTagInfos' ):
135 process.load(
'RecoBTag.SecondaryVertex.pfSecondaryVertexTagInfos_cfi')
136 process.patJets.userData.userFunctions = cms.vstring(
137 '?(tagInfoCandSecondaryVertex("pfSecondaryVertex").nVertices()>0)?(tagInfoCandSecondaryVertex("pfSecondaryVertex").secondaryVertex(0).p4.M):(0)',
138 '?(tagInfoCandSecondaryVertex("pfSecondaryVertex").nVertices()>0)?(tagInfoCandSecondaryVertex("pfSecondaryVertex").secondaryVertex(0).numberOfSourceCandidatePtrs):(0)',
139 '?(tagInfoCandSecondaryVertex("pfSecondaryVertex").nVertices()>0)?(tagInfoCandSecondaryVertex("pfSecondaryVertex").flightDistance(0).value):(0)',
140 '?(tagInfoCandSecondaryVertex("pfSecondaryVertex").nVertices()>0)?(tagInfoCandSecondaryVertex("pfSecondaryVertex").flightDistance(0).significance):(0)',
141 '?(tagInfoCandSecondaryVertex("pfSecondaryVertex").nVertices()>0)?(tagInfoCandSecondaryVertex("pfSecondaryVertex").secondaryVertex(0).p4.x):(0)',
142 '?(tagInfoCandSecondaryVertex("pfSecondaryVertex").nVertices()>0)?(tagInfoCandSecondaryVertex("pfSecondaryVertex").secondaryVertex(0).p4.y):(0)',
143 '?(tagInfoCandSecondaryVertex("pfSecondaryVertex").nVertices()>0)?(tagInfoCandSecondaryVertex("pfSecondaryVertex").secondaryVertex(0).p4.z):(0)',
144 '?(tagInfoCandSecondaryVertex("pfSecondaryVertex").nVertices()>0)?(tagInfoCandSecondaryVertex("pfSecondaryVertex").secondaryVertex(0).vertex.x):(0)',
145 '?(tagInfoCandSecondaryVertex("pfSecondaryVertex").nVertices()>0)?(tagInfoCandSecondaryVertex("pfSecondaryVertex").secondaryVertex(0).vertex.y):(0)',
146 '?(tagInfoCandSecondaryVertex("pfSecondaryVertex").nVertices()>0)?(tagInfoCandSecondaryVertex("pfSecondaryVertex").secondaryVertex(0).vertex.z):(0)',
148 process.patJets.userData.userFunctionLabels = cms.vstring(
'vtxMass',
'vtxNtracks',
'vtx3DVal',
'vtx3DSig',
'vtxPx',
'vtxPy',
'vtxPz',
'vtxPosX',
'vtxPosY',
'vtxPosZ')
149 process.patJets.tagInfoSources = cms.VInputTag(cms.InputTag(
"pfSecondaryVertexTagInfos"))
150 process.patJets.addTagInfos = cms.bool(
True)
159 jetSource = cms.InputTag(
'selectedPatJets'),
161 pvSource = cms.InputTag(
'offlinePrimaryVertices'),
162 pfCandidates = cms.InputTag(
'particleFlow'),
163 svSource = cms.InputTag(
'inclusiveCandidateSecondaryVertices'),
164 muSource = cms.InputTag(
'muons'),
165 elSource = cms.InputTag(
'gedGsfElectrons'),
167 jetCorrections = (
'AK4PFchs', [
'L1FastJet',
'L2Relative',
'L3Absolute'],
''),
168 btagDiscriminators = [
"pfCombinedSecondaryVertexV2BJetTags",
"pfCombinedInclusiveSecondaryVertexV2BJetTags",
169 "pfCombinedCvsLJetTags",
"pfCombinedCvsBJetTags"],
171 tightBTagNTkHits =
True,
172 btagPrefix =
'tight',
177 process.load(
"RecoJets.JetProducers.PileupJetID_cfi")
178 process.patJets.userData.userFloats.src = [ cms.InputTag(
"pileupJetId:fullDiscriminant"), ]
179 process.patJets.userData.userInts.src = [ cms.InputTag(
"pileupJetId:fullId"), ]
182 process.caloJetMap = cms.EDProducer(
"RecoJetDeltaRValueMapProducer",
183 src = process.patJets.jetSource,
184 matched = cms.InputTag(
"ak4CaloJets"),
185 distMax = cms.double(0.4),
186 values = cms.vstring(
'pt',
'emEnergyFraction'),
187 valueLabels = cms.vstring(
'pt',
'emEnergyFraction'),
188 lazyParser = cms.bool(
True) )
189 process.patJets.userData.userFloats.src += [ cms.InputTag(
"caloJetMap:pt"), cms.InputTag(
"caloJetMap:emEnergyFraction") ]
192 from RecoEgamma.EgammaTools.egammaObjectModificationsInMiniAOD_cff
import egamma_modifications
193 process.slimmedElectrons.modifierConfig.modifications = egamma_modifications
194 process.slimmedPhotons.modifierConfig.modifications = egamma_modifications
197 electron_ids = [
'RecoEgamma.ElectronIdentification.Identification.cutBasedElectronID_PHYS14_PU20bx25_V2_cff',
198 'RecoEgamma.ElectronIdentification.Identification.cutBasedElectronID_Spring15_25ns_V1_cff',
199 'RecoEgamma.ElectronIdentification.Identification.cutBasedElectronID_Spring15_50ns_V2_cff',
200 'RecoEgamma.ElectronIdentification.Identification.heepElectronID_HEEPV60_cff',
201 'RecoEgamma.ElectronIdentification.Identification.mvaElectronID_Spring15_25ns_nonTrig_V1_cff',
202 'RecoEgamma.ElectronIdentification.Identification.mvaElectronID_Spring15_25ns_Trig_V1_cff',
203 'RecoEgamma.ElectronIdentification.Identification.mvaElectronID_Spring15_50ns_Trig_V1_cff']
205 process.egmGsfElectronIDs.physicsObjectSrc = \
206 cms.InputTag(
"reducedEgamma",
"reducedGedGsfElectrons")
207 process.electronMVAValueMapProducer.src = \
208 cms.InputTag(
'reducedEgamma',
'reducedGedGsfElectrons')
209 process.electronRegressionValueMapProducer.src = \
210 cms.InputTag(
'reducedEgamma',
'reducedGedGsfElectrons')
211 for idmod
in electron_ids:
215 photon_ids = [
'RecoEgamma.PhotonIdentification.Identification.cutBasedPhotonID_Spring15_25ns_V1_cff',
216 'RecoEgamma.PhotonIdentification.Identification.cutBasedPhotonID_Spring15_50ns_V1_cff',
217 'RecoEgamma.PhotonIdentification.Identification.mvaPhotonID_Spring15_25ns_nonTrig_V2p1_cff',
218 'RecoEgamma.PhotonIdentification.Identification.mvaPhotonID_Spring15_50ns_nonTrig_V2p1_cff']
220 process.egmPhotonIDs.physicsObjectSrc = \
221 cms.InputTag(
"reducedEgamma",
"reducedGedPhotons")
222 process.photonIDValueMapProducer.src = \
223 cms.InputTag(
"reducedEgamma",
"reducedGedPhotons")
224 process.photonRegressionValueMapProducer.src = \
225 cms.InputTag(
"reducedEgamma",
"reducedGedPhotons")
226 process.photonIDValueMapProducer.particleBasedIsolation = \
227 cms.InputTag(
"reducedEgamma",
"reducedPhotonPfCandMap")
228 process.photonMVAValueMapProducer.src = \
229 cms.InputTag(
'reducedEgamma',
'reducedGedPhotons')
230 for idmod
in photon_ids:
235 from RecoTauTag.Configuration.boostedHPSPFTaus_cfi
import addBoostedTaus
240 process.load(
'RecoJets.JetProducers.ak4PFJetsPuppi_cfi')
242 process.ak4PFJetsPuppi.doAreaFastjet =
True
245 process.ak4PFJetsPuppiTracksAssociatorAtVertex = cms.EDProducer(
"JetTracksAssociatorAtVertex",
247 jets = cms.InputTag(
"ak4PFJetsPuppi")
249 process.patJetPuppiCharge = cms.EDProducer(
"JetChargeProducer",
250 src = cms.InputTag(
"ak4PFJetsPuppiTracksAssociatorAtVertex"),
251 var = cms.string(
'Pt'),
252 exp = cms.double(1.0)
255 addJetCollection(process, postfix =
"", labelName =
'Puppi', jetSource = cms.InputTag(
'ak4PFJetsPuppi'),
256 jetCorrections = (
'AK4PFPuppi', [
'L2Relative',
'L3Absolute'],
''),
257 algo=
'AK', rParam = 0.4, btagDiscriminators = map(
lambda x: x.value() ,process.patJets.discriminatorSources)
260 process.patJetGenJetMatchPuppi.matched =
'slimmedGenJets'
262 process.patJetsPuppi.jetChargeSource = cms.InputTag(
"patJetPuppiCharge")
264 process.selectedPatJetsPuppi.cut = cms.string(
"pt > 15")
266 process.load(
'PhysicsTools.PatAlgos.slimming.slimmedJets_cfi')
267 process.slimmedJetsPuppi = process.slimmedJets.clone()
268 process.slimmedJetsPuppi.src = cms.InputTag(
"selectedPatJetsPuppi")
269 process.slimmedJetsPuppi.packedPFCandidates = cms.InputTag(
"packedPFCandidates")
273 from PhysicsTools.PatAlgos.slimming.puppiForMET_cff
import makePuppies
277 pfCandColl=cms.InputTag(
"puppiForMET"),
278 jetCollUnskimmed=
"slimmedJetsPuppi",
279 recoMetFromPFCs=
True,
280 jetFlavor=
"AK4PFPuppi",
284 process.load(
'PhysicsTools.PatAlgos.slimming.slimmedMETs_cfi')
285 process.slimmedMETsPuppi = process.slimmedMETs.clone()
286 process.slimmedMETsPuppi.src = cms.InputTag(
"patMETsPuppi")
287 process.slimmedMETsPuppi.rawVariation = cms.InputTag(
"patPFMetPuppi")
288 process.slimmedMETsPuppi.t1Uncertainties = cms.InputTag(
"patPFMetT1%sPuppi")
289 process.slimmedMETsPuppi.t01Variation = cms.InputTag(
"patPFMetT0pcT1Puppi")
290 process.slimmedMETsPuppi.t1SmearedVarsAndUncs = cms.InputTag(
"patPFMetT1Smear%sPuppi")
291 process.slimmedMETsPuppi.tXYUncForRaw = cms.InputTag(
"patPFMetTxyPuppi")
292 process.slimmedMETsPuppi.tXYUncForT1 = cms.InputTag(
"patPFMetT1TxyPuppi")
293 process.slimmedMETsPuppi.tXYUncForT01 = cms.InputTag(
"patPFMetT0pcT1TxyPuppi")
294 process.slimmedMETsPuppi.tXYUncForT1Smear = cms.InputTag(
"patPFMetT1SmearTxyPuppi")
295 process.slimmedMETsPuppi.tXYUncForT01Smear = cms.InputTag(
"patPFMetT0pcT1SmearTxyPuppi")
296 del process.slimmedMETsPuppi.caloMET
302 process.load(
'PhysicsTools.PatAlgos.slimming.slimmedAddPileupInfo_cfi')
304 process.muonMatch.matched =
"prunedGenParticles"
305 process.electronMatch.matched =
"prunedGenParticles"
306 process.electronMatch.src = cms.InputTag(
"reducedEgamma",
"reducedGedGsfElectrons")
307 process.photonMatch.matched =
"prunedGenParticles"
308 process.photonMatch.src = cms.InputTag(
"reducedEgamma",
"reducedGedPhotons")
309 process.tauMatch.matched =
"prunedGenParticles"
310 process.tauGenJets.GenParticles =
"prunedGenParticles"
312 process.tauMatchBoosted.matched =
"prunedGenParticles"
313 process.tauGenJetsBoosted.GenParticles =
"prunedGenParticles"
314 process.patJetPartons.particles =
"prunedGenParticles"
315 process.patJetPartonMatch.matched =
"prunedGenParticles"
316 process.patJetPartonMatch.mcStatus = [ 3, 23 ]
317 process.patJetGenJetMatch.matched =
"slimmedGenJets"
318 process.patJetGenJetMatchAK8.matched =
"slimmedGenJetsAK8"
319 process.patMuons.embedGenMatch =
False
320 process.patElectrons.embedGenMatch =
False
321 process.patPhotons.embedGenMatch =
False
322 process.patTaus.embedGenMatch =
False
323 process.patTausBoosted.embedGenMatch =
False
324 process.patJets.embedGenPartonMatch =
False
326 process.patJetFlavourAssociation.rParam = 0.4
329 out.dropMetaData = cms.untracked.string(
'ALL')
330 out.fastCloning= cms.untracked.bool(
False)
331 out.overrideInputFileSplitLevels = cms.untracked.bool(
True)
332 out.compressionAlgorithm = cms.untracked.string(
'LZMA')
336 runOnData( process, outputModules = [] )
def runMetCorAndUncForMiniAODProduction