CMS 3D CMS Logo

List of all members | Public Member Functions | Private Attributes | Static Private Attributes
PhoAnyPFIsoWithEAAndQuadScalingCut Class Reference
Inheritance diagram for PhoAnyPFIsoWithEAAndQuadScalingCut:
CutApplicatorWithEventContentBase CutApplicatorBase candidate_functions::CandidateCut

Public Member Functions

CandidateType candidateType () const final
 
void getEventContent (const edm::EventBase &) final
 
result_type operator() (const reco::PhotonPtr &) const final
 
 PhoAnyPFIsoWithEAAndQuadScalingCut (const edm::ParameterSet &c)
 
void setConsumes (edm::ConsumesCollector &) final
 
double value (const reco::CandidatePtr &cand) const final
 
- Public Member Functions inherited from CutApplicatorWithEventContentBase
 CutApplicatorWithEventContentBase ()
 
 CutApplicatorWithEventContentBase (const CutApplicatorWithEventContentBase &)=delete
 
 CutApplicatorWithEventContentBase (const edm::ParameterSet &c)
 
CutApplicatorWithEventContentBaseoperator= (const CutApplicatorWithEventContentBase &)=delete
 
 ~CutApplicatorWithEventContentBase () override
 Destructor. More...
 
- Public Member Functions inherited from CutApplicatorBase
virtual result_type asCandidate (const argument_type &) const
 
 CutApplicatorBase ()
 
 CutApplicatorBase (const CutApplicatorBase &)=delete
 
 CutApplicatorBase (const edm::ParameterSet &c)
 
const std::string & name () const override
 
result_type operator() (const argument_type &) const final
 
virtual result_type operator() (const pat::ElectronPtr &) const
 
virtual result_type operator() (const pat::MuonPtr &) const
 
virtual result_type operator() (const reco::GsfElectronPtr &) const
 
virtual result_type operator() (const reco::MuonPtr &) const
 
CutApplicatorBaseoperator= (const CutApplicatorBase &)=delete
 
 ~CutApplicatorBase () override
 Destructor. More...
 
- Public Member Functions inherited from candidate_functions::CandidateCut
 CandidateCut ()
 
virtual ~CandidateCut ()
 

Private Attributes

edm::Handle< edm::ValueMap< float > > _anyPFIsoMap
 
float _barrelCutOff
 
float _C1_EB
 
float _C1_EE
 
float _C2_EB
 
float _C2_EE
 
float _C3_EB
 
float _C3_EE
 
EffectiveAreas _effectiveAreas
 
edm::Handle< double > _rhoHandle
 
bool _useRelativeIso
 

Static Private Attributes

constexpr static char anyPFIsoWithEA_ [] = "anyPFIsoWithEA"
 
constexpr static char rhoString_ [] = "rho"
 

Additional Inherited Members

- Public Types inherited from CutApplicatorBase
enum  CandidateType {
  NONE, ELECTRON, MUON, PHOTON,
  TAU, PATELECTRON, PATMUON, PATPHOTON,
  PATTAU
}
 
- Public Types inherited from candidate_functions::CandidateCut
using argument_type = reco::CandidatePtr
 
using result_type = bool
 
- Protected Attributes inherited from CutApplicatorWithEventContentBase
std::unordered_map< std::string, edm::InputTagcontentTags_
 
std::unordered_map< std::string, edm::EDGetTokencontentTokens_
 

Detailed Description

Definition at line 5 of file PhoAnyPFIsoWithEAAndQuadScalingCut.cc.

Constructor & Destructor Documentation

◆ PhoAnyPFIsoWithEAAndQuadScalingCut()

PhoAnyPFIsoWithEAAndQuadScalingCut::PhoAnyPFIsoWithEAAndQuadScalingCut ( const edm::ParameterSet c)

Definition at line 45 of file PhoAnyPFIsoWithEAAndQuadScalingCut.cc.

