L1TStage2RatioClient

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
#ifndef DQM_L1TMonitorClient_L1TStage2RatioClient_H
#define DQM_L1TMonitorClient_L1TStage2RatioClient_H

#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "FWCore/ParameterSet/interface/ConfigurationDescriptions.h"
#include "FWCore/ParameterSet/interface/ParameterSetDescription.h"
#include "DQMServices/Core/interface/DQMStore.h"
#include "DQMServices/Core/interface/DQMEDHarvester.h"

class L1TStage2RatioClient : public DQMEDHarvester {
public:
  L1TStage2RatioClient(const edm::ParameterSet&);
  ~L1TStage2RatioClient() override;
  static void fillDescriptions(edm::ConfigurationDescriptions& descriptions);

protected:
  void dqmEndJob(DQMStore::IBooker& ibooker, DQMStore::IGetter& igetter) override;
  void dqmEndLuminosityBlock(DQMStore::IBooker& ibooker,
                             DQMStore::IGetter& igetter,
                             const edm::LuminosityBlock& lumiSeg,
                             const edm::EventSetup& c) override;

private:
  void book(DQMStore::IBooker& ibooker, DQMStore::IGetter& igetter);
  void processHistograms(DQMStore::IGetter& igetter);

  std::string monitorDir_;
  std::string inputNum_;
  std::string inputDen_;
  std::string ratioName_;
  std::string ratioTitle_;
  std::string yAxisTitle_;
  bool binomialErr_;
  std::vector<int> ignoreBin_;

  MonitorElement* ratioME_;
};

#endif