CMS 3D CMS Logo

MTDUncalibratedRecHitProducer.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<BTLDigiCollection> ftlbDigis_; // collection of BTL digis
22  const edm::EDGetTokenT<ETLDigiCollection> ftleDigis_; // collection of ETL 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<BTLUncalibratedRecHitAlgoBase> barrel_;
28  std::unique_ptr<ETLUncalibratedRecHitAlgoBase> endcap_;
29 };
30 
32  : ftlbDigis_(consumes<BTLDigiCollection>(ps.getParameter<edm::InputTag>("barrelDigis"))),
33  ftleDigis_(consumes<ETLDigiCollection>(ps.getParameter<edm::InputTag>("endcapDigis"))),
34  ftlbInstance_(ps.getParameter<std::string>("BarrelHitsName")),
35  ftleInstance_(ps.getParameter<std::string>("EndcapHitsName")) {
36  produces<FTLUncalibratedRecHitCollection>(ftlbInstance_);
37  produces<FTLUncalibratedRecHitCollection>(ftleInstance_);
38 
39  auto sumes = consumesCollector();
40 
41  const edm::ParameterSet& barrel = ps.getParameterSet("barrel");
42  const std::string& barrelAlgo = barrel.getParameter<std::string>("algoName");
43  barrel_ = std::unique_ptr<BTLUncalibratedRecHitAlgoBase>{
44  BTLUncalibratedRecHitAlgoFactory::get()->create(barrelAlgo, barrel, sumes)};
45 
46  const edm::ParameterSet& endcap = ps.getParameterSet("endcap");
47  const std::string& endcapAlgo = endcap.getParameter<std::string>("algoName");
48  endcap_ = std::unique_ptr<ETLUncalibratedRecHitAlgoBase>{
49  ETLUncalibratedRecHitAlgoFactory::get()->create(endcapAlgo, endcap, sumes)};
50 }
51 
53 
55  // tranparently get things from event setup
56  barrel_->getEventSetup(es);
57  endcap_->getEventSetup(es);
58 
59  barrel_->getEvent(evt);
60  endcap_->getEvent(evt);
61 
62  // prepare output
63  auto barrelRechits = std::make_unique<FTLUncalibratedRecHitCollection>();
64  auto endcapRechits = std::make_unique<FTLUncalibratedRecHitCollection>();
65 
67  evt.getByToken(ftlbDigis_, hBarrel);
68  barrelRechits->reserve(hBarrel->size() / 2);
69  for (const auto& digi : *hBarrel) {
70  barrelRechits->emplace_back(barrel_->makeRecHit(digi));
71  }
72 
74  evt.getByToken(ftleDigis_, hEndcap);
75  endcapRechits->reserve(hEndcap->size() / 2);
76  for (const auto& digi : *hEndcap) {
77  endcapRechits->emplace_back(endcap_->makeRecHit(digi));
78  }
79 
80  // put the collection of recunstructed hits in the event
81  evt.put(std::move(barrelRechits), ftlbInstance_);
82  evt.put(std::move(endcapRechits), ftleInstance_);
83 }
84 
FTLDigiCollections.h
Handle.h
Reference_intrackfit_cff.barrel
list barrel
Definition: Reference_intrackfit_cff.py:37
MessageLogger.h
edm::EDGetTokenT
Definition: EDGetToken.h:33
edm
HLT enums.
Definition: AlignableModifier.h:19
EDProducer.h
edm::SortedCollection
Definition: SortedCollection.h:49
edm::SortedCollection::size
size_type size() const
Definition: SortedCollection.h:215
makeMuonMisalignmentScenario.endcap
endcap
Definition: makeMuonMisalignmentScenario.py:320
edm::Handle
Definition: AssociativeIterator.h:50
MTDUncalibratedRecHitProducer::ftleDigis_
const edm::EDGetTokenT< ETLDigiCollection > ftleDigis_
Definition: MTDUncalibratedRecHitProducer.cc:22
MakerMacros.h
DEFINE_FWK_MODULE
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
MTDUncalibratedRecHitProducer::MTDUncalibratedRecHitProducer
MTDUncalibratedRecHitProducer(const edm::ParameterSet &ps)
Definition: MTDUncalibratedRecHitProducer.cc:31
MTDUncalibratedRecHitProducer::endcap_
std::unique_ptr< ETLUncalibratedRecHitAlgoBase > endcap_
Definition: MTDUncalibratedRecHitProducer.cc:28
MTDUncalibratedRecHitAlgoBase.h
edm::Event::getByToken
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:528
AlCaHLTBitMon_QueryRunRegistry.string
string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
MTDUncalibratedRecHitProducer::ftleInstance_
const std::string ftleInstance_
Definition: MTDUncalibratedRecHitProducer.cc:25
HLT_2018_cff.InputTag
InputTag
Definition: HLT_2018_cff.py:79016
edm::ParameterSet
Definition: ParameterSet.h:36
Event.h
MTDUncalibratedRecHitProducer::barrel_
std::unique_ptr< BTLUncalibratedRecHitAlgoBase > barrel_
Definition: MTDUncalibratedRecHitProducer.cc:27
edm::Event::put
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:132
edm::stream::EDProducer
Definition: EDProducer.h:38
MTDUncalibratedRecHitProducer
Definition: MTDUncalibratedRecHitProducer.cc:14
edm::EventSetup
Definition: EventSetup.h:57
get
#define get
MTDUncalibratedRecHitProducer::ftlbDigis_
const edm::EDGetTokenT< BTLDigiCollection > ftlbDigis_
Definition: MTDUncalibratedRecHitProducer.cc:21
FTLRecHitCollections.h
eostools.move
def move(src, dest)
Definition: eostools.py:511
std
Definition: JetResolutionObject.h:76
MTDUncalibratedRecHitProducer::~MTDUncalibratedRecHitProducer
~MTDUncalibratedRecHitProducer() override
Definition: MTDUncalibratedRecHitProducer.cc:52
EventSetup.h
MTDUncalibratedRecHitProducer::produce
void produce(edm::Event &evt, const edm::EventSetup &es) override
Definition: MTDUncalibratedRecHitProducer.cc:54
ParameterSet.h
edm::Event
Definition: Event.h:73
edm::ParameterSet::getParameterSet
ParameterSet const & getParameterSet(std::string const &) const
Definition: ParameterSet.cc:2121
MTDUncalibratedRecHitProducer::ftlbInstance_
const std::string ftlbInstance_
Definition: MTDUncalibratedRecHitProducer.cc:24