47  _C1_EB(c.getParameter<double>("C1_EB")),
48  _C2_EB(c.getParameter<double>("C2_EB")),
49  _C3_EB(c.getParameter<double>("C3_EB")),
50  _C1_EE(c.getParameter<double>("C1_EE")),
51  _C2_EE(c.getParameter<double>("C2_EE")),
52  _C3_EE(c.getParameter<double>("C3_EE")),
53  _barrelCutOff(c.getParameter<double>("barrelCutOff")),
54  _useRelativeIso(c.getParameter<bool>("useRelativeIso")),
55  _effectiveAreas((c.getParameter<edm::FileInPath>("effAreasConfigFile")).fullPath()) {
56  edm::InputTag maptag = c.getParameter<edm::InputTag>("anyPFIsoMap");
57  contentTags_.emplace(anyPFIsoWithEA_, maptag);
58 
59  edm::InputTag rhoTag = c.getParameter<edm::InputTag>("rho");
60  contentTags_.emplace(rhoString_, rhoTag);
61 }

References anyPFIsoWithEA_, HltBtagPostValidation_cff::c, CutApplicatorWithEventContentBase::contentTags_, rhoString_, and HLT_FULL_cff::rhoTag.

Member Function Documentation

◆ candidateType()

CandidateType PhoAnyPFIsoWithEAAndQuadScalingCut::candidateType ( ) const
inlinefinalvirtual

Reimplemented from CutApplicatorBase.

Definition at line 16 of file PhoAnyPFIsoWithEAAndQuadScalingCut.cc.

16 { return PHOTON; }

References CutApplicatorBase::PHOTON.

◆ getEventContent()

void PhoAnyPFIsoWithEAAndQuadScalingCut::getEventContent ( const edm::EventBase ev)
finalvirtual

◆ operator()()

CutApplicatorBase::result_type PhoAnyPFIsoWithEAAndQuadScalingCut::operator() ( const reco::PhotonPtr cand) const
finalvirtual

Reimplemented from CutApplicatorBase.

Definition at line 76 of file PhoAnyPFIsoWithEAAndQuadScalingCut.cc.

76  {
77  // in case we are by-value
78  const std::string& inst_name = contentTags_.find(anyPFIsoWithEA_)->second.instance();
80  float anyisoval = -1.0;
81  if (_anyPFIsoMap.isValid() && _anyPFIsoMap->contains(cand.id())) {
82  anyisoval = (*_anyPFIsoMap)[cand];
83  } else if (_anyPFIsoMap.isValid() && _anyPFIsoMap->idSize() == 1 && cand.id() == edm::ProductID()) {
84  // in case we have spoofed a ptr
85  //note this must be a 1:1 valuemap (only one product input)
86  anyisoval = _anyPFIsoMap->begin()[cand.key()];
87  } else if (_anyPFIsoMap.isValid()) { // throw an exception
88  anyisoval = (*_anyPFIsoMap)[cand];
89  }
90 
91  // Figure out the cut value
92  // The value is generally pt-dependent: C1 + pt * C2
93  const float pt = cand->pt();
94 
95  // In this version of the isolation cut we apply
96  // exponential pt scaling to the barrel isolation cut,
97  // and linear pt scaling to the endcap isolation cut.
98  double absEta = std::abs(cand->superCluster()->eta());
99  const float isolationCutValue =
100  (absEta < _barrelCutOff ? _C1_EB + pt * _C2_EB + pt * pt * _C3_EB : _C1_EE + pt * _C2_EE + pt * pt * _C3_EE);
101 
102  // Retrieve the variable value for this particle
103  float anyPFIso = _anyPFIsoMap.isValid() ? anyisoval : pat->userFloat(inst_name);
104 
105  // Apply pile-up correction
106  double eA = _effectiveAreas.getEffectiveArea(absEta);
107  double rho = *_rhoHandle;
108  float anyPFIsoWithEA = std::max(0.0, anyPFIso - rho * eA);
109 
110  // Divide by pT if the relative isolation is requested
111  if (_useRelativeIso)
112  anyPFIsoWithEA /= pt;
113 
114  // Apply the cut and return the result
115  return anyPFIsoWithEA < isolationCutValue;
116 }

