1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
#ifndef DQM_HcalTasks_RawRunSummary_h
#define DQM_HcalTasks_RawRunSummary_h
#include "DQM/HcalCommon/interface/DQClient.h"
#include "DQM/HcalCommon/interface/ElectronicsMap.h"
namespace hcaldqm {
class RawRunSummary : public DQClient {
public:
RawRunSummary(std::string const &, std::string const &, edm::ParameterSet const &, edm::ConsumesCollector &iC);
~RawRunSummary() override {}
void beginRun(edm::Run const &, edm::EventSetup const &) override;
void endLuminosityBlock(DQMStore::IBooker &,
DQMStore::IGetter &,
edm::LuminosityBlock const &,
edm::EventSetup const &) override;
std::vector<flag::Flag> endJob(DQMStore::IBooker &, DQMStore::IGetter &) override;
protected:
// Flag Summary for each LS and Run as a whole
std::vector<LSSummary> _vflagsLS;
electronicsmap::ElectronicsMap _ehashmap;
// some useful vectors - not to reintialize all the time
std::vector<uint32_t> _vhashVME, _vhashuTCA;
std::vector<int> _vFEDsVME, _vFEDsuTCA;
filter::HashFilter _filter_VME, _filter_uTCA;
// Containers to store info for the whole run
Container2D _cEvnMsm_ElectronicsuTCA;
Container2D _cBcnMsm_ElectronicsuTCA;
Container2D _cBadQuality_depth;
bool _booked;
//
ContainerXXX<uint32_t> _xEvn, _xBcn, _xBadQ;
enum RawLSFlag { fEvnMsm = 0, fBcnMsm = 1, fBadQ = 2, nRawFlag = 3 };
};
} // namespace hcaldqm
#endif
|