CMS 3D CMS Logo

All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
FTLUncalibratedRecHitProducer.cc
Go to the documentation of this file.
5 
9 
11 
13 
15 public:
18  void produce(edm::Event& evt, const edm::EventSetup& es) override;
19 
20 private:
21  const edm::EDGetTokenT<FTLDigiCollection> ftlbDigis_; // collection of HGCEE digis
22  const edm::EDGetTokenT<FTLDigiCollection> ftleDigis_; // collection of HGCHEF digis
23 
24  const std::string ftlbInstance_; // instance name of barrel hits
25  const std::string ftleInstance_; // instance name of endcap hits
26 
27  std::unique_ptr<FTLUncalibratedRecHitAlgoBase> barrel_, endcap_;
28 };
29 
31  : ftlbDigis_(consumes<FTLDigiCollection>(ps.getParameter<edm::InputTag>("barrelDigis"))),
32  ftleDigis_(consumes<FTLDigiCollection>(ps.getParameter<edm::InputTag>("endcapDigis"))),
33  ftlbInstance_(ps.getParameter<std::string>("BarrelHitsName")),
34  ftleInstance_(ps.getParameter<std::string>("EndcapHitsName")) {
35  produces<FTLUncalibratedRecHitCollection>(ftlbInstance_);
36  produces<FTLUncalibratedRecHitCollection>(ftleInstance_);
37 
38  auto sumes = consumesCollector();
39 
40  const edm::ParameterSet& barrel = ps.getParameterSet("barrel");
41  const std::string& barrelAlgo = barrel.getParameter<std::string>("algoName");
42  barrel_ = std::unique_ptr<FTLUncalibratedRecHitAlgoBase>{
43  FTLUncalibratedRecHitAlgoFactory::get()->create(barrelAlgo, barrel, sumes)};
44 
45  const edm::ParameterSet& endcap = ps.getParameterSet("endcap");
46  const std::string& endcapAlgo = endcap.getParameter<std::string>("algoName");
47  endcap_ = std::unique_ptr<FTLUncalibratedRecHitAlgoBase>{
48  FTLUncalibratedRecHitAlgoFactory::get()->create(endcapAlgo, endcap, sumes)};
49 }
50 
52 
54  // tranparently get things from event setup
55  barrel_->getEventSetup(es);
56  endcap_->getEventSetup(es);
57 
58  barrel_->getEvent(evt);
59  endcap_->getEvent(evt);
60 
61  // prepare output
62  auto barrelRechits = std::make_unique<FTLUncalibratedRecHitCollection>();
63  auto endcapRechits = std::make_unique<FTLUncalibratedRecHitCollection>();
64 
66  evt.getByToken(ftlbDigis_, hBarrel);
67  barrelRechits->reserve(hBarrel->size() / 2);
68  for (const auto& digi : *hBarrel) {
69  barrelRechits->emplace_back(barrel_->makeRecHit(digi));
70  }
71 
73  evt.getByToken(ftleDigis_, hEndcap);
74  endcapRechits->reserve(hEndcap->size() / 2);
75  for (const auto& digi : *hEndcap) {
76  endcapRechits->emplace_back(endcap_->makeRecHit(digi));
77  }
78 
79  // put the collection of recunstructed hits in the event
80  evt.put(std::move(barrelRechits), ftlbInstance_);
81  evt.put(std::move(endcapRechits), ftleInstance_);
82 }
83 
T getParameter(std::string const &) const
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:131
std::unique_ptr< FTLUncalibratedRecHitAlgoBase > endcap_
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:525
FTLUncalibratedRecHitProducer(const edm::ParameterSet &ps)
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
const edm::EDGetTokenT< FTLDigiCollection > ftlbDigis_
const edm::EDGetTokenT< FTLDigiCollection > ftleDigis_
std::unique_ptr< FTLUncalibratedRecHitAlgoBase > barrel_
ParameterSet const & getParameterSet(std::string const &) const
HLT enums.
size_type size() const
void produce(edm::Event &evt, const edm::EventSetup &es) override
def move(src, dest)
Definition: eostools.py:511