References _anyPFIsoMap, _barrelCutOff, _C1_EB, _C1_EE, _C2_EB, _C2_EE, _C3_EB, _C3_EE, _effectiveAreas, _rhoHandle, _useRelativeIso, funct::abs(), anyPFIsoWithEA_, edm::ValueMap< T >::begin(), edm::ValueMap< T >::contains(), CutApplicatorWithEventContentBase::contentTags_, EffectiveAreas::getEffectiveArea(), edm::ValueMap< T >::idSize(), edm::HandleBase::isValid(), SiStripPI::max, DiDispStaMuonMonitor_cfi::pt, rho, and AlCaHLTBitMon_QueryRunRegistry::string.

◆ setConsumes()

void PhoAnyPFIsoWithEAAndQuadScalingCut::setConsumes ( edm::ConsumesCollector cc)
finalvirtual

Implements CutApplicatorWithEventContentBase.

Definition at line 63 of file PhoAnyPFIsoWithEAAndQuadScalingCut.cc.

63  {
64  auto anyPFIsoWithEA = cc.consumes<edm::ValueMap<float> >(contentTags_[anyPFIsoWithEA_]);
65  contentTokens_.emplace(anyPFIsoWithEA_, anyPFIsoWithEA);
66 
67  auto rho = cc.consumes<double>(contentTags_[rhoString_]);
68  contentTokens_.emplace(rhoString_, rho);
69 }

References anyPFIsoWithEA_, CutApplicatorWithEventContentBase::contentTags_, CutApplicatorWithEventContentBase::contentTokens_, rho, and rhoString_.

◆ value()

double PhoAnyPFIsoWithEAAndQuadScalingCut::value ( const reco::CandidatePtr cand) const
finalvirtual

Implements candidate_functions::CandidateCut.

Definition at line 118 of file PhoAnyPFIsoWithEAAndQuadScalingCut.cc.

118  {
119  reco::PhotonPtr pho(cand);
120 
121  // in case we are by-value
122  const std::string& inst_name = contentTags_.find(anyPFIsoWithEA_)->second.instance();
124  float anyisoval = -1.0;
125  if (_anyPFIsoMap.isValid() && _anyPFIsoMap->contains(cand.id())) {
126  anyisoval = (*_anyPFIsoMap)[cand];
127  } else if (_anyPFIsoMap.isValid() && _anyPFIsoMap->idSize() == 1 && cand.id() == edm::ProductID()) {
128  // in case we have spoofed a ptr
129  //note this must be a 1:1 valuemap (only one product input)
130  anyisoval = _anyPFIsoMap->begin()[cand.key()];
131  } else if (_anyPFIsoMap.isValid()) { // throw an exception
132  anyisoval = (*_anyPFIsoMap)[cand];
133  }
134 
135  // Figure out the cut value
136  // The value is generally pt-dependent: C1 + pt * C2
137  const float pt = pho->pt();
138 
139  // In this version of the isolation cut we apply
140  // exponential pt scaling to the barrel isolation cut,
141  // and linear pt scaling to the endcap isolation cut.
142  double absEta = std::abs(pho->superCluster()->eta());
143 
144  // Retrieve the variable value for this particle
145  float anyPFIso = _anyPFIsoMap.isValid() ? anyisoval : pat->userFloat(inst_name);
146 
147  // Apply pile-up correction
148  double eA = _effectiveAreas.getEffectiveArea(absEta);
149  double rho = *_rhoHandle;
150  float anyPFIsoWithEA = std::max(0.0, anyPFIso - rho * eA);
151 
152  // Divide by pT if the relative isolation is requested
153  if (_useRelativeIso)
154  anyPFIsoWithEA /= pt;
155 
156  // Apply the cut and return the result
157  return anyPFIsoWithEA;
158 }

References _anyPFIsoMap, _effectiveAreas, _rhoHandle, _useRelativeIso, funct::abs(), anyPFIsoWithEA_, edm::ValueMap< T >::begin(), edm::ValueMap< T >::contains(), CutApplicatorWithEventContentBase::contentTags_, EffectiveAreas::getEffectiveArea(), edm::ValueMap< T >::idSize(), edm::HandleBase::isValid(), SiStripPI::max, DiDispStaMuonMonitor_cfi::pt, rho, and AlCaHLTBitMon_QueryRunRegistry::string.

