File indexing completed on 2024-04-06 12:30:36
0001 #ifndef SimGeneral_MixingModule_DigiAccumulatorMixMod_h
0002 #define SimGeneral_MixingModule_DigiAccumulatorMixMod_h
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022 #include <vector>
0023 #include "SimDataFormats/PileupSummaryInfo/interface/PileupMixingContent.h"
0024 #include "DataFormats/Provenance/interface/EventID.h"
0025
0026
0027
0028
0029
0030 namespace edm {
0031 class Event;
0032 class EventPrincipal;
0033 class EventSetup;
0034 class LuminosityBlock;
0035 class Run;
0036 class StreamID;
0037 }
0038
0039 class PileUpEventPrincipal;
0040
0041 class DigiAccumulatorMixMod {
0042 public:
0043 DigiAccumulatorMixMod();
0044
0045 DigiAccumulatorMixMod(DigiAccumulatorMixMod const&) = delete;
0046
0047 DigiAccumulatorMixMod const& operator=(DigiAccumulatorMixMod const&) = delete;
0048
0049 virtual ~DigiAccumulatorMixMod();
0050
0051
0052
0053
0054
0055
0056
0057 virtual void initializeEvent(edm::Event const& event, edm::EventSetup const& setup) = 0;
0058
0059
0060 virtual void accumulate(edm::Event const& event, edm::EventSetup const& setup) = 0;
0061
0062
0063 virtual void accumulate(PileUpEventPrincipal const& event, edm::EventSetup const& setup, edm::StreamID const&) = 0;
0064
0065
0066
0067 virtual void finalizeEvent(edm::Event& event, edm::EventSetup const& setup) = 0;
0068
0069
0070 virtual void initializeBunchCrossing(edm::Event const& event, edm::EventSetup const& setup, int bunchCrossing) {}
0071
0072
0073
0074 virtual void finalizeBunchCrossing(edm::Event& event, edm::EventSetup const& setup, int bunchCrossing) {}
0075
0076 virtual void beginRun(edm::Run const& run, edm::EventSetup const& setup) {}
0077 virtual void endRun(edm::Run const& run, edm::EventSetup const& setup) {}
0078 virtual void beginLuminosityBlock(edm::LuminosityBlock const& lumi, edm::EventSetup const& setup) {}
0079 virtual void endLuminosityBlock(edm::LuminosityBlock const& lumi, edm::EventSetup const& setup) {}
0080
0081 virtual void StorePileupInformation(std::vector<int>& numInteractionList,
0082 std::vector<int>& bunchCrossingList,
0083 std::vector<float>& TrueInteractionList,
0084 std::vector<edm::EventID>& eventList,
0085 int bunchSpace) {}
0086
0087 virtual PileupMixingContent* getEventPileupInfo() {
0088 std::cout << " You must override the virtual functions in DigiAccumulatorMixMod in\n"
0089 << "order to access PileupInformation. Returning empty object." << std::endl;
0090
0091 PileupMixingContent* dummyPileupObject = new PileupMixingContent();
0092
0093 return dummyPileupObject;
0094 }
0095
0096 private:
0097
0098 };
0099
0100 #endif