CMS 3D CMS Logo

MaskedMeasurementTrackerEventProducer.cc
Go to the documentation of this file.
7 
9 public:
12 private:
13  void produce(edm::Event&, const edm::EventSetup&) override;
14 
18 
20 
23 
27 };
28 
29 
31  src_(consumes<MeasurementTrackerEvent>(iConfig.getParameter<edm::InputTag>("src"))),
32  skipClusters_(false), phase2skipClusters_(false)
33 {
34  //FIXME:temporary solution in order to use this class for both phase0/1 and phase2
35  if (iConfig.existsAs<edm::InputTag>("clustersToSkip")) {
36  skipClusters_ = true;
37  edm::InputTag clustersToSkip = iConfig.getParameter<edm::InputTag>("clustersToSkip");
38  maskPixels_ = consumes<PixelMask>(clustersToSkip);
39  maskStrips_ = consumes<StripMask>(clustersToSkip);
40  }
41  if (iConfig.existsAs<edm::InputTag>("phase2clustersToSkip")) {
42  phase2skipClusters_ = true;
43  edm::InputTag phase2clustersToSkip = iConfig.getParameter<edm::InputTag>("phase2clustersToSkip");
44  maskPixels_ = consumes<PixelMask>(phase2clustersToSkip);
45  maskPhase2OTs_ = consumes<Phase2OTMask>(phase2clustersToSkip);
46  }
47  produces<MeasurementTrackerEvent>();
48 }
49 
50 void
52 {
54  iEvent.getByToken(src_, mte);
55 
56  // prepare output
57  std::unique_ptr<MeasurementTrackerEvent> out;
58 
59  if (skipClusters_) {
60 
61  edm::Handle<PixelMask> maskPixels;
62  iEvent.getByToken(maskPixels_, maskPixels);
63  edm::Handle<StripMask> maskStrips;
64  iEvent.getByToken(maskStrips_, maskStrips);
65 
66  out = std::make_unique<MeasurementTrackerEvent>(*mte, *maskStrips, *maskPixels);
67 
68  } else if (phase2skipClusters_) {
69 
70  edm::Handle<PixelMask> maskPixels;
71  iEvent.getByToken(maskPixels_, maskPixels);
72  edm::Handle<Phase2OTMask> maskPhase2OTs;
73  iEvent.getByToken(maskPhase2OTs_, maskPhase2OTs);
74 
75  out = std::make_unique<MeasurementTrackerEvent>(*mte, *maskPixels, *maskPhase2OTs);
76  }
77 
78  // put into event
79  iEvent.put(std::move(out));
80 }
81 
T getParameter(std::string const &) const
#define dso_hidden
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:127
bool existsAs(std::string const &parameterName, bool trackiness=true) const
checks if a parameter exists as a given type
Definition: ParameterSet.h:186
void produce(edm::Event &, const edm::EventSetup &) override
edm::EDGetTokenT< MeasurementTrackerEvent > src_
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:508
virtual void produce(Event &, EventSetup const &)=0
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:17
MaskedMeasurementTrackerEventProducer(const edm::ParameterSet &iConfig)
int iEvent
Definition: GenABIO.cc:230
edm::ContainerMask< edmNew::DetSetVector< Phase2TrackerCluster1D > > Phase2OTMask
edm::ContainerMask< edmNew::DetSetVector< SiPixelCluster > > PixelMask
HLT enums.
def move(src, dest)
Definition: eostools.py:510
edm::ContainerMask< edmNew::DetSetVector< SiStripCluster > > StripMask