44 mixProdStep2_(ps_mix.getParameter<bool>(
"mixProdStep2")),
45 mixProdStep1_(ps_mix.getParameter<bool>(
"mixProdStep1")),
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.";
53 if (ps_mix.
exists(
"useCurrentProcessOnly")) {
58 if (ps_mix.
exists(
"LabelPlayback")) {
61 if (labelPlayback.empty()) {
71 for(std::vector<std::string>::iterator it=names.begin();it!= names.end();++it) {
73 if (!pset.
exists(
"type"))
continue;
75 std::vector<InputTag>
tags=pset.
getParameter<std::vector<InputTag> >(
"input");
82 if (
object==
"SimTrack") {
84 if (tags.size()>0) tag=tags[0];
90 if(makeCrossingFrame) {
92 produces<CrossingFrame<SimTrack> >(
label);
94 consumes<std::vector<SimTrack> >(
tag);
96 LogInfo(
"MixingModule") <<
"Will mix "<<
object<<
"s with InputTag= "<<tag.
encode()<<
", label will be "<<
label;
99 }
else if (
object==
"RecoTrack") {
101 if (tags.size()>0) tag=tags[0];
112 LogInfo(
"MixingModule") <<
"Will mix "<<
object<<
"s with InputTag= "<<tag.
encode()<<
", label will be "<<
label;
115 }
else if (
object==
"SimVertex") {
117 if (tags.size()>0) tag=tags[0];
123 if(makeCrossingFrame) {
125 produces<CrossingFrame<SimVertex> >(
label);
127 consumes<std::vector<SimVertex> >(
tag);
129 LogInfo(
"MixingModule") <<
"Will mix "<<
object<<
"s with InputTag "<<tag.
encode()<<
", label will be "<<
label;
132 }
else if (
object==
"HepMCProduct") {
134 if (tags.size()>0) tag=tags[0];
139 if(makeCrossingFrame) {
141 produces<CrossingFrame<HepMCProduct> >(
label);
143 consumes<HepMCProduct>(
tag);
145 LogInfo(
"MixingModule") <<
"Will mix "<<
object<<
"s with InputTag= "<<tag.
encode()<<
", label will be "<<
label;
148 }
else if (
object==
"PCaloHit") {
150 std::vector<std::string> crossingFrames=pset.
getUntrackedParameter<std::vector<std::string> >(
"crossingFrames", std::vector<std::string>());
152 for (
unsigned int ii=0;
ii<subdets.size();++
ii) {
154 if (tags.size()==1) tag=tags[0];
155 else if(tags.size()>1) tag=tags[
ii];
162 produces<CrossingFrame<PCaloHit> >(
label);
163 consumes<std::vector<PCaloHit> >(
tag);
166 LogInfo(
"MixingModule") <<
"Will mix "<<
object<<
"s with InputTag= "<<tag.
encode()<<
", label will be "<<
label;
171 }
else if (
object==
"PSimHit") {
173 std::vector<std::string> crossingFrames=pset.
getUntrackedParameter<std::vector<std::string> >(
"crossingFrames", std::vector<std::string>());
175 for (
unsigned int ii=0;
ii<subdets.size();++
ii) {
177 if (tags.size()==1) tag=tags[0];
178 else if(tags.size()>1) tag=tags[
ii];
185 produces<CrossingFrame<PSimHit> >(
label);
186 consumes<std::vector<PSimHit> >(
tag);
189 LogInfo(
"MixingModule") <<
"Will mix "<<
object<<
"s with InputTag= "<<tag.
encode()<<
", label will be "<<
label;
193 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!";
203 produces<PileupMixingContent>();
205 produces<CrossingFramePlaybackInfoNew>();
216 for(
auto const& digiName : digiNames) {
220 if(accumulator.get() != 0) {
256 if (adjuster->checkSignal(e)){
263 if (worker->checkSignal(e)){
290 delete digiAccumulator;
296 LogDebug(
"MixingModule")<<
"===============> adding signals for "<<e.
id();
307 int bunchCrossing,
int eventId,
319 adjuster->doOffset(
bunchSpace_, bunchCrossing, eventPrincipal, &moduleCallingContext, eventId, vertexOffset);
324 for (
auto const& worker :
workers_) {
325 LogDebug(
"MixingModule") <<
" merging Event: id " << eventPrincipal.
id();
328 worker->addPileups(eventPrincipal, &moduleCallingContext, eventId);
333 using namespace std::placeholders;
336 std::vector<edm::SecondaryEventIDAndFileInfo> recordEventID;
337 std::vector<size_t> sizes;
339 size_t playbackCounter = 0U;
342 bool oldFormatPlayback =
false;
349 "CrossingFramePlaybackInfoNew on the input file, but playback "
350 "option set!!!!! Please change the input file if you really want "
351 "playback!!!!!!" << std::endl;
353 oldFormatPlayback =
true;
359 std::vector<int> PileupList;
365 if((source0 && source0->doPileUp(0) ) && !
playback_) {
379 for (
size_t setBcrIdx=0; setBcrIdx<
workers_.size(); ++setBcrIdx) {
380 workers_[setBcrIdx]->setBcrOffset();
383 (*accItr)->initializeBunchCrossing(e, setup, bunchIdx);
386 for (
size_t readSrcIdx=0; readSrcIdx<
maxNbSources_; ++readSrcIdx) {
391 for (
size_t setSrcIdx=0; setSrcIdx<
workers_.size(); ++setSrcIdx) {
392 workers_[setSrcIdx]->setSourceOffset(readSrcIdx);
395 if (!source || !source->doPileUp(bunchIdx)) {
398 playbackCounter += playbackInfo_H->getNumberOfEvents(bunchIdx, readSrcIdx);
404 int vertexOffset = 0;
409 int numberOfEvents = (readSrcIdx == 0 ? PileupList[bunchIdx -
minBunch_] : 1);
410 sizes.push_back(numberOfEvents);
413 _2, vertexOffset, std::ref(setup), e.
streamID()), numberOfEvents, e.
streamID());
414 }
else if(oldFormatPlayback) {
415 std::vector<edm::EventID>
const& playEventID = oldFormatPlaybackInfo_H->getStartEventId(readSrcIdx, bunchIdx);
416 size_t numberOfEvents = playEventID.size();
417 if(readSrcIdx == 0) {
418 PileupList.push_back(numberOfEvents);
421 sizes.push_back(numberOfEvents);
422 std::vector<EventID>::const_iterator
begin = playEventID.begin();
423 std::vector<EventID>::const_iterator
end = playEventID.end();
425 begin, end, recordEventID,
427 _2, vertexOffset, std::ref(setup), e.
streamID()));
429 size_t numberOfEvents = playbackInfo_H->getNumberOfEvents(bunchIdx, readSrcIdx);
430 if(readSrcIdx == 0) {
431 PileupList.push_back(numberOfEvents);
434 sizes.push_back(numberOfEvents);
435 std::vector<SecondaryEventIDAndFileInfo>::const_iterator
begin = playbackInfo_H->getEventId(playbackCounter);
436 playbackCounter += numberOfEvents;
437 std::vector<SecondaryEventIDAndFileInfo>::const_iterator
end = playbackInfo_H->getEventId(playbackCounter);
439 begin, end, recordEventID,
441 _2, vertexOffset, std::ref(setup), e.
streamID()));
445 (*accItr)->finalizeBunchCrossing(e, setup, bunchIdx);
450 std::vector<edm::EventID> eventInfoList;
451 for (
auto const item : recordEventID) {
452 eventInfoList.emplace_back(item.eventID());
460 std::auto_ptr<PileupMixingContent> PileupMixing_;
462 std::vector<int> numInteractionList;
463 std::vector<int> bunchCrossingList;
464 std::vector<float> TrueInteractionList;
468 bunchCrossingList.push_back(bunchCrossing);
470 numInteractionList.push_back(0);
471 TrueInteractionList.push_back(0);
474 numInteractionList.push_back(PileupList[bunchCrossing-
minBunch_]);
480 (*accItr)->StorePileupInformation( bunchCrossingList,
488 PileupMixing_ = std::auto_ptr<PileupMixingContent>(
new PileupMixingContent(bunchCrossingList,
494 e.
put(PileupMixing_);
506 std::auto_ptr<CrossingFramePlaybackInfoNew> pOut(
playbackInfo_);
513 (*accItr)->beginRun(run, setup);
520 (*accItr)->endRun(run, setup);
527 (*accItr)->beginLuminosityBlock(lumi, setup);
534 (*accItr)->endLuminosityBlock(lumi, setup);
542 (*accItr)->initializeEvent(event, setup);
549 (*accItr)->accumulate(event, setup);
556 (*accItr)->accumulate(event, setup, streamID);
563 (*accItr)->finalizeEvent(event, setup);
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
virtual void reload(const edm::EventSetup &)
virtual void beginRun(const edm::Run &r, const edm::EventSetup &setup) override
MixingModule(const edm::ParameterSet &ps)
virtual void beginLuminosityBlock(LuminosityBlock const &l1, EventSetup const &c) override
static std::string const source("source")
static const HistoName names[]
virtual void createnewEDProduct()
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 ¶meterName) const
checks if a parameter exists
std::auto_ptr< DigiAccumulatorMixMod > makeDigiAccumulator(ParameterSet const &, one::EDProducerBase &, ConsumesCollector &) const
ModuleDescription const & moduleDescription() const
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
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_
OrphanHandle< PROD > put(std::auto_ptr< PROD > product)
Put a new product.
Accumulators digiAccumulators_
ConsumesCollector consumesCollector()
Use a ConsumesCollector to gather consumes information from helper functions.
std::vector< AdjusterBase * > adjusters_
static const unsigned int maxNbSources_
std::vector< MixingWorkerBase * > workersObjects_
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
CrossingFramePlaybackInfoNew * playbackInfo_
bool getByLabel(InputTag const &tag, Handle< PROD > &result) const
bool useCurrentProcessOnly_
virtual void branchesActivate(const std::string &friendlyName, const std::string &subdet, InputTag &tag, std::string &label)
void finalizeEvent(Event &event, EventSetup const &setup)
void sort_all(RandomAccessSequence &s)
wrappers for std::sort
ParameterSet const & getParameterSet(std::string const &) const
std::vector< std::string > wantedBranches_
std::vector< AdjusterBase * > adjustersObjects_
InputTag inputTagPlayback_
void accumulateEvent(Event const &event, EventSetup const &setup)
std::vector< std::shared_ptr< PileUp > > inputSources_
StreamID streamID() const
bool binary_search_all(ForwardSequence const &s, Datum const &d)
wrappers for std::binary_search
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)
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
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