CMS 3D CMS Logo

ME0SegmentProducer.cc
Go to the documentation of this file.
1 
14 
19 
21 
23 
25 public:
27  explicit ME0SegmentProducer(const edm::ParameterSet&);
29  ~ME0SegmentProducer() override {}
31  void produce(edm::Event&, const edm::EventSetup&) override;
32 
33 private:
34  int iev; // events through
36  std::unique_ptr<ME0SegmentBuilder> segmentBuilder_;
38 };
39 
41  theME0RecHitToken = consumes<ME0RecHitCollection>(ps.getParameter<edm::InputTag>("me0RecHitLabel"));
42  segmentBuilder_ = std::make_unique<ME0SegmentBuilder>(ps); // pass on the Parameter Set
43  me0GeomToken_ = esConsumes<ME0Geometry, MuonGeometryRecord>();
44  // register what this produces
45  produces<ME0SegmentCollection>();
46 }
47 
49  LogDebug("ME0SegmentProducer") << "start producing segments for " << ++iev << "th event with ME0 data";
50 
51  // find the geometry (& conditions?) for this event & cache it in the builder
53  const ME0Geometry* mgeom = &*me0g;
54  segmentBuilder_->setGeometry(mgeom);
55 
56  // get the collection of ME0RecHit
58  ev.getByToken(theME0RecHitToken, me0RecHits);
59 
60  // create empty collection of Segments
61  auto oc = std::make_unique<ME0SegmentCollection>();
62 
63  // fill the collection
64  segmentBuilder_->build(me0RecHits.product(), *oc); //@@ FILL oc
65 
66  // put collection in event
67  ev.put(std::move(oc));
68 }
69 
iev
const HitContainer *__restrict__ const TkSoA *__restrict__ const Quality *__restrict__ const CAHitNtupletGeneratorKernelsGPU::HitToTuple *__restrict__ uint32_t int iev
Definition: CAHitNtupletGeneratorKernelsImpl.h:544
Handle.h
ME0RecHitCollection.h
MessageLogger.h
ME0SegmentProducer::ME0SegmentProducer
ME0SegmentProducer(const edm::ParameterSet &)
Constructor.
Definition: ME0SegmentProducer.cc:40
ESHandle.h
edm::EDGetTokenT< ME0RecHitCollection >
ME0Geometry
Definition: ME0Geometry.h:12
me0RecHits_cfi.me0RecHits
me0RecHits
Definition: me0RecHits_cfi.py:3
ME0SegmentProducer::segmentBuilder_
std::unique_ptr< ME0SegmentBuilder > segmentBuilder_
Definition: ME0SegmentProducer.cc:36
ME0SegmentCollection.h
EDProducer.h
edm::Handle
Definition: AssociativeIterator.h:50
ESGetToken.h
ME0SegmentProducer
Definition: ME0SegmentProducer.cc:24
singleTopDQM_cfi.setup
setup
Definition: singleTopDQM_cfi.py:37
MakerMacros.h
DEFINE_FWK_MODULE
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
edm::ESHandle< ME0Geometry >
ME0SegmentProducer::iev
int iev
Definition: ME0SegmentProducer.cc:34
LogDebug
#define LogDebug(id)
Definition: MessageLogger.h:233
edm::ParameterSet
Definition: ParameterSet.h:47
Event.h
edm::stream::EDProducer
Definition: EDProducer.h:38
edm::EventSetup
Definition: EventSetup.h:58
ME0Segment.h
ME0SegmentProducer::me0GeomToken_
edm::ESGetToken< ME0Geometry, MuonGeometryRecord > me0GeomToken_
Definition: ME0SegmentProducer.cc:37
edm::ESGetToken< ME0Geometry, MuonGeometryRecord >
InputTag.h
ME0SegmentProducer::theME0RecHitToken
edm::EDGetTokenT< ME0RecHitCollection > theME0RecHitToken
Definition: ME0SegmentProducer.cc:35
eostools.move
def move(src, dest)
Definition: eostools.py:511
Frameworkfwd.h
ev
bool ev
Definition: Hydjet2Hadronizer.cc:95
ME0SegmentProducer::~ME0SegmentProducer
~ME0SegmentProducer() override
Destructor.
Definition: ME0SegmentProducer.cc:29
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
Definition: ParameterSet.h:303
ME0SegmentBuilder.h
ParameterSet.h
MuonGeometryRecord.h
edm::Event
Definition: Event.h:73
edm::InputTag
Definition: InputTag.h:15
ME0SegmentProducer::produce
void produce(edm::Event &, const edm::EventSetup &) override
Produce the ME0Segment collection.
Definition: ME0SegmentProducer.cc:48