CMS 3D CMS Logo

List of all members | Public Member Functions | Private Attributes
MTDRecHitProducer Class Reference
Inheritance diagram for MTDRecHitProducer:
edm::stream::EDProducer<>

Public Member Functions

 MTDRecHitProducer (const edm::ParameterSet &ps)
 
void produce (edm::Event &evt, const edm::EventSetup &es) override
 
 ~MTDRecHitProducer () override
 
- Public Member Functions inherited from edm::stream::EDProducer<>
 EDProducer ()=default
 
bool hasAbilityToProduceInBeginLumis () const final
 
bool hasAbilityToProduceInBeginRuns () const final
 
bool hasAbilityToProduceInEndLumis () const final
 
bool hasAbilityToProduceInEndRuns () const final
 

Private Attributes

std::unique_ptr< MTDRecHitAlgoBasebarrel_
 
std::unique_ptr< MTDRecHitAlgoBaseendcap_
 
const std::string ftlbInstance_
 
const edm::EDGetTokenT< FTLUncalibratedRecHitCollectionftlbURecHits_
 
const std::string ftleInstance_
 
const edm::EDGetTokenT< FTLUncalibratedRecHitCollectionftleURecHits_
 
const MTDGeometrygeom_
 

Additional Inherited Members

- Public Types inherited from edm::stream::EDProducer<>
typedef CacheContexts< T... > CacheTypes
 
typedef CacheTypes::GlobalCache GlobalCache
 
typedef AbilityChecker< T... > HasAbility
 
typedef CacheTypes::LuminosityBlockCache LuminosityBlockCache
 
typedef LuminosityBlockContextT< LuminosityBlockCache, RunCache, GlobalCacheLuminosityBlockContext
 
typedef CacheTypes::LuminosityBlockSummaryCache LuminosityBlockSummaryCache
 
typedef CacheTypes::RunCache RunCache
 
typedef RunContextT< RunCache, GlobalCacheRunContext
 
typedef CacheTypes::RunSummaryCache RunSummaryCache
 

Detailed Description

Definition at line 22 of file MTDRecHitProducer.cc.

Constructor & Destructor Documentation

◆ MTDRecHitProducer()

MTDRecHitProducer::MTDRecHitProducer ( const edm::ParameterSet ps)
explicit

Definition at line 40 of file MTDRecHitProducer.cc.

41  : ftlbURecHits_(
42  consumes<FTLUncalibratedRecHitCollection>(ps.getParameter<edm::InputTag>("barrelUncalibratedRecHits"))),
44  consumes<FTLUncalibratedRecHitCollection>(ps.getParameter<edm::InputTag>("endcapUncalibratedRecHits"))),
45  ftlbInstance_(ps.getParameter<std::string>("BarrelHitsName")),
46  ftleInstance_(ps.getParameter<std::string>("EndcapHitsName")) {
47  produces<FTLRecHitCollection>(ftlbInstance_);
48  produces<FTLRecHitCollection>(ftleInstance_);
49 
50  auto sumes = consumesCollector();
51 
52  const edm::ParameterSet& barrel = ps.getParameterSet("barrel");
53  const std::string& barrelAlgo = barrel.getParameter<std::string>("algoName");
54  barrel_ = MTDRecHitAlgoFactory::get()->create(barrelAlgo, barrel, sumes);
55 
56  const edm::ParameterSet& endcap = ps.getParameterSet("endcap");
57  const std::string& endcapAlgo = endcap.getParameter<std::string>("algoName");
58  endcap_ = MTDRecHitAlgoFactory::get()->create(endcapAlgo, endcap, sumes);
59 }

References Reference_intrackfit_cff::barrel, barrel_, makeMuonMisalignmentScenario::endcap, endcap_, ftlbInstance_, ftleInstance_, get, edm::ParameterSet::getParameterSet(), and AlCaHLTBitMon_QueryRunRegistry::string.

◆ ~MTDRecHitProducer()

MTDRecHitProducer::~MTDRecHitProducer ( )
override

Definition at line 61 of file MTDRecHitProducer.cc.

61 {}

Member Function Documentation

◆ produce()

void MTDRecHitProducer::produce ( edm::Event evt,
const edm::EventSetup es 
)
override

Definition at line 63 of file MTDRecHitProducer.cc.

63  {
66  geom_ = geom.product();
67 
68  // tranparently get things from event setup
69  barrel_->getEventSetup(es);
70  endcap_->getEventSetup(es);
71 
72  barrel_->getEvent(evt);
73  endcap_->getEvent(evt);
74 
75  // prepare output
76  auto barrelRechits = std::make_unique<FTLRecHitCollection>();
77  auto endcapRechits = std::make_unique<FTLRecHitCollection>();
78 
80  evt.getByToken(ftlbURecHits_, hBarrel);
81  barrelRechits->reserve(hBarrel->size() / 2);
82  for (const auto& uhit : *hBarrel) {
83  uint32_t flags = FTLRecHit::kGood;
84  auto rechit = barrel_->makeRecHit(uhit, flags);
85  if (flags == FTLRecHit::kGood)
86  barrelRechits->push_back(std::move(rechit));
87  }
88 
90  evt.getByToken(ftleURecHits_, hEndcap);
91  endcapRechits->reserve(hEndcap->size() / 2);
92  for (const auto& uhit : *hEndcap) {
93  uint32_t flags = FTLRecHit::kGood;
94  auto rechit = endcap_->makeRecHit(uhit, flags);
95  if (flags == FTLRecHit::kGood)
96  endcapRechits->push_back(std::move(rechit));
97  }
98 
99  // put the collection of recunstructed hits in the event
100  // get the orphan handles so we can make refs for the tracking rechits
101  auto barrelHandle = evt.put(std::move(barrelRechits), ftlbInstance_);
102  auto endcapHandle = evt.put(std::move(endcapRechits), ftleInstance_);
103 }

