1 import FWCore.ParameterSet.Config
as cms
4 finalIsolatedTracks = cms.EDProducer(
"IsolatedTrackCleaner",
5 tracks = cms.InputTag(
"isolatedTracks"),
6 cut = cms.string(
"((pt>5 && (abs(pdgId) == 11 || abs(pdgId) == 13)) || pt > 10) && (abs(pdgId) < 15 || abs(eta) < 2.5) && abs(dxy) < 0.2 && abs(dz) < 0.1 && ((pfIsolationDR03().chargedHadronIso < 5 && pt < 25) || pfIsolationDR03().chargedHadronIso/pt < 0.2)"),
7 finalLeptons = cms.VInputTag(
8 cms.InputTag(
"finalElectrons"),
9 cms.InputTag(
"finalMuons"),
13 isoForIsoTk = cms.EDProducer(
"IsoTrackIsoValueMapProducer",
14 src = cms.InputTag(
"finalIsolatedTracks"),
15 relative = cms.bool(
True),
16 rho_MiniIso = cms.InputTag(
"fixedGridRhoFastjetAll"),
17 EAFile_MiniIso = cms.FileInPath(
"PhysicsTools/NanoAOD/data/effAreaMuons_cone03_pfNeuHadronsAndPhotons_80X.txt"),
20 isoTrackTable = cms.EDProducer(
"SimpleCandidateFlatTableProducer",
21 src = cms.InputTag(
"finalIsolatedTracks"),
23 name = cms.string(
"IsoTrack"),
24 doc = cms.string(
"isolated tracks after basic selection (" + finalIsolatedTracks.cut.value() +
") and lepton veto"),
25 singleton = cms.bool(
False),
26 extension = cms.bool(
False),
27 variables = cms.PSet(P3Vars,
28 dz =
Var(
"dz",float,doc=
"dz (with sign) wrt first PV, in cm",precision=10),
29 dxy =
Var(
"dxy",float,doc=
"dxy (with sign) wrt first PV, in cm",precision=10),
30 pfRelIso03_chg =
Var(
"pfIsolationDR03().chargedHadronIso/pt",float,doc=
"PF relative isolation dR=0.3, charged component",precision=10),
31 pfRelIso03_all =
Var(
"(pfIsolationDR03().chargedHadronIso + max(pfIsolationDR03().neutralHadronIso + pfIsolationDR03().photonIso - pfIsolationDR03().puChargedHadronIso/2,0.0))/pt",float,doc=
"PF relative isolation dR=0.3, total (deltaBeta corrections)",precision=10),
32 isPFcand =
Var(
"packedCandRef().isNonnull()",bool,doc=
"if isolated track is a PF candidate"),
33 pdgId =
Var(
"pdgId",int,doc=
"PDG id of PF cand"),
34 isHighPurityTrack =
Var(
"isHighPurityTrack",bool,doc=
"track is high purity"),
36 externalVariables = cms.PSet(
37 miniPFRelIso_chg =
ExtVar(
"isoForIsoTk:miniIsoChg",float,doc=
"mini PF relative isolation, charged component",precision=10),
38 miniPFRelIso_all =
ExtVar(
"isoForIsoTk:miniIsoAll",float,doc=
"mini PF relative isolation, total (with scaled rho*EA PU corrections)",precision=10),
42 isoTrackSequence = cms.Sequence(finalIsolatedTracks + isoForIsoTk)
43 isoTrackTables = cms.Sequence(isoTrackTable)
def ExtVar(tag, valtype, compression=None, doc=None, mcOnly=False, precision=-1)
def Var(expr, valtype, compression=None, doc=None, mcOnly=False, precision=-1)