CSCMonitorModule

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 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127
/*
 * =====================================================================================
 *
 *       Filename:  CSCMonitorModule.h
 *
 *    Description:  Updated CSC Monitor module
 *
 *        Version:  1.0
 *        Created:  11/13/2008 01:36:45 PM
 *       Revision:  none
 *       Compiler:  gcc
 *
 *         Author:  Valdas Rapsevicius (VR), valdas.rapsevicius@cern.ch
 *        Company:  CERN, CH
 *
 * =====================================================================================
 */

#ifndef CSCMonitorModule_H
#define CSCMonitorModule_H

/// Global stuff
#include <iostream>
#include <cstring>
#include <vector>
#include <map>
#include <set>

/// DQM Framework stuff
#include <FWCore/ParameterSet/interface/ParameterSet.h>

#include <DQMServices/Core/interface/DQMOneEDAnalyzer.h>

#include <FWCore/ServiceRegistry/interface/Service.h>
#include <FWCore/Framework/interface/ESHandle.h>
#include <FWCore/Framework/interface/EventSetup.h>

#ifdef DQMGLOBAL
#include <FWCore/Utilities/interface/InputTag.h>
#include <FWCore/Framework/interface/ConsumesCollector.h>
#endif

/// CSC Framework stuff
#include "DataFormats/MuonDetId/interface/CSCDetId.h"
#include "CondFormats/CSCObjects/interface/CSCCrateMap.h"
#include "CondFormats/DataRecord/interface/CSCCrateMapRcd.h"
#include "DataFormats/Scalers/interface/DcsStatus.h"

/// CSCDQM Framework stuff
#include "CSCDQM_Logger.h"
#include "CSCDQM_Configuration.h"
#include "CSCDQM_Dispatcher.h"

/// Local stuff
#include "CSCMonitorObject.h"

/// Local Constants
static const char INPUT_TAG_LABEL[] = "source";
static const char DIR_EVENTINFO[] = "CSC/EventInfo/";
static const char DIR_DCSINFO[] = "CSC/EventInfo/DCSContents/";
static const char DIR_DAQINFO[] = "CSC/EventInfo/DAQContents/";
static const char DIR_CRTINFO[] = "CSC/EventInfo/CertificationContents/";

static const unsigned int MIN_CRATE_ID = 1;
static const unsigned int MAX_CRATE_ID = 60;
static const unsigned int MIN_DMB_SLOT = 1;
static const unsigned int MAX_DMB_SLOT = 10;

/**
 * @class CSCMonitorModule
 * @brief Common CSC DQM Module that uses CSCDQM Framework  
 */
class CSCMonitorModule : public DQMOneEDAnalyzer<>, public cscdqm::MonitorObjectProvider {
  /**
   * Global stuff
   */

public:
  CSCMonitorModule(const edm::ParameterSet& ps);
  ~CSCMonitorModule() override;

private:
  cscdqm::Configuration config;
  cscdqm::Dispatcher* dispatcher;
  // DQMStore                 *dbe;
  DQMStore::IBooker* ibooker;
  edm::InputTag inputTag;
  bool prebookEffParams;
  bool processDcsScalers;

  const edm::ESGetToken<CSCCrateMap, CSCCrateMapRcd> hcrateToken_;

  /** Pointer to crate mapping from database **/
  const CSCCrateMap* pcrate;

  std::vector<std::string> maskedHW;

#ifdef DQMGLOBAL
  edm::EDGetTokenT<DcsStatusCollection> dcstoken;
#endif

  /**
   * MonitorObjectProvider Implementation
   */

public:
  bool getCSCDetId(const unsigned int crateId, const unsigned int dmbId, CSCDetId& detId) const override {
    // Check parameter values
    if (crateId < MIN_CRATE_ID || crateId > MAX_CRATE_ID || dmbId < MIN_DMB_SLOT || dmbId > MAX_DMB_SLOT) {
      return false;
    }
    detId = pcrate->detId(crateId, dmbId, 0, 0);
    return (detId.rawId() != 0);
  }

  cscdqm::MonitorObject* bookMonitorObject(const cscdqm::HistoBookRequest& p_req) override;

  /** 
   * EDAnalyzer Implementation
   */

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

#endif