CMS 3D CMS Logo

All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
MuPFIsoHelper.cc
Go to the documentation of this file.
2 
3 
4 MuPFIsoHelper::MuPFIsoHelper(const std::map<std::string,edm::ParameterSet>& labelMap):
5  labelMap_(labelMap)
6 {
8  for(std::map<std::string,edm::ParameterSet>::const_iterator i = labelMap_.begin();i!=labelMap_.end();++i) {
9  chargedParticle_.push_back(nullHandle);
10  chargedHadron_.push_back(nullHandle);
11  neutralHadron_.push_back(nullHandle);
12  neutralHadronHighThreshold_.push_back(nullHandle);
13  photon_.push_back(nullHandle);
14  photonHighThreshold_.push_back(nullHandle);
15  pu_.push_back(nullHandle);
16  }
17 
18 
19 
20 
21 }
22 
23 
24 
26 
27 }
28 
29 
31  const edm::Handle<CandDoubleMap>& chargedParticle,
32  const edm::Handle<CandDoubleMap>& chargedHadron,
33  const edm::Handle<CandDoubleMap>& neutralHadron,
34  const edm::Handle<CandDoubleMap>& neutralHadronHighThreshold,
35  const edm::Handle<CandDoubleMap>& photon,
36  const edm::Handle<CandDoubleMap>& photonHighThreshold,
37  const edm::Handle<CandDoubleMap>& pu) {
38 
40  if(chargedParticle.isValid())
41  iso.sumChargedParticlePt = (*chargedParticle)[muonRef];
42 
43  if(chargedHadron.isValid())
44  iso.sumChargedHadronPt = (*chargedHadron)[muonRef];
45 
46  if(neutralHadron.isValid())
47  iso.sumNeutralHadronEt = (*neutralHadron)[muonRef];
48 
49  if(neutralHadronHighThreshold.isValid())
50  iso.sumNeutralHadronEtHighThreshold = (*neutralHadronHighThreshold)[muonRef];
51 
52  if(photon.isValid())
53  iso.sumPhotonEt = (*photon)[muonRef];
54 
55  if(photonHighThreshold.isValid())
56  iso.sumPhotonEtHighThreshold = (*photonHighThreshold)[muonRef];
57 
58  if(pu.isValid())
59  iso.sumPUPt = (*pu)[muonRef];
60 
61  return iso;
62 }
63 
64 
66 
67  unsigned int count=0;
68  for(std::map<std::string,edm::ParameterSet>::const_iterator i = labelMap_.begin();i!=labelMap_.end();++i) {
70  chargedParticle_[count],
71  chargedHadron_[count],
72  neutralHadron_[count],
74  photon_[count],
75  photonHighThreshold_[count],
76  pu_[count]);
77 
78  muon.setPFIsolation(i->first,iso);
79  count++;
80  }
81 
82 
83  return 0;
84 }
85 
86 
87 
89 
90  unsigned int count=0;
91  for(std::map<std::string,edm::ParameterSet>::const_iterator i = labelMap_.begin();i!=labelMap_.end();++i) {
92  iEvent.getByLabel(i->second.getParameter<edm::InputTag>("chargedParticle"),chargedParticle_[count]);
93  iEvent.getByLabel(i->second.getParameter<edm::InputTag>("chargedHadron"),chargedHadron_[count]);
94  iEvent.getByLabel(i->second.getParameter<edm::InputTag>("neutralHadron"),neutralHadron_[count]);
95  iEvent.getByLabel(i->second.getParameter<edm::InputTag>("neutralHadronHighThreshold"),neutralHadronHighThreshold_[count]);
96  iEvent.getByLabel(i->second.getParameter<edm::InputTag>("photon"),photon_[count]);
97  iEvent.getByLabel(i->second.getParameter<edm::InputTag>("photonHighThreshold"),photonHighThreshold_[count]);
98  iEvent.getByLabel(i->second.getParameter<edm::InputTag>("pu"),pu_[count]);
99  count++;
100  }
101 
102 }
int i
Definition: DBlmapReader.cc:9
std::vector< edm::Handle< CandDoubleMap > > chargedHadron_
Definition: MuPFIsoHelper.h:54
float sumNeutralHadronEtHighThreshold
sum pt of neutral hadrons with a higher threshold
float sumPhotonEt
sum pt of PF photons
reco::MuonPFIsolation makeIsoDeposit(reco::MuonRef &, const edm::Handle< CandDoubleMap > &, const edm::Handle< CandDoubleMap > &, const edm::Handle< CandDoubleMap > &, const edm::Handle< CandDoubleMap > &, const edm::Handle< CandDoubleMap > &, const edm::Handle< CandDoubleMap > &, const edm::Handle< CandDoubleMap > &)
std::vector< edm::Handle< CandDoubleMap > > pu_
Definition: MuPFIsoHelper.h:59
float sumNeutralHadronEt
sum pt of neutral hadrons
float sumChargedParticlePt
sum-pt of charged Particles(inludes e/mu)
std::vector< edm::Handle< CandDoubleMap > > neutralHadronHighThreshold_
Definition: MuPFIsoHelper.h:56
float sumPUPt
sum pt of charged Particles not from PV (for Pu corrections)
int iEvent
Definition: GenABIO.cc:243
void setPFIsolation(const std::string &label, const reco::MuonPFIsolation &deposit)
Definition: Muon.cc:813
bool isValid() const
Definition: HandleBase.h:76
std::vector< edm::Handle< CandDoubleMap > > chargedParticle_
Definition: MuPFIsoHelper.h:53
bool getByLabel(InputTag const &tag, Handle< PROD > &result) const
Definition: Event.h:361
std::vector< edm::Handle< CandDoubleMap > > photon_
Definition: MuPFIsoHelper.h:57
std::vector< edm::Handle< CandDoubleMap > > neutralHadron_
Definition: MuPFIsoHelper.h:55
int embedPFIsolation(reco::Muon &, reco::MuonRef &)
std::vector< edm::Handle< CandDoubleMap > > photonHighThreshold_
Definition: MuPFIsoHelper.h:58
void beginEvent(const edm::Event &iEvent)
std::map< std::string, edm::ParameterSet > labelMap_
Definition: MuPFIsoHelper.h:51
MuPFIsoHelper(const std::map< std::string, edm::ParameterSet > &)
Definition: MuPFIsoHelper.cc:4
float sumPhotonEtHighThreshold
sum pt of PF photons with a higher threshold
float sumChargedHadronPt
sum-pt of charged Hadron