References barrel_, endcap_, HLT_2018_cff::flags, ftlbInstance_, ftlbURecHits_, ftleInstance_, ftleURecHits_, relativeConstraints::geom, geom_, edm::EventSetup::get(), get, edm::Event::getByToken(), FTLRecHit::kGood, eostools::move(), edm::Event::put(), and edm::SortedCollection< T, SORT >::size().

Member Data Documentation

◆ barrel_

std::unique_ptr<MTDRecHitAlgoBase> MTDRecHitProducer::barrel_
private

Definition at line 35 of file MTDRecHitProducer.cc.

Referenced by MTDRecHitProducer(), and produce().

◆ endcap_

std::unique_ptr<MTDRecHitAlgoBase> MTDRecHitProducer::endcap_
private

Definition at line 35 of file MTDRecHitProducer.cc.

Referenced by MTDRecHitProducer(), and produce().

◆ ftlbInstance_

const std::string MTDRecHitProducer::ftlbInstance_
private

Definition at line 32 of file MTDRecHitProducer.cc.

Referenced by MTDRecHitProducer(), and produce().

◆ ftlbURecHits_

const edm::EDGetTokenT<FTLUncalibratedRecHitCollection> MTDRecHitProducer::ftlbURecHits_
private

Definition at line 29 of file MTDRecHitProducer.cc.

Referenced by produce().

◆ ftleInstance_

const std::string MTDRecHitProducer::ftleInstance_
private

Definition at line 33 of file MTDRecHitProducer.cc.

Referenced by MTDRecHitProducer(), and produce().

◆ ftleURecHits_

const edm::EDGetTokenT<FTLUncalibratedRecHitCollection> MTDRecHitProducer::ftleURecHits_
private

Definition at line 30 of file MTDRecHitProducer.cc.

Referenced by produce().

◆ geom_

const MTDGeometry* MTDRecHitProducer::geom_
private

Definition at line 37 of file MTDRecHitProducer.cc.

Referenced by produce().

MTDDigiGeometryRecord
Definition: MTDDigiGeometryRecord.h:15
Reference_intrackfit_cff.barrel
list barrel
Definition: Reference_intrackfit_cff.py:37
MTDRecHitProducer::barrel_
std::unique_ptr< MTDRecHitAlgoBase > barrel_
Definition: MTDRecHitProducer.cc:35
edm::SortedCollection::size
size_type size() const
Definition: SortedCollection.h:215
makeMuonMisalignmentScenario.endcap
endcap
Definition: makeMuonMisalignmentScenario.py:320
edm::Handle
Definition: AssociativeIterator.h:50
edm::EventSetup::get
T get() const
Definition: EventSetup.h:73
edm::ESHandle
Definition: DTSurvey.h:22
relativeConstraints.geom
geom
Definition: relativeConstraints.py:72
MTDRecHitProducer::ftlbInstance_
const std::string ftlbInstance_
Definition: MTDRecHitProducer.cc:32
edm::Event::getByToken
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:528
AlCaHLTBitMon_QueryRunRegistry.string
string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
edm::ParameterSet
Definition: ParameterSet.h:36
MTDRecHitProducer::endcap_
std::unique_ptr< MTDRecHitAlgoBase > endcap_
Definition: MTDRecHitProducer.cc:35
MTDRecHitProducer::ftleURecHits_
const edm::EDGetTokenT< FTLUncalibratedRecHitCollection > ftleURecHits_
Definition: MTDRecHitProducer.cc:30
edm::Event::put
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:132
MTDRecHitProducer::ftlbURecHits_
const edm::EDGetTokenT< FTLUncalibratedRecHitCollection > ftlbURecHits_
Definition: MTDRecHitProducer.cc:29
MTDRecHitProducer::geom_
const MTDGeometry * geom_
Definition: MTDRecHitProducer.cc:37
get
#define get
FTLRecHit::kGood
Definition: FTLRecHit.h:21
MTDRecHitProducer::ftleInstance_
const std::string ftleInstance_
Definition: MTDRecHitProducer.cc:33
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
eostools.move
def move(src, dest)
Definition: eostools.py:511
HLT_2018_cff.flags
flags
Definition: HLT_2018_cff.py:11758
edm::InputTag
Definition: InputTag.h:15
edm::ParameterSet::getParameterSet
ParameterSet const & getParameterSet(std::string const &) const
Definition: ParameterSet.cc:2121