CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
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"))),
35  matchMapTokens_(edm::vector_transform(
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;
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) {
62  GenParticleMatch::Filler filler(*matchMap);
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  }
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 
95 
96  } // namespace modulesNew
97 } // namespace reco
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:133
tuple cfg
Definition: looper.py:296
std::vector< edm::EDGetTokenT< reco::GenParticleMatch > > matchMapTokens_
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:539
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
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
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 find(edm::Handle< EcalRecHitCollection > &hits, DetId thisDet, std::vector< EcalRecHitCollection::const_iterator > &hit, bool debug=false)
Definition: FindCaloHit.cc:19
def move
Definition: eostools.py:511
pdgId_(cfg.getParameter< std::vector< int > >("matchPDGId"))
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
bool isNull() const
Checks for null.
Definition: Ref.h:235
void produce(edm::Event &, const edm::EventSetup &) override
MCTruthCompositeMatcher MCTruthCompositeMatcherNew
RefToBaseProd< T > makeRefToBaseProdFrom(RefToBase< T > const &iRef, Event const &iEvent)
string end
Definition: dataset.py:937
std::pair< typename Association::data_type::first_type, double > match(Reference key, Association association, bool bestMatchByMaxValue)
Generic matching function.
Definition: Utils.h:10
list indices
Definition: dqmdumpme.py:50
tuple size
Write out results.
def template
Definition: svgfig.py:521