CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
CombinedRecHitCollectionProducer.cc
Go to the documentation of this file.
1 #ifndef RECOECAL_EGAMMACLUSTERPRODUCERS_COMBINEDDRECHITCOLLECTIONPRODUCER_H
2 #define RECOECAL_EGAMMACLUSTERPRODUCERS_COMBINEDRECHITCOLLECTIONPRODUCER_H
3 
4 
5 //
6 //
7 // Class: CombinedRecHitCollectionProducer
8 //
9 //
10 // this class takes two rec-hit collections A and B and makes a new collection C
11 // collection C is identical to collection A except that if a rec-hit is also in B,
12 // the rec-hit from collection B is put into C instead of the A flavour
13 //
14 // takes inspiration from ReducedRecHitCollectionProducer
15 
16 
17 // system include files
18 #include <memory>
19 
20 // user include files
23 
30 
32 
33 #include <iostream>
34 
35 class CaloTopology;
36 
38 public:
41  virtual void produce(edm::Event &, const edm::EventSetup&);
42 
43 private:
44 
47  const std::vector<int> flagsToReplaceHit_;
52 };
53 
56 
57  primaryRecHitsToken_(consumes<EcalRecHitCollection>(iConfig.getParameter< edm::InputTag > ("primaryRecHits"))),
58  secondaryRecHitsToken_(consumes<EcalRecHitCollection>(iConfig.getParameter< edm::InputTag > ("secondaryRecHits"))),
59  flagsToReplaceHit_(StringToEnumValue<EcalRecHit::Flags>(iConfig.getParameter<std::vector<std::string> >("flagsToReplaceHit"))),
60  outputCollectionName_(iConfig.getParameter<std::string>("outputCollectionName")),
61  outputReplacedHitsCollName_(iConfig.getParameter<std::string>("outputReplacedHitsCollName")),
62  outputReplacingHitsCollName_(iConfig.getParameter<std::string>("outputReplacingHitsCollName")),
63  outputDetIdCollName_("hitsNotReplaced")
64 {
65 
66  //register your products
67  produces< EcalRecHitCollection > (outputCollectionName_);
68  produces< EcalRecHitCollection > (outputReplacedHitsCollName_);
69  produces< EcalRecHitCollection > (outputReplacingHitsCollName_);
70  produces< DetIdCollection> (outputDetIdCollName_);
71 }
72 
73 
76  const edm::EventSetup& iSetup)
77 {
78  edm::Handle<EcalRecHitCollection> primaryRecHits;
79  edm::Handle<EcalRecHitCollection> secondaryRecHits;
80 
81  iEvent.getByToken(primaryRecHitsToken_,primaryRecHits);
82  iEvent.getByToken(secondaryRecHitsToken_,secondaryRecHits);
83 
84  auto outColl = std::make_unique<EcalRecHitCollection>();
85  auto missingDetIds = std::make_unique<DetIdCollection>();
86  auto outReplacedHits = std::make_unique<EcalRecHitCollection>(); //all the hits in primary coll replaced by secondary coll
87  auto outReplacingHits = std::make_unique<EcalRecHitCollection>(); //all the hits in secondary coll which replaced a primary coll rec hit
88 
89  for(auto& hit : *primaryRecHits){
90 
91  //first we check if the hit as any flags set requiring it to be replaced
92 
93  if(hit.checkFlags(flagsToReplaceHit_)){
94 
95  auto secHit = secondaryRecHits->find(hit.detid());
96  if(secHit!=secondaryRecHits->end()){ //found secondary hit
97  outColl->push_back(*secHit);
98  outReplacingHits->push_back(*secHit);
99  outReplacedHits->push_back(hit);
100  }else{
101  outColl->push_back(hit);
102  missingDetIds->push_back(hit.detid());
103  }
104  }else{
105  outColl->push_back(hit);
106  }
107  }
108  iEvent.put(std::move(outColl),outputCollectionName_);
109  iEvent.put(std::move(outReplacingHits),outputReplacingHitsCollName_);
110  iEvent.put(std::move(outReplacedHits),outputReplacedHitsCollName_);
111  iEvent.put(std::move(missingDetIds),outputDetIdCollName_);
112 }
115 
116 #endif
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:462
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:17
int iEvent
Definition: GenABIO.cc:230
OrphanHandle< PROD > put(std::auto_ptr< PROD > product)
Put a new product.
Definition: Event.h:121
def move
Definition: eostools.py:510
const edm::EDGetTokenT< EcalRecHitCollection > secondaryRecHitsToken_
virtual void produce(edm::Event &, const edm::EventSetup &)
const edm::EDGetTokenT< EcalRecHitCollection > primaryRecHitsToken_
CombinedRecHitCollectionProducer(const edm::ParameterSet &)
int StringToEnumValue(std::string const &enumConstName)