CMS 3D CMS Logo

ScalersRawToDigi.cc
Go to the documentation of this file.
1 // -*- C++ -*-
2 //
3 // Package: EventFilter/ScalersRawToDigi
4 // Class: ScalersRawToDigi
5 //
12 //
13 // Original Author: William Badgett
14 // Created: Wed Nov 14 07:47:59 CDT 2006
15 //
16 
17 #include <memory>
18 
25 
26 // FEDRawData
29 
30 // Scalers classes
39 
41 public:
42  explicit ScalersRawToDigi(const edm::ParameterSet&);
43  ~ScalersRawToDigi() override;
44  static void fillDescriptions(edm::ConfigurationDescriptions& descriptions);
45 
46  void produce(edm::Event&, const edm::EventSetup&) override;
47 
48 private:
51 };
52 
53 // Constructor
54 ScalersRawToDigi::ScalersRawToDigi(const edm::ParameterSet& iConfig) : inputTag_((char const*)"rawDataCollector") {
55  produces<L1AcceptBunchCrossingCollection>();
56  produces<L1TriggerScalersCollection>();
57  produces<Level1TriggerScalersCollection>();
58  produces<LumiScalersCollection>();
59  produces<BeamSpotOnlineCollection>();
60  produces<DcsStatusCollection>();
61  if (iConfig.exists("scalersInputTag")) {
62  inputTag_ = iConfig.getParameter<edm::InputTag>("scalersInputTag");
63  }
64  fedToken_ = consumes<FEDRawDataCollection>(inputTag_);
65 }
66 
67 // Destructor
69 
72  desc.add<edm::InputTag>("scalersInputTag", edm::InputTag("rawDataCollector"));
73  descriptions.add("scalersRawToDigi", desc);
74 }
75 
76 // Method called to produce the data
78  using namespace edm;
79 
80  // Get a handle to the FED data collection
82  iEvent.getByToken(fedToken_, rawdata);
83 
84  auto pLumi = std::make_unique<LumiScalersCollection>();
85 
86  auto pOldTrigger = std::make_unique<L1TriggerScalersCollection>();
87 
88  auto pTrigger = std::make_unique<Level1TriggerScalersCollection>();
89 
90  auto pBunch = std::make_unique<L1AcceptBunchCrossingCollection>();
91 
92  auto pBeamSpotOnline = std::make_unique<BeamSpotOnlineCollection>();
93  auto pDcsStatus = std::make_unique<DcsStatusCollection>();
94 
96  const FEDRawData& fedData = rawdata->FEDData(ScalersRaw::SCALERS_FED_ID);
97  unsigned short int length = fedData.size();
98  if (length > 0) {
99  int nWords = length / 8;
100  int nBytesExtra = 0;
101 
102  const ScalersEventRecordRaw_v6* raw = (struct ScalersEventRecordRaw_v6*)fedData.data();
103  if ((raw->version == 1) || (raw->version == 2)) {
104  L1TriggerScalers oldTriggerScalers(fedData.data());
105  pOldTrigger->push_back(oldTriggerScalers);
106  nBytesExtra = length - sizeof(struct ScalersEventRecordRaw_v1);
107  } else if (raw->version >= 3) {
108  Level1TriggerScalers triggerScalers(fedData.data());
109  pTrigger->push_back(triggerScalers);
110  if (raw->version >= 6) {
111  nBytesExtra = ScalersRaw::N_BX_v6 * sizeof(unsigned long long);
112  } else {
113  nBytesExtra = ScalersRaw::N_BX_v2 * sizeof(unsigned long long);
114  }
115  }
116 
117  LumiScalers lumiScalers(fedData.data());
118  pLumi->push_back(lumiScalers);
119 
120  if ((nBytesExtra >= 8) && ((nBytesExtra % 8) == 0)) {
121  unsigned long long* data = (unsigned long long*)fedData.data();
122 
123  int nWordsExtra = nBytesExtra / 8;
124  for (int i = 0; i < nWordsExtra; i++) {
125  int index = nWords - (nWordsExtra + 1) + i;
126  L1AcceptBunchCrossing bc(i, data[index]);
127  pBunch->push_back(bc);
128  }
129  }
130 
131  if (raw->version >= 4) {
132  BeamSpotOnline beamSpotOnline(fedData.data());
133  pBeamSpotOnline->push_back(beamSpotOnline);
134 
135  DcsStatus dcsStatus(fedData.data());
136  pDcsStatus->push_back(dcsStatus);
137  }
138  }
139  iEvent.put(std::move(pOldTrigger));
140  iEvent.put(std::move(pTrigger));
141  iEvent.put(std::move(pLumi));
142  iEvent.put(std::move(pBunch));
143  iEvent.put(std::move(pBeamSpotOnline));
144  iEvent.put(std::move(pDcsStatus));
145 }
146 
147 // Define this as a plug-in
T getParameter(std::string const &) const
static void fillDescriptions(edm::ConfigurationDescriptions &descriptions)
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:131
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:525
bool exists(std::string const &parameterName) const
checks if a parameter exists
edm::InputTag inputTag_
size_t size() const
Lenght of the data buffer in bytes.
Definition: FEDRawData.h:45
~ScalersRawToDigi() override
int iEvent
Definition: GenABIO.cc:224
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
const FEDRawData & FEDData(int fedid) const
retrieve data for fed
ScalersRawToDigi(const edm::ParameterSet &)
ParameterDescriptionBase * add(U const &iLabel, T const &value)
void produce(edm::Event &, const edm::EventSetup &) override
void add(std::string const &label, ParameterSetDescription const &psetDescription)
edm::EDGetTokenT< FEDRawDataCollection > fedToken_
HLT enums.
char data[epos_bytes_allocation]
Definition: EPOS_Wrapper.h:79
def move(src, dest)
Definition: eostools.py:511