ModMEs

SiStripMonitorPedestals

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
#ifndef SiStripMonitorPedestals_SiStripMonitorPedestals_h
#define SiStripMonitorPedestals_SiStripMonitorPedestals_h
// -*- C++ -*-
//
// Package:     SiStripMonitorPedestals
// Class  :     SiStripMonitorPedestals
//
/**\class SiStripMonitorPedestals SiStripMonitorPedestals.h

 Description: <one line class summary>

 Usage:
    <usage>

*/
//
// Original Author:  gennai, dutta
//         Created:  Sat Feb  4 20:49:51 CET 2006
//

// system include files
#include <memory>
#include <iomanip>
#include <string>
#include <cstdint>

// user include files
#include "FWCore/Framework/interface/ESWatcher.h"
#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/Frameworkfwd.h"
#include "FWCore/Framework/interface/MakerMacros.h"
#include "FWCore/Utilities/interface/EDGetToken.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"

// data formats
#include "DataFormats/Common/interface/DetSetVector.h"
#include "DataFormats/FEDRawData/interface/FEDRawDataCollection.h"
#include "DataFormats/SiStripDigi/interface/SiStripDigi.h"
#include "DataFormats/SiStripDigi/interface/SiStripRawDigi.h"

// cabling
#include "CalibFormats/SiStripObjects/interface/SiStripDetCabling.h"
#include "CalibTracker/Records/interface/SiStripDetCablingRcd.h"

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

class ApvAnalysisFactory;
class SiStripDetCabling;

class SiStripMonitorPedestals : public DQMOneEDAnalyzer<> {
public:
  explicit SiStripMonitorPedestals(const edm::ParameterSet &);
  ~SiStripMonitorPedestals() override;

  void analyze(const edm::Event &, const edm::EventSetup &) override;
  void dqmEndRun(edm::Run const &run, edm::EventSetup const &eSetup) override;
  void endJob() override;
  void bookHistograms(DQMStore::IBooker &, edm::Run const &, edm::EventSetup const &) override;

private:
  edm::EDGetTokenT<edm::DetSetVector<SiStripRawDigi>> digiToken_;

  void resetMEs(uint32_t idet);
  void createMEs(DQMStore::IBooker &, edm::EventSetup const &eSetup);
  void fillCondDBMEs(edm::EventSetup const &eSetup);

  struct ModMEs {
    MonitorElement *PedsPerStrip;
    MonitorElement *PedsDistribution;
    MonitorElement *PedsEvolution;

    MonitorElement *CMSubNoisePerStrip;
    MonitorElement *RawNoisePerStrip;
    MonitorElement *CMSubNoiseProfile;
    MonitorElement *RawNoiseProfile;
    MonitorElement *NoisyStrips;
    MonitorElement *NoisyStripDistribution;

    MonitorElement *CMDistribution;
    MonitorElement *CMSlopeDistribution;

    // MonitorElements for CondDB data display
    MonitorElement *PedsPerStripDB;
    MonitorElement *CMSubNoisePerStripDB;
    MonitorElement *BadStripsDB;
  };

  DQMStore *dqmStore_;
  edm::ParameterSet conf_;
  std::map<uint32_t, ModMEs> PedMEs;
  const SiStripDetCabling *detcabling;
  edm::ParameterSet pedsPSet_;
  bool analyzed;
  bool firstEvent;

  // The following to be put inside the parametersets
  int16_t nEvUpdate_;
  int16_t signalCutPeds_;
  int16_t nEvTot_;
  int16_t nEvInit_;
  int nIteration_;
  ApvAnalysisFactory *apvFactory_;
  int theEventInitNumber_;
  int theEventIterNumber_;
  int NumCMstripsInGroup_;
  std::string runTypeFlag_;
  std::string outPutFileName;

  edm::ESGetToken<TrackerTopology, TrackerTopologyRcd> tTopoToken_;
  edm::ESGetToken<SiStripDetCabling, SiStripDetCablingRcd> detCablingToken_;
  edm::ESWatcher<SiStripDetCablingRcd> detCablingWatcher_;
  edm::ESGetToken<SiStripPedestals, SiStripPedestalsRcd> pedestalToken_;
  edm::ESGetToken<SiStripNoises, SiStripNoisesRcd> noiseToken_;
  edm::ESGetToken<SiStripQuality, SiStripQualityRcd> qualityToken_;

  static const std::string RunMode1;
  static const std::string RunMode2;
  static const std::string RunMode3;
};

#endif