L1TStage2uGT

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 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94
#ifndef L1TSTAGE2UGT_H
#define L1TSTAGE2UGT_H

/**
 * \class L1TStage2uGT
 *
 * Description: DQM for L1 Micro Global Trigger.
 *
 * \author Mateusz Zarucki 2016
 * \author J. Berryhill, I. Mikulec
 * \author Vasile Mihai Ghete - HEPHY Vienna
 *
 */

// System include files
#include <memory>
#include <vector>
#include <utility>
// User include files
#include "FWCore/Framework/interface/Frameworkfwd.h"
#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/MakerMacros.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "FWCore/ServiceRegistry/interface/Service.h"
#include "FWCore/MessageLogger/interface/MessageLogger.h"
#include "FWCore/Framework/interface/EventSetup.h"

// L1 trigger include files
//#include "DataFormats/L1GlobalTrigger/interface/L1GlobalTriggerReadoutSetup.h"
#include "DataFormats/L1TGlobal/interface/GlobalAlgBlk.h"
#include "DataFormats/L1TGlobal/interface/GlobalExtBlk.h"
#include "DataFormats/L1Trigger/interface/BXVector.h"
#include "L1Trigger/L1TGlobal/interface/L1TGlobalUtil.h"

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

//
// Class declaration
//

class L1TStage2uGT : public DQMEDAnalyzer {
public:
  L1TStage2uGT(const edm::ParameterSet& ps);  // constructor
  ~L1TStage2uGT() override;                   // destructor

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

private:
  // Input parameters
  edm::EDGetTokenT<GlobalAlgBlkBxCollection> l1tStage2uGtSource_;  // input tag for L1 uGT DAQ readout record

  std::string monitorDir_;  // histogram folder for L1 uGT plots

  bool verbose_;  // verbosity switch

  // To get the number of algorithms
  std::shared_ptr<l1t::L1TGlobalUtil> gtUtil_;
  int numAlgs_;  // number of algorithms

  // Algorithm bits
  MonitorElement* algoBits_before_bxmask_;
  MonitorElement* algoBits_before_prescale_;
  MonitorElement* algoBits_after_prescale_;

  // Algorithm bits correlation
  MonitorElement* algoBits_before_bxmask_corr_;
  MonitorElement* algoBits_before_prescale_corr_;
  MonitorElement* algoBits_after_prescale_corr_;

  // Algorithm bits vs global BX number
  MonitorElement* algoBits_before_bxmask_bx_global_;
  MonitorElement* algoBits_before_prescale_bx_global_;
  MonitorElement* algoBits_after_prescale_bx_global_;

  // Algorithm bits vs BX number in event
  MonitorElement* algoBits_before_bxmask_bx_inEvt_;
  MonitorElement* algoBits_before_prescale_bx_inEvt_;
  MonitorElement* algoBits_after_prescale_bx_inEvt_;

  // Algorithm bits vs LS
  MonitorElement* algoBits_before_bxmask_lumi_;
  MonitorElement* algoBits_before_prescale_lumi_;
  MonitorElement* algoBits_after_prescale_lumi_;

  // Prescale factor index
  MonitorElement* prescaleFactorSet_;
};

#endif