CMS 3D CMS Logo

PFCandIsolatorFromDeposit.h
Go to the documentation of this file.
1 #ifndef PFCandIsolatorFromDeposits_H
2 #define PFCandIsolatorFromDeposits_H
3 
7 
13 
17 
18 #include <string>
19 
20 namespace edm { class Event; }
21 namespace edm { class EventSetup; }
22 
24 
25 public:
27 
28  enum Mode { Sum, SumRelative, Sum2, Sum2Relative, Max, MaxRelative, Count, NearestDR };
30 
31  ~PFCandIsolatorFromDeposits() override;
32 
33  void produce(edm::Event&, const edm::EventSetup&) override;
34 
35 private:
36  class SingleDeposit {
37  public:
39  void cleanup() ;
40  void open(const edm::Event &iEvent, const edm::EventSetup &iSetup) ;
41  double compute(const reco::CandidateBaseRef &cand) ;
42  const reco::IsoDepositMap & map() { return *hDeps_; }
43  private:
46  double deltaR_;
48  double weight_;
49 
53  reco::isodeposit::EventDependentAbsVetos evdepVetos_; // note: these are a subset of the above. Don't delete twice!
57 
58  bool isNumber(const std::string &str) const ;
59  double toNumber(const std::string &str) const ;
60  };
61  // datamembers
62  std::vector<SingleDeposit> sources_;
63 
64 
65 
66 };
67 #endif
bool isNumber(const std::string &str)
std::vector< SingleDeposit > sources_
StringObjectFunction< reco::Candidate > weightExpr_
static void cleanup(const Factory::MakerMap::value_type &v)
Definition: Factory.cc:12
std::vector< EventDependentAbsVeto * > EventDependentAbsVetos
double toNumber(const std::string &str)
int iEvent
Definition: GenABIO.cc:230
reco::isodeposit::EventDependentAbsVetos evdepVetos_
edm::Handle< reco::IsoDepositMap > hDeps_
edm::EDGetTokenT< reco::IsoDepositMap > srcToken_
T Max(T a, T b)
Definition: MathUtil.h:44
def compute(min, max)
HLT enums.
std::vector< AbsVeto * > AbsVetos
Definition: IsoDeposit.h:40
#define str(s)
edm::ValueMap< double > CandDoubleMap