Member Data Documentation

◆ _anyPFIsoMap

edm::Handle<edm::ValueMap<float> > PhoAnyPFIsoWithEAAndQuadScalingCut::_anyPFIsoMap
private

Definition at line 32 of file PhoAnyPFIsoWithEAAndQuadScalingCut.cc.

Referenced by getEventContent(), operator()(), and value().

◆ _barrelCutOff

float PhoAnyPFIsoWithEAAndQuadScalingCut::_barrelCutOff
private

Definition at line 27 of file PhoAnyPFIsoWithEAAndQuadScalingCut.cc.

Referenced by operator()().

◆ _C1_EB

float PhoAnyPFIsoWithEAAndQuadScalingCut::_C1_EB
private

Definition at line 20 of file PhoAnyPFIsoWithEAAndQuadScalingCut.cc.

Referenced by operator()().

◆ _C1_EE

float PhoAnyPFIsoWithEAAndQuadScalingCut::_C1_EE
private

Definition at line 23 of file PhoAnyPFIsoWithEAAndQuadScalingCut.cc.

Referenced by operator()().

◆ _C2_EB

float PhoAnyPFIsoWithEAAndQuadScalingCut::_C2_EB
private

Definition at line 21 of file PhoAnyPFIsoWithEAAndQuadScalingCut.cc.

Referenced by operator()().

◆ _C2_EE

float PhoAnyPFIsoWithEAAndQuadScalingCut::_C2_EE
private

Definition at line 24 of file PhoAnyPFIsoWithEAAndQuadScalingCut.cc.

Referenced by operator()().

◆ _C3_EB

float PhoAnyPFIsoWithEAAndQuadScalingCut::_C3_EB
private

Definition at line 22 of file PhoAnyPFIsoWithEAAndQuadScalingCut.cc.

Referenced by operator()().

◆ _C3_EE

float PhoAnyPFIsoWithEAAndQuadScalingCut::_C3_EE
private

Definition at line 25 of file PhoAnyPFIsoWithEAAndQuadScalingCut.cc.

Referenced by operator()().

◆ _effectiveAreas

EffectiveAreas PhoAnyPFIsoWithEAAndQuadScalingCut::_effectiveAreas
private

Definition at line 30 of file PhoAnyPFIsoWithEAAndQuadScalingCut.cc.

Referenced by operator()(), and value().

◆ _rhoHandle

edm::Handle<double> PhoAnyPFIsoWithEAAndQuadScalingCut::_rhoHandle
private

Definition at line 34 of file PhoAnyPFIsoWithEAAndQuadScalingCut.cc.

Referenced by getEventContent(), operator()(), and value().

◆ _useRelativeIso

bool PhoAnyPFIsoWithEAAndQuadScalingCut::_useRelativeIso
private

Definition at line 28 of file PhoAnyPFIsoWithEAAndQuadScalingCut.cc.

Referenced by operator()(), and value().

◆ anyPFIsoWithEA_

constexpr char PhoAnyPFIsoWithEAAndQuadScalingCut::anyPFIsoWithEA_ = "anyPFIsoWithEA"
staticconstexprprivate

◆ rhoString_

