DQClient

LSSummary

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 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
#ifndef DQM_HcalCommon_DQClient_h
#define DQM_HcalCommon_DQClient_h

/**
 *	file:
 *	Author:
 *	Description:
 */

#include "DQM/HcalCommon/interface/Container1D.h"
#include "DQM/HcalCommon/interface/Container2D.h"
#include "DQM/HcalCommon/interface/ContainerProf1D.h"
#include "DQM/HcalCommon/interface/ContainerProf2D.h"
#include "DQM/HcalCommon/interface/ContainerSingle1D.h"
#include "DQM/HcalCommon/interface/ContainerSingle2D.h"
#include "DQM/HcalCommon/interface/ContainerXXX.h"
#include "DQM/HcalCommon/interface/DQModule.h"
#include "DQM/HcalCommon/interface/Flag.h"
#include "DQM/HcalCommon/interface/HashFilter.h"
#include "DQM/HcalCommon/interface/Utilities.h"

namespace hcaldqm {
  class DQClient : public DQModule {
  public:
    typedef dqm::legacy::MonitorElement MonitorElement;
    typedef dqm::legacy::DQMStore DQMStore;

    DQClient(std::string const &, std::string const &, edm::ParameterSet const &, edm::ConsumesCollector &iC);
    ~DQClient() override {}

    virtual void beginRun(edm::Run const &, edm::EventSetup const &);
    virtual void beginLuminosityBlock(DQMStore::IBooker &,
                                      DQMStore::IGetter &,
                                      edm::LuminosityBlock const &lb,
                                      edm::EventSetup const &);
    virtual void endLuminosityBlock(DQMStore::IBooker &,
                                    DQMStore::IGetter &,
                                    edm::LuminosityBlock const &,
                                    edm::EventSetup const &);
    virtual std::vector<flag::Flag> endJob(DQMStore::IBooker &, DQMStore::IGetter &);

  protected:
    struct LSSummary {
      //	vector of flags per each FED
      std::vector<std::vector<flag::Flag>> _vflags;
      int _LS;
    };

    //	task name
    std::string _taskname;

    //	counters
    int _totalLS;
    int _maxProcessedLS;

    //	emap
    edm::ESGetToken<HcalDbService, HcalDbRecord> hcalDbServiceToken_;
    edm::ESGetToken<RunInfo, RunInfoRcd> runInfoToken_;
    edm::ESGetToken<HcalChannelQuality, HcalChannelQualityRcd> hcalChannelQualityToken_;
    HcalElectronicsMap const *_emap;

    // Crate and crate eid lists
    std::vector<int> _vCrates;
    std::vector<uint32_t> _vhashCrates;

    //	FED and FED Eids lists
    std::vector<int> _vFEDs;
    std::vector<uint32_t> _vhashFEDs;

    //	Container of Quality masks
    ContainerXXX<uint32_t> _xQuality;

    //	vector of FEDs registered at cDAQ
    std::vector<uint32_t> _vcdaqEids;
  };
}  // namespace hcaldqm

#endif