CMS 3D CMS Logo

GsfEleRelPFIsoScaledCut.cc
Go to the documentation of this file.
4 
6 public:
8 
9  result_type operator()(const reco::GsfElectronPtr&) const final;
10 
12  void getEventContent(const edm::EventBase&) final;
13 
14  double value(const reco::CandidatePtr& cand) const final;
15 
17 
18 private:
22 };
23 
25 
28  barrelC0_(c.getParameter<double>("barrelC0")),
29  endcapC0_(c.getParameter<double>("endcapC0")),
30  barrelCpt_(c.getParameter<double>("barrelCpt")),
31  endcapCpt_(c.getParameter<double>("endcapCpt")),
32  barrelCutOff_(c.getParameter<double>("barrelCutOff")),
33  effectiveAreas_((c.getParameter<edm::FileInPath>("effAreasConfigFile")).fullPath()) {
34  edm::InputTag rhoTag = c.getParameter<edm::InputTag>("rho");
35  contentTags_.emplace("rho", rhoTag);
36 }
37 
39  auto rho = cc.consumes<double>(contentTags_["rho"]);
40  contentTokens_.emplace("rho", rho);
41 }
42 
44  ev.getByLabel(contentTags_["rho"], rhoHandle_);
45 }
46 
48  // Establish the cut value
49  double absEta = std::abs(cand->superCluster()->eta());
50 
51  const float C0 = (absEta < barrelCutOff_ ? barrelC0_ : endcapC0_);
52  const float Cpt = (absEta < barrelCutOff_ ? barrelCpt_ : endcapCpt_);
53  const float isoCut = C0 + Cpt / cand->pt();
54 
55  return value(cand) < isoCut;
56 }
57 
59  // Establish the cut value
61  double absEta = std::abs(ele->superCluster()->eta());
62 
63  // Compute the combined isolation with effective area correction
64  auto pfIso = ele->pfIsolationVariables();
65  const float chad = pfIso.sumChargedHadronPt;
66  const float nhad = pfIso.sumNeutralHadronEt;
67  const float pho = pfIso.sumPhotonEt;
68  const float eA = effectiveAreas_.getEffectiveArea(absEta);
69  const float rho = rhoHandle_.isValid() ? (float)(*rhoHandle_) : 0; // std::max likes float arguments
70  const float iso = chad + std::max(0.0f, nhad + pho - rho * eA);
71  return iso / cand->pt();
72 }
dqmMemoryStats.float
float
Definition: dqmMemoryStats.py:127
GsfEleRelPFIsoScaledCut::effectiveAreas_
EffectiveAreas effectiveAreas_
Definition: GsfEleRelPFIsoScaledCut.cc:20
f
double f[11][100]
Definition: MuScleFitUtils.cc:78
contentValuesFiles.fullPath
fullPath
Definition: contentValuesFiles.py:64
edm
HLT enums.
Definition: AlignableModifier.h:19
GsfEleRelPFIsoScaledCut::barrelCutOff_
const float barrelCutOff_
Definition: GsfEleRelPFIsoScaledCut.cc:19
EffectiveAreas.h
watchdog.const
const
Definition: watchdog.py:83
edm::Handle< double >
GsfEleRelPFIsoScaledCut
Definition: GsfEleRelPFIsoScaledCut.cc:5
GsfEleRelPFIsoScaledCut::barrelC0_
const float barrelC0_
Definition: GsfEleRelPFIsoScaledCut.cc:19
CutApplicatorWithEventContentBase::contentTags_
std::unordered_map< std::string, edm::InputTag > contentTags_
Definition: CutApplicatorWithEventContentBase.h:35
HLT_FULL_cff.rhoTag
rhoTag
Definition: HLT_FULL_cff.py:14986
candidate_functions::CandidateCut::result_type
bool result_type
Definition: CandidateCut.h:11
EffectiveAreas
Definition: EffectiveAreas.h:7
GsfEleRelPFIsoScaledCut::GsfEleRelPFIsoScaledCut
GsfEleRelPFIsoScaledCut(const edm::ParameterSet &c)
Definition: GsfEleRelPFIsoScaledCut.cc:26
CutApplicatorWithEventContentBase.h
zSelection_cfi.isoCut
isoCut
Definition: zSelection_cfi.py:5
GsfElectron.h
DEFINE_EDM_PLUGIN
#define DEFINE_EDM_PLUGIN(factory, type, name)
Definition: PluginFactory.h:124
DDAxes::rho
edm::ParameterSet
Definition: ParameterSet.h:47
CutApplicatorBase::CandidateType
CandidateType
Definition: CutApplicatorBase.h:47
SiStripPI::max
Definition: SiStripPayloadInspectorHelper.h:169
GsfEleRelPFIsoScaledCut::candidateType
CandidateType candidateType() const final
Definition: GsfEleRelPFIsoScaledCut.cc:16
edmplugin::PluginFactory
Definition: PluginFactory.h:34
cand
Definition: decayParser.h:32
GsfEleRelPFIsoScaledCut::endcapCpt_
const float endcapCpt_
Definition: GsfEleRelPFIsoScaledCut.cc:19
HltBtagPostValidation_cff.c
c
Definition: HltBtagPostValidation_cff.py:31
cc
GsfEleRelPFIsoScaledCut::rhoHandle_
edm::Handle< double > rhoHandle_
Definition: GsfEleRelPFIsoScaledCut.cc:21
edm::Ptr< reco::GsfElectron >
GsfEleRelPFIsoScaledCut::barrelCpt_
const float barrelCpt_
Definition: GsfEleRelPFIsoScaledCut.cc:19
GsfEleRelPFIsoScaledCut::operator()
result_type operator()(const reco::GsfElectronPtr &) const final
Definition: GsfEleRelPFIsoScaledCut.cc:47
ev
bool ev
Definition: Hydjet2Hadronizer.cc:95
CutApplicatorWithEventContentBase::contentTokens_
std::unordered_map< std::string, edm::EDGetToken > contentTokens_
Definition: CutApplicatorWithEventContentBase.h:40
edm::EventBase
Definition: EventBase.h:46
EffectiveAreas::getEffectiveArea
const float getEffectiveArea(float eta) const
Definition: EffectiveAreas.cc:44
reco::GsfElectron::superCluster
SuperClusterRef superCluster() const override
reference to a SuperCluster
Definition: GsfElectron.h:163
GsfEleRelPFIsoScaledCut::setConsumes
void setConsumes(edm::ConsumesCollector &) final
Definition: GsfEleRelPFIsoScaledCut.cc:38
GsfEleRelPFIsoScaledCut::endcapC0_
const float endcapC0_
Definition: GsfEleRelPFIsoScaledCut.cc:19
funct::abs
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
reco::GsfElectron::pfIsolationVariables
const PflowIsolationVariables & pfIsolationVariables() const
Definition: GsfElectron.h:658
edm::HandleBase::isValid
bool isValid() const
Definition: HandleBase.h:70
CutApplicatorBase::ELECTRON
Definition: CutApplicatorBase.h:47
edm::InputTag
Definition: InputTag.h:15
GsfEleRelPFIsoScaledCut::value
double value(const reco::CandidatePtr &cand) const final
Definition: GsfEleRelPFIsoScaledCut.cc:58
edm::ConsumesCollector
Definition: ConsumesCollector.h:45
CutApplicatorWithEventContentBase
Definition: CutApplicatorWithEventContentBase.h:19
reco::GsfElectron::PflowIsolationVariables::sumChargedHadronPt
float sumChargedHadronPt
sum-pt of charged Hadron // old float chargedHadronIso ;
Definition: GsfElectron.h:608
GsfEleRelPFIsoScaledCut::getEventContent
void getEventContent(const edm::EventBase &) final
Definition: GsfEleRelPFIsoScaledCut.cc:43