constexpr char PhoAnyPFIsoWithEAAndQuadScalingCut::rhoString_ = "rho"
staticconstexprprivate
PhoAnyPFIsoWithEAAndQuadScalingCut::_barrelCutOff
float _barrelCutOff
Definition: PhoAnyPFIsoWithEAAndQuadScalingCut.cc:27
PhoAnyPFIsoWithEAAndQuadScalingCut::_C1_EB
float _C1_EB
Definition: PhoAnyPFIsoWithEAAndQuadScalingCut.cc:20
CutApplicatorBase::PHOTON
Definition: CutApplicatorBase.h:47
DiDispStaMuonMonitor_cfi.pt
pt
Definition: DiDispStaMuonMonitor_cfi.py:39
PhoAnyPFIsoWithEAAndQuadScalingCut::rhoString_
constexpr static char rhoString_[]
Definition: PhoAnyPFIsoWithEAAndQuadScalingCut.cc:37
PhoAnyPFIsoWithEAAndQuadScalingCut::_C2_EE
float _C2_EE
Definition: PhoAnyPFIsoWithEAAndQuadScalingCut.cc:24
PhoAnyPFIsoWithEAAndQuadScalingCut::_rhoHandle
edm::Handle< double > _rhoHandle
Definition: PhoAnyPFIsoWithEAAndQuadScalingCut.cc:34
CutApplicatorWithEventContentBase::contentTags_
std::unordered_map< std::string, edm::InputTag > contentTags_
Definition: CutApplicatorWithEventContentBase.h:35
HLT_FULL_cff.rhoTag
rhoTag
Definition: HLT_FULL_cff.py:15052
edm::FileInPath
Definition: FileInPath.h:64
PhoAnyPFIsoWithEAAndQuadScalingCut::_C2_EB
float _C2_EB
Definition: PhoAnyPFIsoWithEAAndQuadScalingCut.cc:21
PhoAnyPFIsoWithEAAndQuadScalingCut::_C1_EE
float _C1_EE
Definition: PhoAnyPFIsoWithEAAndQuadScalingCut.cc:23
PhoAnyPFIsoWithEAAndQuadScalingCut::_useRelativeIso
bool _useRelativeIso
Definition: PhoAnyPFIsoWithEAAndQuadScalingCut.cc:28
PhoAnyPFIsoWithEAAndQuadScalingCut::_C3_EE
float _C3_EE
Definition: PhoAnyPFIsoWithEAAndQuadScalingCut.cc:25
PhoAnyPFIsoWithEAAndQuadScalingCut::_C3_EB
float _C3_EB
Definition: PhoAnyPFIsoWithEAAndQuadScalingCut.cc:22
DDAxes::rho
AlCaHLTBitMon_QueryRunRegistry.string
string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
PhoAnyPFIsoWithEAAndQuadScalingCut::_anyPFIsoMap
edm::Handle< edm::ValueMap< float > > _anyPFIsoMap
Definition: PhoAnyPFIsoWithEAAndQuadScalingCut.cc:32
CutApplicatorWithEventContentBase::CutApplicatorWithEventContentBase
CutApplicatorWithEventContentBase()
Definition: CutApplicatorWithEventContentBase.h:21
SiStripPI::max
Definition: SiStripPayloadInspectorHelper.h:169
edm::ValueMap::begin
const_iterator begin() const
Definition: ValueMap.h:229
cand
Definition: decayParser.h:32
pat
Definition: HeavyIon.h:7
HltBtagPostValidation_cff.c
c
Definition: HltBtagPostValidation_cff.py:31
PhoAnyPFIsoWithEAAndQuadScalingCut::_effectiveAreas
EffectiveAreas _effectiveAreas
Definition: PhoAnyPFIsoWithEAAndQuadScalingCut.cc:30
cc
edm::Ptr
Definition: AssociationVector.h:31
edm::ValueMap::idSize
size_t idSize() const
Definition: ValueMap.h:157
edm::ValueMap< float >
ev
bool ev
Definition: Hydjet2Hadronizer.cc:95
CutApplicatorWithEventContentBase::contentTokens_
std::unordered_map< std::string, edm::EDGetToken > contentTokens_
Definition: CutApplicatorWithEventContentBase.h:40
PhoAnyPFIsoWithEAAndQuadScalingCut::anyPFIsoWithEA_
constexpr static char anyPFIsoWithEA_[]
Definition: PhoAnyPFIsoWithEAAndQuadScalingCut.cc:36
EffectiveAreas::getEffectiveArea
const float getEffectiveArea(float eta) const
Definition: EffectiveAreas.cc:44
edm::ValueMap::contains
bool contains(ProductID id) const
Definition: ValueMap.h:155
funct::abs
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
edm::HandleBase::isValid
bool isValid() const
Definition: HandleBase.h:70
edm::InputTag
Definition: InputTag.h:15
edm::ProductID
Definition: ProductID.h:27