L1TStage2RegionalMuonShowerComp

ratioVariables

tfs

variables

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

#include "DataFormats/L1TMuon/interface/RegionalMuonShower.h"

#include "DQMServices/Core/interface/DQMEDAnalyzer.h"
#include "DQMServices/Core/interface/DQMStore.h"

#include "FWCore/Framework/interface/Event.h"
#include "FWCore/MessageLogger/interface/MessageLogger.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "FWCore/ParameterSet/interface/ConfigurationDescriptions.h"
#include "FWCore/ParameterSet/interface/ParameterSetDescription.h"

class L1TStage2RegionalMuonShowerComp : public DQMEDAnalyzer {
public:
  L1TStage2RegionalMuonShowerComp(const edm::ParameterSet& ps);
  ~L1TStage2RegionalMuonShowerComp() override;
  static void fillDescriptions(edm::ConfigurationDescriptions& descriptions);

protected:
  void bookHistograms(DQMStore::IBooker&, const edm::Run&, const edm::EventSetup&) override;
  void analyze(const edm::Event&, const edm::EventSetup&) override;

private:
  enum variables {
    BXRANGEGOOD = 1,
    BXRANGEBAD,
    NSHOWERGOOD,
    NSHOWERBAD,
    SHOWERALL,
    SHOWERGOOD,
    NOMINALBAD,
    TIGHTBAD,
    LOOSEBAD
  };
  enum ratioVariables { RBXRANGE = 1, RNSHOWER, RSHOWER, RNOMINAL, RTIGHT, RLOOSE };
  enum tfs { EMTFNEGBIN = 1, EMTFPOSBIN };
  int numSummaryBins_{LOOSEBAD};
  int numErrBins_{RLOOSE};
  bool incBin_[RLOOSE + 1];

  edm::EDGetTokenT<l1t::RegionalMuonShowerBxCollection> showerToken1_;
  edm::EDGetTokenT<l1t::RegionalMuonShowerBxCollection> showerToken2_;
  std::string monitorDir_;
  std::string showerColl1Title_;
  std::string showerColl2Title_;
  std::string summaryTitle_;
  std::vector<int> ignoreBin_;
  bool verbose_;

  MonitorElement* summary_;
  MonitorElement* errorSummaryNum_;
  MonitorElement* errorSummaryDen_;

  MonitorElement* showerColl1BxRange_;
  MonitorElement* showerColl1nShowers_;
  MonitorElement* showerColl1ShowerTypeVsProcessor_;
  MonitorElement* showerColl1ShowerTypeVsBX_;
  MonitorElement* showerColl1ProcessorVsBX_;

  MonitorElement* showerColl2BxRange_;
  MonitorElement* showerColl2nShowers_;
  MonitorElement* showerColl2ShowerTypeVsProcessor_;
  MonitorElement* showerColl2ShowerTypeVsBX_;
  MonitorElement* showerColl2ProcessorVsBX_;

  static constexpr unsigned IDX_LOOSE_SHOWER{3};
  static constexpr unsigned IDX_TIGHT_SHOWER{2};
  static constexpr unsigned IDX_NOMINAL_SHOWER{1};
};

#endif