CMS 3D CMS Logo

DataMixingModule.cc
Go to the documentation of this file.
1 // File: DataMixingModule.cc
2 // Description: see DataMixingModule.h
3 // Author: Mike Hildreth, University of Notre Dame
4 //
5 //--------------------------------------------
6 
7 #include <map>
8 #include <iostream>
9 #include <memory>
10 #include <functional>
11 
19 //
20 //
23 #include "DataMixingModule.h"
25 
26 using namespace std;
27 
28 namespace edm
29 {
30 
31  // Constructor
32  DataMixingModule::DataMixingModule(const edm::ParameterSet& ps, MixingCache::Config const* globalConf) :
33  BMixingModule(ps, globalConf),
34  EBPileInputTag_(ps.getParameter<edm::InputTag>("EBPileInputTag")),
35  EEPileInputTag_(ps.getParameter<edm::InputTag>("EEPileInputTag")),
36  ESPileInputTag_(ps.getParameter<edm::InputTag>("ESPileInputTag")),
37  HBHEPileInputTag_(ps.getParameter<edm::InputTag>("HBHEPileInputTag")),
38  HOPileInputTag_(ps.getParameter<edm::InputTag>("HOPileInputTag")),
39  HFPileInputTag_(ps.getParameter<edm::InputTag>("HFPileInputTag")),
40  ZDCPileInputTag_(ps.getParameter<edm::InputTag>("ZDCPileInputTag")),
41  QIE10PileInputTag_(ps.getParameter<edm::InputTag>("QIE10PileInputTag")),
42  QIE11PileInputTag_(ps.getParameter<edm::InputTag>("QIE11PileInputTag")),
43  label_(ps.getParameter<std::string>("Label"))
44  {
45  // prepare for data access in DataMixingHcalDigiWorkerProd
46  tok_hbhe_ = consumes<HBHEDigitizerTraits::DigiCollection>(HBHEPileInputTag_);
47  tok_ho_ = consumes<HODigitizerTraits::DigiCollection>(HOPileInputTag_);
48  tok_hf_ = consumes<HFDigitizerTraits::DigiCollection>(HFPileInputTag_);
49  tok_zdc_ = consumes<ZDCDigitizerTraits::DigiCollection>(ZDCPileInputTag_);
50  tok_qie10_ = consumes<HcalQIE10DigitizerTraits::DigiCollection>(QIE10PileInputTag_);
51  tok_qie11_ = consumes<HcalQIE11DigitizerTraits::DigiCollection>(QIE11PileInputTag_);
52 
53  // get the subdetector names
54  this->getSubdetectorNames(); //something like this may be useful to check what we are supposed to do...
55 
56  // For now, list all of them here. Later, make this selectable with input parameters
57  //
58 
59  // Check to see if we are working in Full or Fast Simulation
60 
61  MergeTrackerDigis_ = (ps.getParameter<std::string>("TrackerMergeType")) == "Digis";
62  MergeEMDigis_ = (ps.getParameter<std::string>("EcalMergeType")) == "Digis";
63  MergeHcalDigis_ = (ps.getParameter<std::string>("HcalMergeType")) == "Digis";
64  if(MergeHcalDigis_) MergeHcalDigisProd_ = (ps.getParameter<std::string>("HcalDigiMerge")=="FullProd");
65 
66  // Put Fast Sim Sequences here for Simplification: Fewer options!
67 
68 
69  if(MergeEMDigis_) {
70 
71  // cout<<"EM Digis TRUE!!!"<<endl;
72 
73  EBDigiCollectionDM_ = ps.getParameter<std::string>("EBDigiCollectionDM");
74  EEDigiCollectionDM_ = ps.getParameter<std::string>("EEDigiCollectionDM");
75  ESDigiCollectionDM_ = ps.getParameter<std::string>("ESDigiCollectionDM");
76  // nMaxPrintout_ = ps.getUntrackedParameter<int>("nMaxPrintout",10);
77 
78  produces< EBDigiCollection >(EBDigiCollectionDM_);
79  produces< EEDigiCollection >(EEDigiCollectionDM_);
80  produces< ESDigiCollection >(ESDigiCollectionDM_);
81 
82 
83  EMDigiWorker_ = new DataMixingEMDigiWorker(ps, consumesCollector());
84  }
85  else { // merge RecHits
86  EBRecHitCollectionDM_ = ps.getParameter<std::string>("EBRecHitCollectionDM");
87  EERecHitCollectionDM_ = ps.getParameter<std::string>("EERecHitCollectionDM");
88  ESRecHitCollectionDM_ = ps.getParameter<std::string>("ESRecHitCollectionDM");
89  // nMaxPrintout_ = ps.getUntrackedParameter<int>("nMaxPrintout",10);
90 
91  produces< EBRecHitCollection >(EBRecHitCollectionDM_);
92  produces< EERecHitCollection >(EERecHitCollectionDM_);
93  produces< ESRecHitCollection >(ESRecHitCollectionDM_);
94 
95  EMWorker_ = new DataMixingEMWorker(ps, consumesCollector());
96  }
97  // Hcal next
98 
99  if(MergeHcalDigis_){
100  HBHEDigiCollectionDM_ = ps.getParameter<std::string>("HBHEDigiCollectionDM");
101  HODigiCollectionDM_ = ps.getParameter<std::string>("HODigiCollectionDM");
102  HFDigiCollectionDM_ = ps.getParameter<std::string>("HFDigiCollectionDM");
103  ZDCDigiCollectionDM_ = ps.getParameter<std::string>("ZDCDigiCollectionDM");
104  QIE10DigiCollectionDM_ = ps.getParameter<std::string>("QIE10DigiCollectionDM");
105  QIE11DigiCollectionDM_ = ps.getParameter<std::string>("QIE11DigiCollectionDM");
106 
107  produces< HBHEDigiCollection >();
108  produces< HODigiCollection >();
109  produces< HFDigiCollection >();
110  produces< ZDCDigiCollection >();
111 
112  produces<QIE10DigiCollection>("HFQIE10DigiCollection");
113  produces<QIE11DigiCollection>("HBHEQIE11DigiCollection");
114 
115  if(ps.getParameter<bool>("debugCaloSamples")){
116  produces<CaloSamplesCollection>("HcalSamples");
117  }
118  if(ps.getParameter<bool>("injectTestHits")){
119  produces<edm::PCaloHitContainer>("HcalHits");
120  }
121 
122  if(MergeHcalDigisProd_) HcalDigiWorkerProd_ = new DataMixingHcalDigiWorkerProd(ps, consumesCollector());
123  else HcalDigiWorker_ = new DataMixingHcalDigiWorker(ps, consumesCollector());
124 
125  }
126  else{
127  HBHERecHitCollectionDM_ = ps.getParameter<std::string>("HBHERecHitCollectionDM");
128  HORecHitCollectionDM_ = ps.getParameter<std::string>("HORecHitCollectionDM");
129  HFRecHitCollectionDM_ = ps.getParameter<std::string>("HFRecHitCollectionDM");
130  ZDCRecHitCollectionDM_ = ps.getParameter<std::string>("ZDCRecHitCollectionDM");
131 
132  produces< HBHERecHitCollection >(HBHERecHitCollectionDM_);
133  produces< HORecHitCollection >(HORecHitCollectionDM_);
134  produces< HFRecHitCollection >(HFRecHitCollectionDM_);
135  produces< ZDCRecHitCollection >(ZDCRecHitCollectionDM_);
136 
137  HcalWorker_ = new DataMixingHcalWorker(ps, consumesCollector());
138  }
139 
140  // Muons
141 
142  DTDigiCollectionDM_ = ps.getParameter<std::string>("DTDigiCollectionDM");
143  RPCDigiCollectionDM_ = ps.getParameter<std::string>("RPCDigiCollectionDM");
144  CSCStripDigiCollectionDM_ = ps.getParameter<std::string>("CSCStripDigiCollectionDM");
145  CSCWireDigiCollectionDM_ = ps.getParameter<std::string>("CSCWireDigiCollectionDM");
146  CSCComparatorDigiCollectionDM_ = ps.getParameter<std::string>("CSCComparatorDigiCollectionDM");
147 
148 
149  produces< DTDigiCollection >();
150  produces< RPCDigiCollection >();
151  produces< CSCStripDigiCollection >(CSCStripDigiCollectionDM_);
152  produces< CSCWireDigiCollection >(CSCWireDigiCollectionDM_);
153  produces< CSCComparatorDigiCollection >(CSCComparatorDigiCollectionDM_);
154 
155  MuonWorker_ = new DataMixingMuonWorker(ps, consumesCollector());
156 
157 
158  // Si-Strips
159 
160  useSiStripRawDigi_ = ps.exists("SiStripRawDigiSource")?
161  ps.getParameter<std::string>("SiStripRawDigiSource")=="PILEUP" ||
162  ps.getParameter<std::string>("SiStripRawDigiSource")=="SIGNAL" : false;
163 
164  SiStripDigiCollectionDM_ = ps.getParameter<std::string>("SiStripDigiCollectionDM");
165 
166  if(useSiStripRawDigi_) {
167 
168  produces< edm::DetSetVector<SiStripRawDigi> > (SiStripDigiCollectionDM_);
169  SiStripRawWorker_ = new DataMixingSiStripRawWorker(ps, consumesCollector());
170 
171  } else {
172 
173  produces< edm::DetSetVector<SiStripDigi> > (SiStripDigiCollectionDM_);
174 
175  SiStripWorker_ = new DataMixingSiStripWorker(ps, consumesCollector());
176  }
177 
178  // Pixels
179 
180  PixelDigiCollectionDM_ = ps.getParameter<std::string>("PixelDigiCollectionDM");
181 
182  produces< edm::DetSetVector<PixelDigi> > (PixelDigiCollectionDM_);
183 
184  SiPixelWorker_ = new DataMixingSiPixelWorker(ps, consumesCollector());
185 
186 
187  // Pileup Information: if doing pre-mixing, we have to save the pileup information from the Secondary stream
188 
189  MergePileup_ = ps.getParameter<bool>("MergePileupInfo");
190 
191  if(MergePileup_) {
192  produces< std::vector<PileupSummaryInfo> >();
193  produces< int >("bunchSpacing");
194  produces<CrossingFramePlaybackInfoNew>();
195 
196  std::vector<edm::InputTag> GenPUProtonsInputTags;
197  GenPUProtonsInputTags = ps.getParameter<std::vector<edm::InputTag> >("GenPUProtonsInputTags");
198  for(std::vector<edm::InputTag>::const_iterator it_InputTag = GenPUProtonsInputTags.begin();
199  it_InputTag != GenPUProtonsInputTags.end(); ++it_InputTag)
200  produces< std::vector<reco::GenParticle> >( it_InputTag->label() );
201 
202  PUWorker_ = new DataMixingPileupCopy(ps, consumesCollector());
203  }
204  }
205 
207  // get subdetector names
208  // edm::Service<edm::ConstProductRegistry> reg;
209  // Loop over provenance of products in registry.
210  //for (edm::ProductRegistry::ProductList::const_iterator it = reg->productList().begin(); it != reg->productList().end(); ++it) {
211 
212  // **** Check this out.... ****
213 
214  // See FWCore/Framework/interface/BranchDescription.h
215  // BranchDescription contains all the information for the product.
216 
217  // This section not very backwards-compatible in terms of digi-merging. Need to be able to specify here which data format
218  // to look at...
219 
220  // edm::BranchDescription desc = it->second;
221  //if (!desc.friendlyClassName_.compare(0,9,"EBRecHitC")) {
222  // Subdetectors_.push_back(desc.productInstanceName_);
223  //LogInfo("DataMixingModule") <<"Adding container "<<desc.productInstanceName_ <<" for pileup treatment";
224  //}
225  //else if (!desc.friendlyClassName_.compare(0,9,"EERecHitC")) {
226  // else if (!desc.friendlyClassName_.compare(0,9,"EErechitC") && desc.productInstanceName_.compare(0,11,"TrackerHits")) {
227  // Subdetectors_.push_back(desc.productInstanceName_);
228  //LogInfo("DataMixingModule") <<"Adding container "<<desc.productInstanceName_ <<" for pileup treatment";
229  //}
230  //else if (!desc.friendlyClassName_.compare(0,9,"HBRecHitC")) {
231  // Subdetectors_.push_back(desc.productInstanceName_);
232  //LogInfo("DataMixingModule") <<"Adding container "<<desc.productInstanceName_ <<" for pileup treatment";
233  //}
234  //else if (!desc.friendlyClassName_.compare(0,9,"HERecHitC")) {
235  // Subdetectors_.push_back(desc.productInstanceName_);
236  //LogInfo("DataMixingModule") <<"Adding container "<<desc.productInstanceName_ <<" for pileup treatment";
237  // }
238  // and so on with other detector types...
239  // }
240  }
241 
242 
244  }
245 
246 
248  BMixingModule::beginRun( run, ES);
249  }
250 
252  BMixingModule::endRun( run, ES);
253  }
254 
255  // Virtual destructor needed.
257  if(MergeEMDigis_){
258  delete EMDigiWorker_;
259  }
260  else {delete EMWorker_;}
261  if(MergeHcalDigis_) {
263  else { delete HcalDigiWorker_; }}
264  else {delete HcalWorker_;}
265  if(MuonWorker_) delete MuonWorker_;
267  delete SiStripRawWorker_;
268  else delete SiStripWorker_;
269  delete SiPixelWorker_;
270  if(MergePileup_) { delete PUWorker_;}
271  }
272 
274  // fill in maps of hits
275 
276  LogDebug("DataMixingModule")<<"===============> adding MC signals for "<<e.id();
277 
278  // Ecal
279  if(MergeEMDigis_) {
280  EMDigiWorker_->addEMSignals(e, ES);
281  }
282  else{ EMWorker_->addEMSignals(e);}
283 
284  // Hcal
285  if(MergeHcalDigis_) {
288  }
289  else{
291  }
292  }
293  else {HcalWorker_->addHcalSignals(e);}
294 
295  // Muon
297 
298  // SiStrips
301 
302  // SiPixels
304  AddedPileup_ = false;
305  } // end of addSignals
306 
307 
308 
309 
310  void DataMixingModule::pileWorker(const EventPrincipal &ep, int bcr, int eventNr, const edm::EventSetup& ES, edm::ModuleCallingContext const* mcc) {
311 
312  InternalContext internalContext(ep.id(), mcc);
313  ParentContext parentContext(&internalContext);
314  ModuleCallingContext moduleCallingContext(&moduleDescription());
315  ModuleContextSentry moduleContextSentry(&moduleCallingContext, parentContext);
316 
317  LogDebug("DataMixingModule") <<"\n===============> adding pileups from event "<<ep.id()<<" for bunchcrossing "<<bcr;
318 
319  // Note: setupPileUpEvent may modify the run and lumi numbers of the EventPrincipal to match that of the primary event.
320  setupPileUpEvent(ES);
321 
322  // check and see if we need to copy the pileup information from
323  // secondary stream to the output stream
324  // We only have the pileup event here, so pick the first time and store the info
325 
326 
327  if(MergePileup_ && !AddedPileup_){
328 
329  PUWorker_->addPileupInfo(&ep, eventNr, &moduleCallingContext);
330 
331  AddedPileup_ = true;
332  }
333 
334  // fill in maps of hits; same code as addSignals, except now applied to the pileup events
335 
336  // Ecal
337  if(MergeEMDigis_) {
338  EMDigiWorker_->addEMPileups(bcr, &ep, eventNr, ES, &moduleCallingContext);
339  }
340  else {EMWorker_->addEMPileups(bcr, &ep, eventNr, &moduleCallingContext); }
341 
342  // Hcal
343  if(MergeHcalDigis_) {
344  if(MergeHcalDigisProd_) {
345  HcalDigiWorkerProd_->addHcalPileups(bcr, &ep, eventNr, ES, &moduleCallingContext);
346  }
347  else{
348  HcalDigiWorker_->addHcalPileups(bcr, &ep, eventNr, ES, &moduleCallingContext);}
349  }
350  else {HcalWorker_->addHcalPileups(bcr, &ep, eventNr, &moduleCallingContext);}
351 
352  // Muon
353  MuonWorker_->addMuonPileups(bcr, &ep, eventNr, &moduleCallingContext);
354 
355  // SiStrips
356  if(useSiStripRawDigi_) SiStripRawWorker_->addSiStripPileups(bcr, &ep, eventNr, &moduleCallingContext);
357  else SiStripWorker_->addSiStripPileups(bcr, &ep, eventNr, &moduleCallingContext);
358 
359  // SiPixels
360  //whoops this should be for the MC worker ????? SiPixelWorker_->setPileupInfo(ps,bunchSpacing);
361  SiPixelWorker_->addSiPixelPileups(bcr, &ep, eventNr, &moduleCallingContext);
362  }
363 
364 
365 
367  {
368  using namespace std::placeholders;
369 
370  std::vector<edm::SecondaryEventIDAndFileInfo> recordEventID;
371  std::vector<int> PileupList;
372  PileupList.clear();
373  TrueNumInteractions_.clear();
374 
376 
377  for (int bunchCrossing=minBunch_;bunchCrossing<=maxBunch_;++bunchCrossing) {
378  for (unsigned int isource=0;isource<maxNbSources_;++isource) {
379  std::shared_ptr<PileUp> source = inputSources_[isource];
380  if (!source || !(source->doPileUp(bunchCrossing)))
381  continue;
382 
383  if (isource==0)
384  source->CalculatePileup(minBunch_, maxBunch_, PileupList, TrueNumInteractions_, e.streamID());
385 
386  int NumPU_Events = 0;
387  if (isource ==0) {
388  NumPU_Events = PileupList[bunchCrossing - minBunch_];
389  } else {
390  // non-minbias pileup only gets one event for now. Fix later if desired.
391  NumPU_Events = 1;
392  }
393 
394  source->readPileUp(
395  e.id(),
396  recordEventID,
397  std::bind(&DataMixingModule::pileWorker, std::ref(*this),
398  _1, bunchCrossing, _2, std::cref(ES), mcc),
399  NumPU_Events,
400  e.streamID()
401  );
402  }
403  }
404 
405  }
406 
407 
409 
410  // individual workers...
411 
412  // move pileup first so we have access to the information for the put step
413 
414  std::vector<PileupSummaryInfo> ps;
415  int bunchSpacing=10000;
416 
417  if(MergePileup_) {
418  PUWorker_->getPileupInfo(ps,bunchSpacing);
420  }
421 
422  // Ecal
423  if(MergeEMDigis_) {
424  EMDigiWorker_->putEM(e,ES);
425  }
426  else {EMWorker_->putEM(e);}
427 
428  // Hcal
429  if(MergeHcalDigis_) {
430  if(MergeHcalDigisProd_) {
432  }
433  else{
434  HcalDigiWorker_->putHcal(e,ES);
435  }
436  }
437  else {HcalWorker_->putHcal(e);}
438 
439  // Muon
440  MuonWorker_->putMuon(e);
441 
442  // SiStrips
444  else SiStripWorker_->putSiStrip(e);
445 
446  // SiPixels
448  }
449 
452  }
453 
456  }
457 
458 
459 } //edm
#define LogDebug(id)
void doPileUp(edm::Event &e, const edm::EventSetup &ES) override
T getParameter(std::string const &) const
edm::EDGetTokenT< HcalQIE11DigitizerTraits::DigiCollection > tok_qie11_
void addMuonSignals(const edm::Event &e)
void beginRun(const edm::Run &r, const edm::EventSetup &setup) override
std::string HFDigiCollectionDM_
void addHcalSignals(const edm::Event &e, const edm::EventSetup &ES)
void putEM(edm::Event &e)
void endRun(const edm::Run &r, const edm::EventSetup &setup) override
void beginLuminosityBlock(LuminosityBlock const &l1, EventSetup const &c) override
void addSiStripSignals(const edm::Event &e)
void addHcalSignals(const edm::Event &e)
static std::string const source("source")
std::string HBHERecHitCollectionDM_
edm::InputTag QIE11PileInputTag_
std::string ZDCRecHitCollectionDM_
void addMuonPileups(const int bcr, const edm::EventPrincipal *, unsigned int EventId, ModuleCallingContext const *)
void addEMSignals(const edm::Event &e)
void addHcalPileups(const int bcr, const edm::EventPrincipal *, unsigned int EventId, ModuleCallingContext const *)
std::string CSCStripDigiCollectionDM_
edm::InputTag QIE10PileInputTag_
void putPileupInfo(edm::Event &e)
std::vector< float > TrueNumInteractions_
EventID const & id() const
bool exists(std::string const &parameterName) const
checks if a parameter exists
std::string SiStripDigiCollectionDM_
edm::EDGetTokenT< ZDCDigitizerTraits::DigiCollection > tok_zdc_
edm::EDGetTokenT< HODigitizerTraits::DigiCollection > tok_ho_
void addHcalPileups(const int bcr, const edm::EventPrincipal *, unsigned int EventId, const edm::EventSetup &ES, ModuleCallingContext const *)
void addSiPixelPileups(const int bcr, const edm::EventPrincipal *, unsigned int EventId, ModuleCallingContext const *)
void addEMPileups(const int bcr, const edm::EventPrincipal *, unsigned int EventId, const edm::EventSetup &ES, ModuleCallingContext const *)
void endRun(const edm::Run &r, const edm::EventSetup &setup) override
std::string CSCWireDigiCollectionDM_
void putEM(edm::Event &e, const edm::EventSetup &ES)
std::string QIE10DigiCollectionDM_
DataMixingSiStripRawWorker * SiStripRawWorker_
void beginRun(edm::Run const &run, edm::EventSetup const &eventSetup) override
DataMixingSiPixelWorker * SiPixelWorker_
void addSiStripPileups(const int bcr, const edm::EventPrincipal *, unsigned int EventId, ModuleCallingContext const *)
ModuleCallingContext const * moduleCallingContext() const
Definition: Event.h:269
std::string RPCDigiCollectionDM_
void putHcal(edm::Event &e, const edm::EventSetup &ES)
std::string ZDCDigiCollectionDM_
DataMixingHcalDigiWorker * HcalDigiWorker_
DataMixingEMWorker * EMWorker_
static const unsigned int maxNbSources_
DataMixingPileupCopy * PUWorker_
void addSiStripPileups(const int bcr, const edm::EventPrincipal *, unsigned int EventId, ModuleCallingContext const *)
std::string HORecHitCollectionDM_
void endLuminosityBlock(LuminosityBlock const &l1, EventSetup const &c) override
DataMixingMuonWorker * MuonWorker_
virtual void getSubdetectorNames()
std::string EEDigiCollectionDM_
void addHcalPileups(const int bcr, const edm::EventPrincipal *, unsigned int EventId, const edm::EventSetup &ES, edm::ModuleCallingContext const *)
edm::InputTag HBHEPileInputTag_
std::string HFRecHitCollectionDM_
void pileWorker(const edm::EventPrincipal &, int bcr, int EventId, const edm::EventSetup &ES, ModuleCallingContext const *)
edm::EDGetTokenT< HcalQIE10DigitizerTraits::DigiCollection > tok_qie10_
std::string HBHEDigiCollectionDM_
std::string EBRecHitCollectionDM_
std::string CSCComparatorDigiCollectionDM_
void addEMPileups(const int bcr, const edm::EventPrincipal *, unsigned int EventId, ModuleCallingContext const *)
edm::InputTag HOPileInputTag_
void putHcal(edm::Event &e, const edm::EventSetup &ES)
edm::EventID id() const
Definition: EventBase.h:60
DataMixingSiStripWorker * SiStripWorker_
std::string ESRecHitCollectionDM_
std::string EERecHitCollectionDM_
edm::EDGetTokenT< HFDigitizerTraits::DigiCollection > tok_hf_
HLT enums.
std::vector< std::shared_ptr< PileUp > > inputSources_
std::string ESDigiCollectionDM_
void put(edm::Event &e, const edm::EventSetup &ES) override
std::string DTDigiCollectionDM_
void addSiStripSignals(const edm::Event &e)
void initializeEvent(edm::Event const &e, edm::EventSetup const &eventSetup) override
std::string EBDigiCollectionDM_
StreamID streamID() const
Definition: Event.h:96
DataMixingHcalWorker * HcalWorker_
void getPileupInfo(std::vector< PileupSummaryInfo > &ps, int &bs)
edm::InputTag HFPileInputTag_
std::string HODigiCollectionDM_
std::string PixelDigiCollectionDM_
edm::EDGetTokenT< HBHEDigitizerTraits::DigiCollection > tok_hbhe_
DataMixingHcalDigiWorkerProd * HcalDigiWorkerProd_
void beginLuminosityBlock(const edm::LuminosityBlock &l, const edm::EventSetup &setup) override
std::string QIE11DigiCollectionDM_
void addPileupInfo(const edm::EventPrincipal *, unsigned int EventId, ModuleCallingContext const *mcc)
void addEMSignals(const edm::Event &e, const edm::EventSetup &ES)
void addHcalSignals(const edm::Event &e, const edm::EventSetup &ES)
void setupPileUpEvent(const edm::EventSetup &setup)
void addSignals(const edm::Event &e, const edm::EventSetup &ES) override
void endLuminosityBlock(const edm::LuminosityBlock &l, const edm::EventSetup &setup) override
DataMixingEMDigiWorker * EMDigiWorker_
Definition: Run.h:44
void addSiPixelSignals(const edm::Event &e)
edm::InputTag ZDCPileInputTag_