CMS 3D CMS Logo

All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
GsfEleDEtaInSeedCut.cc
Go to the documentation of this file.
3 
5 public:
8  _dEtaInSeedCutValueEB(c.getParameter<double>("dEtaInSeedCutValueEB")),
9  _dEtaInSeedCutValueEE(c.getParameter<double>("dEtaInSeedCutValueEE")),
10  _barrelCutOff(c.getParameter<double>("barrelCutOff")){
11  }
12 
13  result_type operator()(const reco::GsfElectronPtr&) const override final;
14 
15  CandidateType candidateType() const override final {
16  return ELECTRON;
17  }
18 
19 private:
21 };
22 
25  "GsfEleDEtaInSeedCut");
26 
27 //a little temporary 72X fix
28 float dEtaInSeed(const reco::GsfElectronPtr& ele){
29  return ele->superCluster().isNonnull() && ele->superCluster()->seed().isNonnull() ?
30  ele->deltaEtaSuperClusterTrackAtVtx() - ele->superCluster()->eta() + ele->superCluster()->seed()->eta() : std::numeric_limits<float>::max();
31 }
32 
33 CutApplicatorBase::result_type
35 operator()(const reco::GsfElectronPtr& cand) const{
36  const float dEtaInSeedCutValue =
37  ( std::abs(cand->superCluster()->eta()) < _barrelCutOff ?
39  // return std::abs(cand->deltaEtaSeedClusterTrackAtVtx()) < dEtaInSeedCutValue;
40  return std::abs(dEtaInSeed(cand))<dEtaInSeedCutValue;
41 }
42 
43 
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
const double _dEtaInSeedCutValueEB
const double _dEtaInSeedCutValueEE
bool isNonnull() const
Checks for non-null.
Definition: Ptr.h:152
GsfEleDEtaInSeedCut(const edm::ParameterSet &c)
float dEtaInSeed(const reco::GsfElectronPtr &ele)
result_type operator()(const reco::GsfElectronPtr &) const overridefinal
string const
Definition: compareJSON.py:14
#define DEFINE_EDM_PLUGIN(factory, type, name)
CandidateType candidateType() const overridefinal