CMS 3D CMS Logo

EgammaTrackExtractor.cc
Go to the documentation of this file.
2 
21 
22 using namespace edm;
23 using namespace std;
24 using namespace reco;
25 using namespace egammaisolation;
27 
28 EgammaTrackExtractor::EgammaTrackExtractor(const ParameterSet& par, edm::ConsumesCollector& iC)
29  : theTrackCollectionToken(iC.consumes<View<Track> >(par.getParameter<edm::InputTag>("inputTrackCollection"))),
30  theDepositLabel(par.getUntrackedParameter<std::string>("DepositLabel")),
31  theDiff_r(par.getParameter<double>("Diff_r")),
32  theDiff_z(par.getParameter<double>("Diff_z")),
33  theDR_Max(par.getParameter<double>("DR_Max")),
34  theDR_Veto(par.getParameter<double>("DR_Veto")),
35  theBeamlineOption(par.getParameter<std::string>("BeamlineOption")),
36  theBeamSpotToken(iC.mayConsume<reco::BeamSpot>(par.getParameter<edm::InputTag>("BeamSpotLabel"))),
37  theNHits_Min(par.getParameter<unsigned int>("NHits_Min")),
38  theChi2Ndof_Max(par.getParameter<double>("Chi2Ndof_Max")),
39  theChi2Prob_Min(par.getParameter<double>("Chi2Prob_Min")),
40  thePt_Min(par.getParameter<double>("Pt_Min")),
41  dzOptionString(par.getParameter<std::string>("dzOption")) {
42  if (!dzOptionString.compare("dz"))
44  else if (!dzOptionString.compare("vz"))
46  else if (!dzOptionString.compare("bs"))
48  else if (!dzOptionString.compare("vtx"))
50  else
52 }
53 
55  const edm::EventSetup& evSetup,
56  const reco::Track& track) const {
58  return reco::IsoDeposit::Vetos(1, veto(dir));
59 }
60 
63  result.vetoDir = dir;
64  result.dR = theDR_Veto;
65  return result;
66 }
67 
69  const EventSetup& eventSetup,
70  const Candidate& candTk) const {
71  static const std::string metname = "EgammaIsolationAlgos|EgammaTrackExtractor";
72 
74  double dzCut = 0;
75 
76  reco::TrackBase::Point beamPoint(0, 0, 0);
77  if (theBeamlineOption == "BeamSpotFromEvent") {
78  //pick beamSpot
81 
82  event.getByToken(theBeamSpotToken, beamSpotH);
83 
84  if (beamSpotH.isValid()) {
85  beamPoint = beamSpotH->position();
86  }
87  }
88 
89  Handle<View<Track> > tracksH;
90  event.getByToken(theTrackCollectionToken, tracksH);
91 
92  if (candTk.isElectron()) {
93  const reco::GsfElectron* elec = dynamic_cast<const reco::GsfElectron*>(&candTk);
94  candDir = reco::isodeposit::Direction(elec->gsfTrack()->eta(), elec->gsfTrack()->phi());
95  } else {
96  candDir = reco::isodeposit::Direction(candTk.eta(), candTk.phi());
97  }
98 
99  IsoDeposit deposit(candDir);
100  deposit.setVeto(veto(candDir));
101  deposit.addCandEnergy(candTk.et());
102 
103  View<Track>::const_iterator itrTr = tracksH->begin();
104  View<Track>::const_iterator trEnd = tracksH->end();
105  for (itrTr = tracksH->begin(); itrTr != trEnd; ++itrTr) {
106  if (candDir.deltaR(reco::isodeposit::Direction(itrTr->eta(), itrTr->phi())) > theDR_Max)
107  continue;
108 
109  if (itrTr->normalizedChi2() > theChi2Ndof_Max)
110  continue;
111 
112  if (itrTr->pt() < thePt_Min)
113  continue;
114 
115  if (theChi2Prob_Min > 0 && ChiSquaredProbability(itrTr->chi2(), itrTr->ndof()) < theChi2Prob_Min)
116  continue;
117 
118  if (theNHits_Min > 0 && itrTr->numberOfValidHits() < theNHits_Min)
119  continue;
120 
121  if (candTk.isElectron()) {
122  const reco::GsfElectron* elec = dynamic_cast<const reco::GsfElectron*>(&candTk);
123  switch (dzOption) {
125  dzCut = elec->gsfTrack()->dz() - itrTr->dz();
126  break;
128  dzCut = elec->gsfTrack()->vz() - itrTr->vz();
129  break;
131  dzCut = elec->gsfTrack()->dz(beamPoint) - itrTr->dz(beamPoint);
132  break;
134  dzCut = itrTr->dz(elec->gsfTrack()->vertex());
135  break;
136  default:
137  dzCut = elec->gsfTrack()->vz() - itrTr->vz();
138  break;
139  }
140  } else {
141  switch (dzOption) {
143  dzCut = (*itrTr).dz() - candTk.vertex().z();
144  break;
146  dzCut = (*itrTr).vz() - candTk.vertex().z();
147  break;
149  dzCut = (*itrTr).dz(beamPoint) - candTk.vertex().z();
150  break;
152  dzCut = (*itrTr).dz(candTk.vertex());
153  break;
154  default:
155  dzCut = (*itrTr).vz() - candTk.vertex().z();
156  break;
157  }
158  }
159 
160  if (fabs(dzCut) > theDiff_z)
161  continue;
162 
163  if (fabs(itrTr->dxy(beamPoint)) > theDiff_r)
164  continue;
165 
166  deposit.addDeposit(reco::isodeposit::Direction(itrTr->eta(), itrTr->phi()), itrTr->pt());
167  }
168 
169  return deposit;
170 }
Handle.h
pwdgSkimBPark_cfi.beamSpot
beamSpot
Definition: pwdgSkimBPark_cfi.py:5
reco::GsfElectron::gsfTrack
GsfTrackRef gsfTrack() const override
reference to a GsfTrack
Definition: GsfElectron.h:164
MessageLogger.h
egammaisolation
Definition: EgammaRange.h:12
reco::Candidate::eta
virtual double eta() const =0
momentum pseudorapidity
ChiSquaredProbability
float ChiSquaredProbability(double chiSquared, double nrDOF)
Definition: ChiSquaredProbability.cc:13
edm
HLT enums.
Definition: AlignableModifier.h:19
egammaisolation::EgammaTrackExtractor::theBeamSpotToken
edm::EDGetTokenT< reco::BeamSpot > theBeamSpotToken
Definition: EgammaTrackExtractor.h:59
reco::IsoDeposit::addDeposit
void addDeposit(double dr, double deposit)
Add deposit (ie. transverse energy or pT)
Definition: IsoDeposit.cc:19
ChiSquaredProbability.h
egammaisolation::EgammaTrackSelector::vz
Definition: EgammaTrackSelector.h:20
egammaisolation::EgammaTrackSelector::vtx
Definition: EgammaTrackSelector.h:20
egammaisolation::EgammaTrackSelector::bs
Definition: EgammaTrackSelector.h:20
reco::IsoDeposit::Veto
Definition: IsoDeposit.h:59
reco
fixed size matrix
Definition: AlignmentAlgorithmBase.h:45
egammaisolation::EgammaTrackExtractor::theDR_Max
double theDR_Max
z distance to vertex
Definition: EgammaTrackExtractor.h:54
edm::Handle< reco::BeamSpot >
RecoCandidate.h
IsoDepositDirection.h
egammaisolation::EgammaTrackExtractor::theChi2Ndof_Max
double theChi2Ndof_Max
trk.numberOfValidHits >= theNHits_Min
Definition: EgammaTrackExtractor.h:61
EgammaTrackExtractor.h
Track.h
TrackFwd.h
BeamSpot.h
egammaisolation::EgammaTrackExtractor::deposit
reco::IsoDeposit deposit(const edm::Event &ev, const edm::EventSetup &evSetup, const reco::Track &muon) const override
Definition: EgammaTrackExtractor.h:32
reco::BeamSpot
Definition: BeamSpot.h:21
TrackSplittingMonitor_cfi.dzCut
dzCut
Definition: TrackSplittingMonitor_cfi.py:20
egammaisolation::EgammaTrackExtractor::dzOption
int dzOption
Definition: EgammaTrackExtractor.h:67
reco::Track
Definition: Track.h:27
reco::GsfElectron
Definition: GsfElectron.h:35
reco::BeamSpot::position
const Point & position() const
position
Definition: BeamSpot.h:59
GsfElectron.h
egammaisolation::EgammaTrackSelector::dz
Definition: EgammaTrackSelector.h:20
CaloGeometryRecord.h
AlCaHLTBitMon_QueryRunRegistry.string
string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
egammaisolation::EgammaTrackExtractor::theChi2Prob_Min
double theChi2Prob_Min
trk.normalizedChi2 < theChi2Ndof_Max
Definition: EgammaTrackExtractor.h:62
egammaisolation::EgammaTrackExtractor::theDiff_r
double theDiff_r
minimum candidate et
Definition: EgammaTrackExtractor.h:52
edm::View
Definition: CaloClusterFwd.h:14
GsfElectronFwd.h
edm::ParameterSet
Definition: ParameterSet.h:36
reco::isodeposit::Direction::deltaR
double deltaR(const Direction &dir2) const
Definition: IsoDepositDirection.h:47
egammaisolation::EgammaTrackExtractor::theNHits_Min
unsigned int theNHits_Min
BeamSpot name.
Definition: EgammaTrackExtractor.h:60
egammaisolation::EgammaTrackExtractor::theDR_Veto
double theDR_Veto
Maximum cone angle for deposits.
Definition: EgammaTrackExtractor.h:55
egammaisolation::EgammaTrackExtractor::theDiff_z
double theDiff_z
transverse distance to vertex
Definition: EgammaTrackExtractor.h:53
reco::Candidate::vertex
virtual const Point & vertex() const =0
vertex position
createfilelist.int
int
Definition: createfilelist.py:10
GsfTrack.h
egammaisolation::EgammaTrackExtractor::thePt_Min
double thePt_Min
ChiSquaredProbability(trk.chi2,trk.ndof) > theChi2Prob_Min.
Definition: EgammaTrackExtractor.h:63
edm::EventSetup
Definition: EventSetup.h:57
EgammaTrackSelector.h
reco::Candidate
Definition: Candidate.h:27
egammaisolation::EgammaTrackExtractor::vetos
virtual reco::IsoDeposit::Vetos vetos(const edm::Event &ev, const edm::EventSetup &evSetup, const reco::Track &track) const
Definition: EgammaTrackExtractor.cc:54
reco::TrackBase::Point
math::XYZPoint Point
point in the space
Definition: TrackBase.h:80
reco::IsoDeposit::addCandEnergy
void addCandEnergy(double et)
Set energy or pT attached to cand trajectory.
Definition: IsoDeposit.h:132
reco::Candidate::isElectron
virtual bool isElectron() const =0
std
Definition: JetResolutionObject.h:76
GsfTrackFwd.h
egammaisolation::EgammaTrackExtractor::theBeamlineOption
std::string theBeamlineOption
Veto cone angle.
Definition: EgammaTrackExtractor.h:56
SuperClusterFwd.h
egammaisolation::EgammaTrackExtractor::dzOptionString
std::string dzOptionString
Endcap requirements to determine if isolated for selective filling.
Definition: EgammaTrackExtractor.h:66
reco::isodeposit::Direction
Definition: IsoDepositDirection.h:19
EgammaRecHitIsolation.h
SuperCluster.h
ev
bool ev
Definition: Hydjet2Hadronizer.cc:95
reco::IsoDeposit
Definition: IsoDeposit.h:49
edm::View::const_iterator
boost::indirect_iterator< typename seq_t::const_iterator > const_iterator
Definition: View.h:86
egammaisolation::EgammaTrackExtractor::theTrackCollectionToken
edm::EDGetTokenT< edm::View< reco::Track > > theTrackCollectionToken
Definition: EgammaTrackExtractor.h:49
HLT_2018_cff.track
track
Definition: HLT_2018_cff.py:10352
mps_fire.result
result
Definition: mps_fire.py:303
EgammaRange.h
edm::HandleBase::isValid
bool isValid() const
Definition: HandleBase.h:70
event
Definition: event.py:1
edm::Event
Definition: Event.h:73
reco::Candidate::phi
virtual double phi() const =0
momentum azimuthal angle
reco::IsoDeposit::Vetos
std::vector< Veto > Vetos
Definition: IsoDeposit.h:65
egammaisolation::EgammaTrackExtractor::veto
reco::IsoDeposit::Veto veto(const reco::IsoDeposit::Direction &dir) const
Definition: EgammaTrackExtractor.cc:61
edm::InputTag
Definition: InputTag.h:15
edm::ConsumesCollector
Definition: ConsumesCollector.h:39
reco::IsoDeposit::setVeto
void setVeto(const Veto &aVeto)
Set veto.
Definition: IsoDeposit.h:82
DeadROC_duringRun.dir
dir
Definition: DeadROC_duringRun.py:23
metname
const std::string metname
Definition: MuonSeedOrcaPatternRecognition.cc:43
reco::Candidate::et
virtual double et() const =0
transverse energy