CMS 3D CMS Logo

PhoAnyPFIsoWithEAAndQuadScalingCut.cc
Go to the documentation of this file.
4 
6 public:
8 
9  result_type operator()(const reco::PhotonPtr&) const final;
10 
12  void getEventContent(const edm::EventBase&) final;
13 
14  double value(const reco::CandidatePtr& cand) const final;
15 
17 
18 private:
19  // Cut values
20  float _C1_EB;
21  float _C2_EB;
22  float _C3_EB;
23  float _C1_EE;
24  float _C2_EE;
25  float _C3_EE;
26  // Configuration
29  // Effective area constants
31  // The isolations computed upstream
33  // The rho
35 
36  constexpr static char anyPFIsoWithEA_[] = "anyPFIsoWithEA";
37  constexpr static char rhoString_[] = "rho";
38 };
39 
42 
43 DEFINE_EDM_PLUGIN(CutApplicatorFactory, PhoAnyPFIsoWithEAAndQuadScalingCut, "PhoAnyPFIsoWithEAAndQuadScalingCut");
44 
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 }
62 
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 }
70 
73  ev.getByLabel(contentTags_[rhoString_], _rhoHandle);
74 }
75 
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 }
117 
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 }
EDGetTokenT< ProductType > consumes(edm::InputTag const &tag)
std::unordered_map< std::string, edm::InputTag > contentTags_
size_t idSize() const
Definition: ValueMap.h:157
PhoAnyPFIsoWithEAAndQuadScalingCut(const edm::ParameterSet &c)
Definition: HeavyIon.h:7
void setConsumes(edm::ConsumesCollector &) final
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
double value(const reco::CandidatePtr &cand) const final
const float getEffectiveArea(float eta) const
const_iterator begin() const
Definition: ValueMap.h:229
void getEventContent(const edm::EventBase &) final
std::unordered_map< std::string, edm::EDGetToken > contentTokens_
result_type operator()(const reco::PhotonPtr &) const final
bool isValid() const
Definition: HandleBase.h:70
HLT enums.
#define DEFINE_EDM_PLUGIN(factory, type, name)
bool contains(ProductID id) const
Definition: ValueMap.h:155
edm::Handle< edm::ValueMap< float > > _anyPFIsoMap