CMS 3D CMS Logo

CandIsolatorFromDeposits.h
Go to the documentation of this file.
1 #ifndef MuonIsolationProducers_CandIsolatorFromDeposits_H
2 #define MuonIsolationProducers_CandIsolatorFromDeposits_H
3 
7 
13 
17 
18 #include <string>
19 
20 namespace edm {
21  class Event;
22 }
23 namespace edm {
24  class EventSetup;
25 }
26 
28 public:
30 
31  enum Mode { Sum, SumRelative, Sum2, Sum2Relative, Max, MaxRelative, Count, NearestDR, MeanDR, SumDR };
33 
34  ~CandIsolatorFromDeposits() override;
35 
36  void produce(edm::Event &, const edm::EventSetup &) override;
37 
38 private:
39  class SingleDeposit {
40  public:
42  void cleanup();
43  void open(const edm::Event &iEvent, const edm::EventSetup &iSetup);
44  double compute(const reco::CandidateBaseRef &cand);
45  const reco::IsoDepositMap &map() { return *hDeps_; }
46 
47  private:
50  double deltaR_;
52  double weight_;
55  reco::isodeposit::EventDependentAbsVetos evdepVetos_; // note: these are a subset of the above. Don't delete twice!
58  };
59  // datamembers
60  std::vector<SingleDeposit> sources_;
61 };
62 #endif
StringObjectFunction< reco::Candidate > weightExpr_
static void cleanup(const Factory::MakerMap::value_type &v)
Definition: Factory.cc:12
std::vector< SingleDeposit > sources_
edm::ValueMap< double > CandDoubleMap
edm::Handle< reco::IsoDepositMap > hDeps_
std::vector< EventDependentAbsVeto * > EventDependentAbsVetos
int iEvent
Definition: GenABIO.cc:224
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:43
reco::isodeposit::EventDependentAbsVetos evdepVetos_