CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
MixingModule.cc
Go to the documentation of this file.
1 // File: MixingModule.cc
2 // Description: see MixingModule.h
3 // Author: Ursula Berthon, LLR Palaiseau, Bill Tanenbaum
4 //
5 //--------------------------------------------
6 
7 #include <functional>
8 #include <memory>
9 
10 #include "MixingModule.h"
11 #include "MixingWorker.h"
12 #include "Adjuster.h"
13 
37 
38 namespace edm {
39 
40  // Constructor
42  BMixingModule(ps_mix, globalConf),
43  inputTagPlayback_(),
44  mixProdStep2_(ps_mix.getParameter<bool>("mixProdStep2")),
45  mixProdStep1_(ps_mix.getParameter<bool>("mixProdStep1")),
46  digiAccumulators_()
47  {
48  if (!mixProdStep1_ && !mixProdStep2_) LogInfo("MixingModule") << " The MixingModule was run in the Standard mode.";
49  if (mixProdStep1_) LogInfo("MixingModule") << " The MixingModule was run in the Step1 mode. It produces a mixed secondary source.";
50  if (mixProdStep2_) LogInfo("MixingModule") << " The MixingModule was run in the Step2 mode. It uses a mixed secondary source.";
51 
53  if (ps_mix.exists("useCurrentProcessOnly")) {
54  useCurrentProcessOnly_=ps_mix.getParameter<bool>("useCurrentProcessOnly");
55  LogInfo("MixingModule") <<" using given Parameter 'useCurrentProcessOnly' ="<<useCurrentProcessOnly_;
56  }
57  std::string labelPlayback;
58  if (ps_mix.exists("LabelPlayback")) {
59  labelPlayback = ps_mix.getParameter<std::string>("LabelPlayback");
60  }
61  if (labelPlayback.empty()) {
62  labelPlayback = ps_mix.getParameter<std::string>("@module_label");
63  }
64  if (playback_) {
66  consumes<CrossingFramePlaybackInfoNew>(inputTagPlayback_);
67  }
68 
69  ParameterSet ps=ps_mix.getParameter<ParameterSet>("mixObjects");
70  std::vector<std::string> names = ps.getParameterNames();
71  for(std::vector<std::string>::iterator it=names.begin();it!= names.end();++it) {
73  if (!pset.exists("type")) continue; //to allow replacement by empty pset
74  std::string object = pset.getParameter<std::string>("type");
75  std::vector<InputTag> tags=pset.getParameter<std::vector<InputTag> >("input");
76 
77  //if (!mixProdStep2_) {
78 
79  InputTag tagCF = InputTag();
80  std::string labelCF = " ";
81 
82  if (object=="SimTrack") {
83  InputTag tag;
84  if (tags.size()>0) tag=tags[0];
86 
87  branchesActivate(TypeID(typeid(std::vector<SimTrack>)).friendlyClassName(),std::string(""),tag,label);
88  adjustersObjects_.push_back(new Adjuster<std::vector<SimTrack> >(tag, consumesCollector()));
89  bool makeCrossingFrame = pset.getUntrackedParameter<bool>("makeCrossingFrame", false);
90  if(makeCrossingFrame) {
92  produces<CrossingFrame<SimTrack> >(label);
93  }
94  consumes<std::vector<SimTrack> >(tag);
95 
96  LogInfo("MixingModule") <<"Will mix "<<object<<"s with InputTag= "<<tag.encode()<<", label will be "<<label;
97  // std::cout <<"Will mix "<<object<<"s with InputTag= "<<tag.encode()<<", label will be "<<label<<std::endl;
98 
99  } else if (object=="RecoTrack") {
100  InputTag tag;
101  if (tags.size()>0) tag=tags[0];
103 
104  branchesActivate(TypeID(typeid(std::vector<reco::Track>)).friendlyClassName(),std::string(""),tag,label);
105  branchesActivate(TypeID(typeid(std::vector<reco::TrackExtra>)).friendlyClassName(),std::string(""),tag,label);
108  // note: no crossing frame is foreseen to be used for this object type
109 
110  LogInfo("MixingModule") <<"Will mix "<<object<<"s with InputTag= "<<tag.encode()<<", label will be "<<label;
111  //std::cout <<"Will mix "<<object<<"s with InputTag= "<<tag.encode()<<", label will be "<<label<<std::endl;
112 
113  } else if (object=="SimVertex") {
114  InputTag tag;
115  if (tags.size()>0) tag=tags[0];
117 
118  branchesActivate(TypeID(typeid(std::vector<SimVertex>)).friendlyClassName(),std::string(""),tag,label);
119  adjustersObjects_.push_back(new Adjuster<std::vector<SimVertex> >(tag, consumesCollector()));
120  bool makeCrossingFrame = pset.getUntrackedParameter<bool>("makeCrossingFrame", false);
121  if(makeCrossingFrame) {
123  produces<CrossingFrame<SimVertex> >(label);
124  }
125  consumes<std::vector<SimVertex> >(tag);
126 
127  LogInfo("MixingModule") <<"Will mix "<<object<<"s with InputTag "<<tag.encode()<<", label will be "<<label;
128  // std::cout <<"Will mix "<<object<<"s with InputTag "<<tag.encode()<<", label will be "<<label<<std::endl;
129 
130  } else if (object=="HepMCProduct") {
131  InputTag tag;
132  if (tags.size()>0) tag=tags[0];
134 
135  branchesActivate(TypeID(typeid(HepMCProduct)).friendlyClassName(),std::string(""),tag,label);
136  bool makeCrossingFrame = pset.getUntrackedParameter<bool>("makeCrossingFrame", false);
137  if(makeCrossingFrame) {
138  workersObjects_.push_back(new MixingWorker<HepMCProduct>(minBunch_,maxBunch_,bunchSpace_,std::string(""),label,labelCF,maxNbSources_,tag,tagCF,tags));
139  produces<CrossingFrame<HepMCProduct> >(label);
140  }
141  consumes<HepMCProduct>(tag);
142 
143  LogInfo("MixingModule") <<"Will mix "<<object<<"s with InputTag= "<<tag.encode()<<", label will be "<<label;
144  // std::cout <<"Will mix "<<object<<"s with InputTag= "<<tag.encode()<<", label will be "<<label<<std::endl;
145  for(size_t i = 1; i < tags.size(); ++i) {
146  InputTag fallbackTag = tags[i];
147  std::string fallbackLabel;
148  branchesActivate(TypeID(typeid(HepMCProduct)).friendlyClassName(),std::string(""),fallbackTag,fallbackLabel);
149  mayConsume<HepMCProduct>(fallbackTag);
150  }
151 
152  } else if (object=="PCaloHit") {
153  std::vector<std::string> subdets=pset.getParameter<std::vector<std::string> >("subdets");
154  std::vector<std::string> crossingFrames=pset.getUntrackedParameter<std::vector<std::string> >("crossingFrames", std::vector<std::string>());
155  sort_all(crossingFrames);
156  for (unsigned int ii=0;ii<subdets.size();++ii) {
157  InputTag tag;
158  if (tags.size()==1) tag=tags[0];
159  else if(tags.size()>1) tag=tags[ii];
161 
162  branchesActivate(TypeID(typeid(std::vector<PCaloHit>)).friendlyClassName(),subdets[ii],tag,label);
163  adjustersObjects_.push_back(new Adjuster<std::vector<PCaloHit> >(tag, consumesCollector()));
164  if(binary_search_all(crossingFrames, tag.instance())) {
165  workersObjects_.push_back(new MixingWorker<PCaloHit>(minBunch_,maxBunch_,bunchSpace_,subdets[ii],label,labelCF,maxNbSources_,tag,tagCF));
166  produces<CrossingFrame<PCaloHit> >(label);
167  consumes<std::vector<PCaloHit> >(tag);
168  }
169 
170  LogInfo("MixingModule") <<"Will mix "<<object<<"s with InputTag= "<<tag.encode()<<", label will be "<<label;
171  // std::cout <<"Will mix "<<object<<"s with InputTag= "<<tag.encode()<<", label will be "<<label<<std::endl;
172 
173  }
174 
175  } else if (object=="PSimHit") {
176  std::vector<std::string> subdets=pset.getParameter<std::vector<std::string> >("subdets");
177  std::vector<std::string> crossingFrames=pset.getUntrackedParameter<std::vector<std::string> >("crossingFrames", std::vector<std::string>());
178  sort_all(crossingFrames);
179  for (unsigned int ii=0;ii<subdets.size();++ii) {
180  InputTag tag;
181  if (tags.size()==1) tag=tags[0];
182  else if(tags.size()>1) tag=tags[ii];
184 
185  branchesActivate(TypeID(typeid(std::vector<PSimHit>)).friendlyClassName(),subdets[ii],tag,label);
186  adjustersObjects_.push_back(new Adjuster<std::vector<PSimHit> >(tag, consumesCollector()));
187  if(binary_search_all(crossingFrames, tag.instance())) {
188  workersObjects_.push_back(new MixingWorker<PSimHit>(minBunch_,maxBunch_,bunchSpace_,subdets[ii],label,labelCF,maxNbSources_,tag,tagCF));
189  produces<CrossingFrame<PSimHit> >(label);
190  consumes<std::vector<PSimHit> >(tag);
191  }
192 
193  LogInfo("MixingModule") <<"Will mix "<<object<<"s with InputTag= "<<tag.encode()<<", label will be "<<label;
194  // std::cout <<"Will mix "<<object<<"s with InputTag= "<<tag.encode()<<", label will be "<<label<<std::endl;
195  }
196  } else {
197  LogWarning("MixingModule") <<"You have asked to mix an unknown type of object("<<object<<").\n If you want to include it in mixing, please contact the authors of the MixingModule!";
198  }
199  //} //if for mixProdStep2
200  }//while over the mixObjects parameters
201 
203  for (unsigned int branch=0;branch<wantedBranches_.size();++branch) LogDebug("MixingModule")<<"Will keep branch "<<wantedBranches_[branch]<<" for mixing ";
204 
206 
207  produces<PileupMixingContent>();
208 
209  produces<CrossingFramePlaybackInfoNew>();
210 
212  // Create and configure digitizers
213  createDigiAccumulators(ps_mix, iC);
214  }
215 
216 
218  ParameterSet const& digiPSet = mixingPSet.getParameterSet("digitizers");
219  std::vector<std::string> digiNames = digiPSet.getParameterNames();
220  for(auto const& digiName : digiNames) {
221  ParameterSet const& pset = digiPSet.getParameterSet(digiName);
222  std::auto_ptr<DigiAccumulatorMixMod> accumulator = std::auto_ptr<DigiAccumulatorMixMod>(DigiAccumulatorMixModFactory::get()->makeDigiAccumulator(pset, *this, iC));
223  // Create appropriate DigiAccumulator
224  if(accumulator.get() != 0) {
225  digiAccumulators_.push_back(accumulator.release());
226  }
227  }
228  }
229 
231  //change the basic parameters.
233  setup.get<MixingRcd>().get(config);
234  minBunch_=config->minBunch();
235  maxBunch_=config->maxBunch();
236  bunchSpace_=config->bunchSpace();
237  //propagate to change the workers
238  for (unsigned int ii=0;ii<workersObjects_.size();++ii){
239  workersObjects_[ii]->reload(setup);
240  }
241  }
242 
244 
245  label=tag.label()+tag.instance();
246  wantedBranches_.push_back(friendlyName + '_' +
247  tag.label() + '_' +
248  tag.instance());
249 
250  //if useCurrentProcessOnly, we have to change the input tag
253  tag = InputTag(tag.label(),tag.instance(),processName);
254  }
255  }
256 
258  if (adjusters_.empty()){
259  for (auto const& adjuster : adjustersObjects_) {
260  if (adjuster->checkSignal(e)){
261  adjusters_.push_back(adjuster);
262  }
263  }
264  }
265  if (workers_.empty()){
266  for (auto const& worker : workersObjects_) {
267  if (worker->checkSignal(e)){
268  workers_.push_back(worker);
269  }
270  }
271  }
272  }
273 
275  //create playback info
277  //and CrossingFrames
278  for (unsigned int ii=0;ii<workers_.size();++ii){
279  workers_[ii]->createnewEDProduct();
280  }
281  }
282 
283  // Virtual destructor needed.
285  for (auto& worker : workersObjects_) {
286  delete worker;
287  }
288 
289  for (auto& adjuster : adjustersObjects_) {
290  delete adjuster;
291  }
292 
293  for (auto& digiAccumulator : digiAccumulators_) {
294  delete digiAccumulator;
295  }
296  }
297 
299 
300  LogDebug("MixingModule")<<"===============> adding signals for "<<e.id();
301 
302  accumulateEvent(e, setup);
303  // fill in signal part of CrossingFrame
304  for (unsigned int ii=0;ii<workers_.size();++ii) {
305  workers_[ii]->addSignals(e);
306  }
307  }
308 
309  void MixingModule::pileAllWorkers(EventPrincipal const& eventPrincipal,
310  ModuleCallingContext const* mcc,
311  int bunchCrossing, int eventId,
312  int& vertexOffset,
313  const edm::EventSetup& setup,
314  StreamID const& streamID) {
315 
316 
317  InternalContext internalContext(eventPrincipal.id(), mcc);
318  ParentContext parentContext(&internalContext);
319  ModuleCallingContext moduleCallingContext(&moduleDescription());
320  ModuleContextSentry moduleContextSentry(&moduleCallingContext, parentContext);
321 
322  for (auto const& adjuster : adjusters_) {
323  adjuster->doOffset(bunchSpace_, bunchCrossing, eventPrincipal, &moduleCallingContext, eventId, vertexOffset);
324  }
325  PileUpEventPrincipal pep(eventPrincipal, &moduleCallingContext, bunchCrossing);
326  accumulateEvent(pep, setup, streamID);
327 
328  for (auto const& worker : workers_) {
329  LogDebug("MixingModule") <<" merging Event: id " << eventPrincipal.id();
330  // std::cout <<"PILEALLWORKERS merging Event: id " << eventPrincipal.id() << std::endl;
331 
332  worker->addPileups(eventPrincipal, &moduleCallingContext, eventId);
333  }
334  }
335 
337  using namespace std::placeholders;
338 
339  // Don't allocate because PileUp will do it for us.
340  std::vector<edm::SecondaryEventIDAndFileInfo> recordEventID;
341  std::vector<size_t> sizes;
342  sizes.reserve(maxNbSources_*(maxBunch_ + 1 - minBunch_));
343  size_t playbackCounter = 0U;
345  edm::Handle<CrossingFramePlaybackInfoExtended> oldFormatPlaybackInfo_H;
346  bool oldFormatPlayback = false;
347  if (playback_) {
348  bool got = e.getByLabel(inputTagPlayback_, playbackInfo_H);
349  if (!got) {
350  bool gotOld = e.getByLabel(inputTagPlayback_, oldFormatPlaybackInfo_H);
351  if (!gotOld) {
352  throw cms::Exception("MixingProductNotFound") << " No "
353  "CrossingFramePlaybackInfoNew on the input file, but playback "
354  "option set!!!!! Please change the input file if you really want "
355  "playback!!!!!!" << std::endl;
356  }
357  oldFormatPlayback = true;
358  }
359  }
360 
361  // source[0] is "real" pileup. Check to see that this is what we are doing.
362 
363  std::vector<int> PileupList;
364  PileupList.clear();
365  TrueNumInteractions_.clear();
366 
367  std::shared_ptr<PileUp> source0 = inputSources_[0];
368 
369  if((source0 && source0->doPileUp(0) ) && !playback_) {
370  // if((!inputSources_[0] || !inputSources_[0]->doPileUp()) && !playback_ )
371 
372  // Pre-calculate all pileup distributions before we go fishing for events
373 
374  source0->CalculatePileup(minBunch_, maxBunch_, PileupList, TrueNumInteractions_, e.streamID());
375 
376  }
377 
378  // for (int bunchIdx = minBunch_; bunchIdx <= maxBunch_; ++bunchIdx) {
379  // std::cout << " bunch ID, Pileup, True " << bunchIdx << " " << PileupList[bunchIdx-minBunch_] << " " << TrueNumInteractions_[bunchIdx-minBunch_] << std::endl;
380  //}
381 
382  for (int bunchIdx = minBunch_; bunchIdx <= maxBunch_; ++bunchIdx) {
383  for (size_t setBcrIdx=0; setBcrIdx<workers_.size(); ++setBcrIdx) {
384  workers_[setBcrIdx]->setBcrOffset();
385  }
386  for(Accumulators::const_iterator accItr = digiAccumulators_.begin(), accEnd = digiAccumulators_.end(); accItr != accEnd; ++accItr) {
387  (*accItr)->initializeBunchCrossing(e, setup, bunchIdx);
388  }
389 
390  for (size_t readSrcIdx=0; readSrcIdx<maxNbSources_; ++readSrcIdx) {
391  std::shared_ptr<PileUp> source = inputSources_[readSrcIdx]; // this looks like we create
392  // new PileUp objects for each
393  // source for each event?
394  // Why?
395  for (size_t setSrcIdx=0; setSrcIdx<workers_.size(); ++setSrcIdx) {
396  workers_[setSrcIdx]->setSourceOffset(readSrcIdx);
397  }
398 
399  if (!source || !source->doPileUp(bunchIdx)) {
400  sizes.push_back(0U);
401  if(playback_ && !oldFormatPlayback) {
402  playbackCounter += playbackInfo_H->getNumberOfEvents(bunchIdx, readSrcIdx);
403  }
404  continue;
405  }
406 
407  // int eventId = 0;
408  int vertexOffset = 0;
409 
411  if (!playback_) {
412  // non-minbias pileup only gets one event for now. Fix later if desired.
413  int numberOfEvents = (readSrcIdx == 0 ? PileupList[bunchIdx - minBunch_] : 1);
414  sizes.push_back(numberOfEvents);
415  inputSources_[readSrcIdx]->readPileUp(e.id(), recordEventID,
416  std::bind(&MixingModule::pileAllWorkers, std::ref(*this), _1, mcc, bunchIdx,
417  _2, vertexOffset, std::ref(setup), e.streamID()), numberOfEvents, e.streamID());
418  } else if(oldFormatPlayback) {
419  std::vector<edm::EventID> const& playEventID = oldFormatPlaybackInfo_H->getStartEventId(readSrcIdx, bunchIdx);
420  size_t numberOfEvents = playEventID.size();
421  if(readSrcIdx == 0) {
422  PileupList.push_back(numberOfEvents);
423  TrueNumInteractions_.push_back(numberOfEvents);
424  }
425  sizes.push_back(numberOfEvents);
426  std::vector<EventID>::const_iterator begin = playEventID.begin();
427  std::vector<EventID>::const_iterator end = playEventID.end();
428  inputSources_[readSrcIdx]->playOldFormatPileUp(
429  begin, end, recordEventID,
430  std::bind(&MixingModule::pileAllWorkers, std::ref(*this), _1, mcc, bunchIdx,
431  _2, vertexOffset, std::ref(setup), e.streamID()));
432  } else {
433  size_t numberOfEvents = playbackInfo_H->getNumberOfEvents(bunchIdx, readSrcIdx);
434  if(readSrcIdx == 0) {
435  PileupList.push_back(numberOfEvents);
436  TrueNumInteractions_.push_back(numberOfEvents);
437  }
438  sizes.push_back(numberOfEvents);
439  std::vector<SecondaryEventIDAndFileInfo>::const_iterator begin = playbackInfo_H->getEventId(playbackCounter);
440  playbackCounter += numberOfEvents;
441  std::vector<SecondaryEventIDAndFileInfo>::const_iterator end = playbackInfo_H->getEventId(playbackCounter);
442  inputSources_[readSrcIdx]->playPileUp(
443  begin, end, recordEventID,
444  std::bind(&MixingModule::pileAllWorkers, std::ref(*this), _1, mcc, bunchIdx,
445  _2, vertexOffset, std::ref(setup), e.streamID()));
446  }
447  }
448  for(Accumulators::const_iterator accItr = digiAccumulators_.begin(), accEnd = digiAccumulators_.end(); accItr != accEnd; ++accItr) {
449  (*accItr)->finalizeBunchCrossing(e, setup, bunchIdx);
450  }
451  }
452  // Save playback information
453 
454  std::vector<edm::EventID> eventInfoList;
455  for (auto const item : recordEventID) {
456  eventInfoList.emplace_back(item.eventID());
457  }
458 
459  // setInfo swaps recordEventID, so recordEventID is useless (empty) after the call.
460  playbackInfo_->setInfo(recordEventID, sizes);
461 
462  // Keep track of pileup accounting...
463 
464  std::auto_ptr<PileupMixingContent> PileupMixing_;
465 
466  std::vector<int> numInteractionList;
467  std::vector<int> bunchCrossingList;
468  std::vector<float> TrueInteractionList;
469 
470  //Makin' a list: Basically, we don't care about the "other" sources at this point.
471  for (int bunchCrossing=minBunch_;bunchCrossing<=maxBunch_;++bunchCrossing) {
472  bunchCrossingList.push_back(bunchCrossing);
473  if(!inputSources_[0] || !inputSources_[0]->doPileUp(0)) {
474  numInteractionList.push_back(0);
475  TrueInteractionList.push_back(0);
476  }
477  else {
478  numInteractionList.push_back(PileupList[bunchCrossing-minBunch_]);
479  TrueInteractionList.push_back((TrueNumInteractions_)[bunchCrossing-minBunch_]);
480  }
481  }
482 
483  for(Accumulators::const_iterator accItr = digiAccumulators_.begin(), accEnd = digiAccumulators_.end(); accItr != accEnd; ++accItr) {
484  (*accItr)->StorePileupInformation( bunchCrossingList,
485  numInteractionList,
486  TrueInteractionList,
487  eventInfoList,
488  bunchSpace_);
489  }
490 
491 
492  PileupMixing_ = std::auto_ptr<PileupMixingContent>(new PileupMixingContent(bunchCrossingList,
493  numInteractionList,
494  TrueInteractionList,
495  eventInfoList,
496  bunchSpace_));
497 
498  e.put(PileupMixing_);
499 
500  // we have to do the ToF transformation for PSimHits once all pileup has been added
501  for (unsigned int ii=0;ii<workers_.size();++ii) {
502  workers_[ii]->setTof();
503  workers_[ii]->put(e);
504  }
505  }
506 
508 
509  if (playbackInfo_) {
510  std::auto_ptr<CrossingFramePlaybackInfoNew> pOut(playbackInfo_);
511  e.put(pOut);
512  }
513  }
514 
516  for(Accumulators::const_iterator accItr = digiAccumulators_.begin(), accEnd = digiAccumulators_.end(); accItr != accEnd; ++accItr) {
517  (*accItr)->beginRun(run, setup);
518  }
519  BMixingModule::beginRun( run, setup);
520  }
521 
523  for(Accumulators::const_iterator accItr = digiAccumulators_.begin(), accEnd = digiAccumulators_.end(); accItr != accEnd; ++accItr) {
524  (*accItr)->endRun(run, setup);
525  }
526  BMixingModule::endRun( run, setup);
527  }
528 
530  for(Accumulators::const_iterator accItr = digiAccumulators_.begin(), accEnd = digiAccumulators_.end(); accItr != accEnd; ++accItr) {
531  (*accItr)->beginLuminosityBlock(lumi, setup);
532  }
534  }
535 
537  for(Accumulators::const_iterator accItr = digiAccumulators_.begin(), accEnd = digiAccumulators_.end(); accItr != accEnd; ++accItr) {
538  (*accItr)->endLuminosityBlock(lumi, setup);
539  }
541  }
542 
543  void
545  for(Accumulators::const_iterator accItr = digiAccumulators_.begin(), accEnd = digiAccumulators_.end(); accItr != accEnd; ++accItr) {
546  (*accItr)->initializeEvent(event, setup);
547  }
548  }
549 
550  void
552  for(Accumulators::const_iterator accItr = digiAccumulators_.begin(), accEnd = digiAccumulators_.end(); accItr != accEnd; ++accItr) {
553  (*accItr)->accumulate(event, setup);
554  }
555  }
556 
557  void
559  for(Accumulators::const_iterator accItr = digiAccumulators_.begin(), accEnd = digiAccumulators_.end(); accItr != accEnd; ++accItr) {
560  (*accItr)->accumulate(event, setup, streamID);
561  }
562  }
563 
564  void
566  for(Accumulators::const_iterator accItr = digiAccumulators_.begin(), accEnd = digiAccumulators_.end(); accItr != accEnd; ++accItr) {
567  (*accItr)->finalizeEvent(event, setup);
568  }
569  }
570 }//edm
#define LogDebug(id)
void setInfo(std::vector< edm::SecondaryEventIDAndFileInfo > &eventInfo, std::vector< size_t > &sizes)
T getParameter(std::string const &) const
T getUntrackedParameter(std::string const &, T const &) const
int i
Definition: DBlmapReader.cc:9
virtual void reload(const edm::EventSetup &)
virtual void beginRun(const edm::Run &r, const edm::EventSetup &setup) override
virtual ~MixingModule()
virtual void beginLuminosityBlock(LuminosityBlock const &l1, EventSetup const &c) override
static std::string const source("source")
static const HistoName names[]
virtual void createnewEDProduct()
tuple lumi
Definition: fjr2json.py:35
void createDigiAccumulators(const edm::ParameterSet &mixingPSet, edm::ConsumesCollector &iC)
std::vector< float > TrueNumInteractions_
virtual void addSignals(const edm::Event &e, const edm::EventSetup &es)
EventID const & id() const
bool exists(std::string const &parameterName) const
checks if a parameter exists
int ii
Definition: cuy.py:588
std::string encode() const
Definition: InputTag.cc:164
virtual void endRun(const edm::Run &r, const edm::EventSetup &setup) override
virtual void put(edm::Event &e, const edm::EventSetup &es)
ModuleCallingContext const * moduleCallingContext() const
Definition: Event.h:225
virtual void checkSignal(const edm::Event &e)
std::string friendlyName(std::string const &iFullName)
virtual void endLuminosityBlock(LuminosityBlock const &l1, EventSetup const &c) override
std::vector< MixingWorkerBase * > workers_
Definition: MixingModule.h:97
OrphanHandle< PROD > put(std::auto_ptr< PROD > product)
Put a new product.
Definition: Event.h:121
Accumulators digiAccumulators_
Definition: MixingModule.h:103
ConsumesCollector consumesCollector()
Use a ConsumesCollector to gather consumes information from helper functions.
static const std::string kSkipCurrentProcess
Definition: InputTag.h:50
MixingModule(const edm::ParameterSet &ps, MixingCache::Config const *globalConf)
Definition: MixingModule.cc:41
std::vector< AdjusterBase * > adjusters_
Definition: MixingModule.h:95
static const unsigned int maxNbSources_
#define end
Definition: vmac.h:37
std::vector< MixingWorkerBase * > workersObjects_
Definition: MixingModule.h:98
virtual void beginRun(Run const &r1, EventSetup const &c) override
std::vector< std::string > getParameterNames() const
How EventSelector::AcceptEvent() decides whether to accept an event for output otherwise it is excluding the probing of A single or multiple positive and the trigger will pass if any such matching triggers are PASS or EXCEPTION[A criterion thatmatches no triggers at all is detected and causes a throw.] A single negative with an expectation of appropriate bit checking in the decision and the trigger will pass if any such matching triggers are FAIL or EXCEPTION A wildcarded negative criterion that matches more than one trigger in the trigger but the state exists so we define the behavior If all triggers are the negative crieriion will lead to accepting the event(this again matches the behavior of"!*"before the partial wildcard feature was incorporated).The per-event"cost"of each negative criterion with multiple relevant triggers is about the same as!*was in the past
char const * subdets[11]
CrossingFramePlaybackInfoNew * playbackInfo_
Definition: MixingModule.h:93
bool getByLabel(InputTag const &tag, Handle< PROD > &result) const
Definition: Event.h:418
ModuleDescription const & moduleDescription() const
virtual void branchesActivate(const std::string &friendlyName, const std::string &subdet, InputTag &tag, std::string &label)
tuple tags
Definition: o2o.py:248
void finalizeEvent(Event &event, EventSetup const &setup)
void sort_all(RandomAccessSequence &s)
wrappers for std::sort
Definition: Algorithms.h:120
ParameterSet const & getParameterSet(std::string const &) const
const T & get() const
Definition: EventSetup.h:56
std::vector< std::string > wantedBranches_
Definition: MixingModule.h:99
std::vector< AdjusterBase * > adjustersObjects_
Definition: MixingModule.h:96
InputTag inputTagPlayback_
Definition: MixingModule.h:90
std::string const & label() const
Definition: InputTag.h:36
edm::EventID id() const
Definition: EventBase.h:59
#define begin
Definition: vmac.h:30
void accumulateEvent(Event const &event, EventSetup const &setup)
std::vector< std::shared_ptr< PileUp > > inputSources_
StreamID streamID() const
Definition: Event.h:80
bool binary_search_all(ForwardSequence const &s, Datum const &d)
wrappers for std::binary_search
Definition: Algorithms.h:76
std::auto_ptr< DigiAccumulatorMixMod > makeDigiAccumulator(ParameterSet const &, stream::EDProducerBase &, ConsumesCollector &) const
void dropUnwantedBranches(std::vector< std::string > const &wantedBranches)
virtual void beginLuminosityBlock(const edm::LuminosityBlock &l, const edm::EventSetup &setup) override
static DigiAccumulatorMixModFactory const * get()
void initializeEvent(Event const &event, EventSetup const &setup)
std::string const & instance() const
Definition: InputTag.h:37
void setup(std::vector< TH2F > &depth, std::string name, std::string units="")
virtual void endLuminosityBlock(const edm::LuminosityBlock &l, const edm::EventSetup &setup) override
virtual void doPileUp(edm::Event &e, const edm::EventSetup &es) override
Definition: Run.h:43
void pileAllWorkers(EventPrincipal const &ep, ModuleCallingContext const *, int bcr, int id, int &offset, const edm::EventSetup &setup, edm::StreamID const &)
virtual void endRun(Run const &r1, EventSetup const &c) override