SiPixelRawDataErrorModule

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
#ifndef SiPixelMonitorRawData_SiPixelRawDataErrorModule_h
#define SiPixelMonitorRawData_SiPixelRawDataErrorModule_h
// -*- C++ -*-
//
// Package:    SiPixelMonitorRawData
// Class:      SiPixelRawDataErrorModule
//
/**\class

 Description:
 Error monitoring elements for a Pixel sensor.

 Implementation:
 Contains three functions to monitor error information.  "book" creates
 histograms in detector units and "fill" fills the monitoring elements with
 input error information.

*/
//
// Original Author:  Andrew York
//         Created:
//
#include "DQMServices/Core/interface/DQMStore.h"
#include "DataFormats/Common/interface/DetSetVector.h"
#include "DataFormats/SiPixelRawData/interface/SiPixelRawDataError.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include <cstdint>

class SiPixelRawDataErrorModule {
public:
  typedef dqm::reco::MonitorElement MonitorElement;
  typedef dqm::reco::DQMStore DQMStore;

  /// Default constructor
  SiPixelRawDataErrorModule();
  /// Constructor with raw DetId
  SiPixelRawDataErrorModule(const uint32_t &id);
  /// Constructor with raw DetId and sensor size
  SiPixelRawDataErrorModule(const uint32_t &id, const int &ncols, const int &nrows);
  /// Destructor
  ~SiPixelRawDataErrorModule();

  typedef edm::DetSet<SiPixelRawDataError>::const_iterator ErrorIterator;

  /// Book histograms
  void book(const edm::ParameterSet &iConfig, DQMStore::IBooker &, int type = 0, bool isUpgrade = false);
  /// Fill histograms
  int fill(const edm::DetSetVector<SiPixelRawDataError> &input,
           std::map<std::string, MonitorElement **> *meMapFEDs,
           bool modon = true,
           bool ladon = false,
           bool bladeon = false);
  /// Fill FED histograms
  int fillFED(const edm::DetSetVector<SiPixelRawDataError> &input, std::map<std::string, MonitorElement **> *meMapFEDs);

private:
  uint32_t id_;
  int ncols_;
  int nrows_;
  bool _debug_;

  // barrel:
  MonitorElement *meErrorTypeLad_;
  MonitorElement *meNErrorsLad_;
  MonitorElement *meFullTypeLad_;
  MonitorElement *meTBMMessageLad_;
  MonitorElement *meTBMTypeLad_;
  MonitorElement *meEvtNbrLad_;
  MonitorElement *meEvtSizeLad_;

  // forward:
  MonitorElement *meErrorTypeBlade_;
  MonitorElement *meNErrorsBlade_;
  MonitorElement *meFullTypeBlade_;
  MonitorElement *meTBMMessageBlade_;
  MonitorElement *meTBMTypeBlade_;
  MonitorElement *meEvtNbrBlade_;
  MonitorElement *meEvtSizeBlade_;

  static const int LINK_bits, ROC_bits, DCOL_bits, PXID_bits, ADC_bits, DataBit_bits, TRLRBGN_bits, EVTLGT_bits,
      TRLREND_bits;
  static const int LINK_shift, ROC_shift, DCOL_shift, PXID_shift, ADC_shift, DB0_shift, DB1_shift, DB2_shift, DB3_shift,
      DB4_shift, DB5_shift, DB6_shift, DB7_shift, TRLRBGN_shift, EVTLGT_shift, TRLREND_shift;
  static const uint32_t LINK_mask, ROC_mask, DCOL_mask, PXID_mask, ADC_mask, DataBit_mask;
  static const unsigned long long TRLRBGN_mask, EVTLGT_mask, TRLREND_mask;
};
#endif