RawLSFlag

RawRunSummary

Macros

Line Code
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