1 import FWCore.ParameterSet.Config
as cms
3 from PhysicsTools.NanoAOD.simpleCandidateFlatTableProducer_cfi
import simpleCandidateFlatTableProducer
5 finalIsolatedTracks = cms.EDProducer(
"IsolatedTrackCleaner",
6 tracks = cms.InputTag(
"isolatedTracks"),
7 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) || pt>15) && ((pfIsolationDR03().chargedHadronIso < 5 && pt < 25) || pfIsolationDR03().chargedHadronIso/pt < 0.2)"),
8 finalLeptons = cms.VInputTag(
9 cms.InputTag(
"finalElectrons"),
10 cms.InputTag(
"finalLooseMuons"),
14 isoForIsoTk = cms.EDProducer(
"IsoTrackIsoValueMapProducer",
15 src = cms.InputTag(
"finalIsolatedTracks"),
16 relative = cms.bool(
True),
17 rho_MiniIso = cms.InputTag(
"fixedGridRhoFastjetAll"),
18 EAFile_MiniIso = cms.FileInPath(
"PhysicsTools/NanoAOD/data/effAreaMuons_cone03_pfNeuHadronsAndPhotons_80X.txt"),
21 isFromLostTrackForIsoTk = cms.EDProducer(
"IsFromLostTrackMapProducer",
22 srcIsoTracks = cms.InputTag(
"finalIsolatedTracks"),
23 lostTracks = cms.InputTag(
"lostTracks"),
26 isoTrackTable = simpleCandidateFlatTableProducer.clone(
27 src = cms.InputTag(
"finalIsolatedTracks"),
28 name = cms.string(
"IsoTrack"),
29 doc = cms.string(
"isolated tracks after basic selection (" + finalIsolatedTracks.cut.value() +
") and lepton veto"),
30 variables = cms.PSet(P3Vars,
31 dz =
Var(
"dz",float,doc=
"dz (with sign) wrt first PV, in cm",precision=10),
32 dxy =
Var(
"dxy",float,doc=
"dxy (with sign) wrt first PV, in cm",precision=10),
33 pfRelIso03_chg =
Var(
"pfIsolationDR03().chargedHadronIso/pt",float,doc=
"PF relative isolation dR=0.3, charged component",precision=10),
34 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),
35 isPFcand =
Var(
"packedCandRef().isNonnull()",bool,doc=
"if isolated track is a PF candidate"),
36 fromPV =
Var(
"fromPV", int, doc=
"isolated track comes from PV"),
37 pdgId =
Var(
"pdgId",int,doc=
"PDG id of PF cand"),
38 isHighPurityTrack =
Var(
"isHighPurityTrack",bool,doc=
"track is high purity"),
39 charge =
Var(
"charge", int, doc=
"electric charge"),
41 externalVariables = cms.PSet(
42 miniPFRelIso_chg =
ExtVar(
"isoForIsoTk:miniIsoChg",float,doc=
"mini PF relative isolation, charged component",precision=10),
43 miniPFRelIso_all =
ExtVar(
"isoForIsoTk:miniIsoAll",float,doc=
"mini PF relative isolation, total (with scaled rho*EA PU corrections)",precision=10),
44 isFromLostTrack =
ExtVar(
"isFromLostTrackForIsoTk:isFromLostTrack",bool,doc=
"if isolated track comes from a lost track"),
48 isoTrackTask = cms.Task(finalIsolatedTracks,isoForIsoTk,isFromLostTrackForIsoTk)
49 isoTrackTablesTask = cms.Task(isoTrackTable)
def ExtVar(tag, valtype, doc=None, precision=-1)
def Var(expr, valtype, doc=None, precision=-1)