CMS 3D CMS Logo

PATCompositeCandidateProducer.cc
Go to the documentation of this file.
1 
31 
32 namespace pat {
33 
35  public:
36  explicit PATCompositeCandidateProducer(const edm::ParameterSet& iConfig);
38 
39  void produce(edm::Event& iEvent, const edm::EventSetup& iSetup) override;
40 
41  private:
42  // configurables
43  const edm::EDGetTokenT<edm::View<reco::CompositeCandidate> > srcToken_; // list of reco::CompositeCandidates
44 
45  const bool useUserData_;
47 
48  const bool addEfficiencies_;
50 
51  const bool addResolutions_;
53  };
54 
55 } // namespace pat
56 
57 using namespace pat;
58 using namespace std;
59 using namespace edm;
60 
62  : srcToken_(consumes<edm::View<reco::CompositeCandidate> >(iConfig.getParameter<InputTag>("src"))),
63  useUserData_(iConfig.exists("userData")),
64  userDataHelper_(iConfig.getParameter<edm::ParameterSet>("userData"), consumesCollector()),
65  addEfficiencies_(iConfig.getParameter<bool>("addEfficiencies")),
66  addResolutions_(iConfig.getParameter<bool>("addResolutions")) {
67  // Efficiency configurables
68  if (addEfficiencies_) {
70  pat::helper::EfficiencyLoader(iConfig.getParameter<edm::ParameterSet>("efficiencies"), consumesCollector());
71  }
72 
73  // Resolution configurables
74  if (addResolutions_) {
76  pat::helper::KinResolutionsLoader(iConfig.getParameter<edm::ParameterSet>("resolutions"), consumesCollector());
77  }
78 
79  // produces vector of particles
80  produces<vector<pat::CompositeCandidate> >();
81 }
82 
84 
86  // Get the vector of CompositeCandidate's from the event
88  iEvent.getByToken(srcToken_, cands);
89 
94 
95  auto myCompositeCandidates = std::make_unique<vector<pat::CompositeCandidate> >();
96 
97  if (cands.isValid()) {
98  View<reco::CompositeCandidate>::const_iterator ibegin = cands->begin(), iend = cands->end(), i = ibegin;
99  for (; i != iend; ++i) {
101 
102  if (useUserData_) {
103  userDataHelper_.add(cand, iEvent, iSetup);
104  }
105 
107  efficiencyLoader_.setEfficiencies(cand, cands->refAt(i - cands->begin()));
110 
111  myCompositeCandidates->push_back(std::move(cand));
112  }
113 
114  } // end if the two handles are valid
115 
116  iEvent.put(std::move(myCompositeCandidates));
117 }
118 
120 
Analysis-level particle class.
bool enabled() const
&#39;true&#39; if this there is at least one efficiency configured
void newEvent(const edm::Event &event)
To be called for each new event, reads in the ValueMaps for efficiencies.
T getParameter(std::string const &) const
Definition: ParameterSet.h:307
void setEfficiencies(pat::PATObject< T > &obj, const R &originalRef) const
Sets the efficiencies for this object, using the reference to the original objects.
void produce(edm::Event &iEvent, const edm::EventSetup &iSetup) override
pat::PATUserDataHelper< pat::CompositeCandidate > userDataHelper_
void setResolutions(pat::PATObject< T > &obj) const
Sets the efficiencies for this object, using the reference to the original objects.
Definition: HeavyIon.h:7
int iEvent
Definition: GenABIO.cc:224
void newEvent(const edm::Event &event, const edm::EventSetup &setup)
To be called for each new event, reads in the EventSetup object.
bool enabled() const
&#39;true&#39; if this there is at least one efficiency configured
pat::helper::KinResolutionsLoader resolutionLoader_
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
void add(ObjectType &patObject, edm::Event const &iEvent, edm::EventSetup const &iSetup)
Produces the pat::CompositeCandidate.
const edm::EDGetTokenT< edm::View< reco::CompositeCandidate > > srcToken_
fixed size matrix
HLT enums.
boost::indirect_iterator< typename seq_t::const_iterator > const_iterator
Definition: View.h:88
PATCompositeCandidateProducer(const edm::ParameterSet &iConfig)
def move(src, dest)
Definition: eostools.py:511
pat::helper::EfficiencyLoader efficiencyLoader_