CMS 3D CMS Logo

MCTruthCompositeMatcherNew.cc
Go to the documentation of this file.
1 /* \class MCTruthCompositeMatcher
2  *
3  * \author Luca Lista, INFN
4  *
5  */
6 
17 
18 namespace reco {
19  namespace modulesNew {
20 
22  public:
24  ~MCTruthCompositeMatcher() override;
25 
26  private:
28  std::vector<edm::EDGetTokenT<reco::GenParticleMatch> > matchMapTokens_;
29  std::vector<int> pdgId_;
30  void produce(edm::Event &, const edm::EventSetup &) override;
31  };
32 
34  : srcToken_(consumes<CandidateView>(cfg.getParameter<edm::InputTag>("src"))),
36  cfg.template getParameter<std::vector<edm::InputTag> >("matchMaps"),
37  [this](edm::InputTag const &tag) { return consumes<reco::GenParticleMatch>(tag); })),
38  pdgId_(cfg.getParameter<std::vector<int> >("matchPDGId")) {
39  produces<reco::GenParticleMatch>();
40  }
41 
43 
45  using namespace edm;
46  using namespace std;
48  evt.getByToken(srcToken_, cands);
49  size_t nMaps = matchMapTokens_.size();
50  std::vector<const GenParticleMatch *> maps;
51  maps.reserve(nMaps);
52  for (size_t i = 0; i != nMaps; ++i) {
54  evt.getByToken(matchMapTokens_[i], matchMap);
55  maps.push_back(&*matchMap);
56  }
58  auto matchMap = std::make_unique<GenParticleMatch>(match.ref());
59  int size = cands->size();
60  vector<int>::const_iterator begin = pdgId_.begin(), end = pdgId_.end();
61  if (size != 0) {
63  vector<int> indices(size);
64  for (int i = 0; i != size; ++i) {
65  const Candidate &cand = (*cands)[i];
66  GenParticleRef mc = match[cand];
67  if (mc.isNull()) {
68  indices[i] = -1;
69  } else {
70  bool found = true;
71  if (begin != end)
72  found = find(begin, end, std::abs(mc->pdgId())) != end;
73  indices[i] = found ? int(mc.key()) : -1;
74  }
75  }
76  CandidateBaseRefProd ref(edm::makeRefToBaseProdFrom(cands->refAt(0), evt));
77  filler.insert(ref, indices.begin(), indices.end());
78  filler.fill();
79  }
80  evt.put(std::move(matchMap));
81  }
82 
83  } // namespace modulesNew
84 } // namespace reco
85 
88 
89 namespace reco {
90  namespace modulesNew {
91 
93 
94  DEFINE_FWK_MODULE(MCTruthCompositeMatcherNew);
95 
96  } // namespace modulesNew
97 } // namespace reco
size
Write out results.
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:131
std::vector< edm::EDGetTokenT< reco::GenParticleMatch > > matchMapTokens_
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:525
void insert(const H &h, I begin, I end)
Definition: ValueMap.h:53
map_type::refprod_type ref() const
reference to matched collection
key_type key() const
Accessor for product key.
Definition: Ref.h:250
void find(edm::Handle< EcalRecHitCollection > &hits, DetId thisDet, std::vector< EcalRecHitCollection::const_iterator > &hit, bool debug=false)
Definition: FindCaloHit.cc:19
EDGetTokenT< ProductType > consumes(edm::InputTag const &tag)
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
def template(fileName, svg, replaceme="REPLACEME")
Definition: svgfig.py:521
#define end
Definition: vmac.h:39
bool isNull() const
Checks for null.
Definition: Ref.h:235
auto vector_transform(std::vector< InputType > const &input, Function predicate) -> std::vector< typename std::remove_cv< typename std::remove_reference< decltype(predicate(input.front()))>::type >::type >
Definition: transform.h:11
void produce(edm::Event &, const edm::EventSetup &) override
MCTruthCompositeMatcher MCTruthCompositeMatcherNew
RefToBaseProd< T > makeRefToBaseProdFrom(RefToBase< T > const &iRef, Event const &iEvent)
fixed size matrix
#define begin
Definition: vmac.h:32
HLT enums.
std::pair< typename Association::data_type::first_type, double > match(Reference key, Association association, bool bestMatchByMaxValue)
Generic matching function.
Definition: Utils.h:10
def move(src, dest)
Definition: eostools.py:511