SiPixelClusterSource

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
#ifndef SiPixelMonitorCluster_SiPixelClusterSource_h
#define SiPixelMonitorCluster_SiPixelClusterSource_h
// -*- C++ -*-
//
// Package:     SiPixelMonitorCluster
// Class  :     SiPixelClusterSource
//
/*

 Description: <one line class summary>

 Usage:
    <usage>

*/
//
// Original Author:  Vincenzo Chiochia & Andrew York
//
// Updated by: Lukas Wehrli
// for pixel offline DQM
//         Created:

#include <memory>

// user include files
#include "DQMServices/Core/interface/DQMEDAnalyzer.h"
#include "DQM/SiPixelMonitorCluster/interface/SiPixelClusterModule.h"
#include "DataFormats/SiPixelDigi/interface/PixelDigi.h"
#include "Geometry/TrackerGeometryBuilder/interface/TrackerGeometry.h"
#include "Geometry/Records/interface/TrackerDigiGeometryRecord.h"
#include "DataFormats/TrackerCommon/interface/TrackerTopology.h"
#include "Geometry/Records/interface/TrackerTopologyRcd.h"
#include <cstdint>

class SiPixelClusterSource : public DQMEDAnalyzer {
public:
  explicit SiPixelClusterSource(const edm::ParameterSet &conf);
  ~SiPixelClusterSource() override;

  typedef edmNew::DetSet<SiPixelCluster>::const_iterator ClusterIterator;

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

  virtual void buildStructure(edm::EventSetup const &);
  virtual void bookMEs(DQMStore::IBooker &, const edm::EventSetup &iSetup);

  std::string topFolderName_;

private:
  edm::ParameterSet conf_;
  edm::InputTag src_;
  edm::InputTag digisrc_;
  bool saveFile;
  bool isPIB;
  bool slowDown;
  int eventNo;
  std::map<uint32_t, SiPixelClusterModule *> thePixelStructure;
  bool modOn;
  bool twoDimOn;
  bool reducedSet;
  // barrel:
  bool ladOn, layOn, phiOn;
  // forward:
  bool ringOn, bladeOn, diskOn;
  bool smileyOn;  // cluster sizeY vs Cluster eta plot
  bool firstRun;
  int lumSec;
  int nLumiSecs;
  int nBigEvents;
  MonitorElement *bigFpixClusterEventRate;
  int bigEventSize;
  bool isUpgrade;

  std::vector<MonitorElement *> meClPosLayer;
  std::vector<MonitorElement *> meClPosDiskpz;
  std::vector<MonitorElement *> meClPosDiskmz;

  MonitorElement *meClusBarrelProf;
  MonitorElement *meClusFpixPProf;
  MonitorElement *meClusFpixMProf;

  std::vector<MonitorElement *> meZeroRocBPIX;
  MonitorElement *meZeroRocFPIX;

  int noOfLayers;
  int noOfDisks;

  void getrococcupancy(DetId detId,
                       const edm::DetSetVector<PixelDigi> &diginp,
                       const TrackerTopology *const tTopo,
                       std::vector<MonitorElement *> const &meinput);
  void getrococcupancye(DetId detId,
                        const edmNew::DetSetVector<SiPixelCluster> &clustColl,
                        const TrackerTopology *const pTT,
                        edm::ESHandle<TrackerGeometry> pDD,
                        MonitorElement *meinput);

  // define Token(-s)
  edm::EDGetTokenT<edmNew::DetSetVector<SiPixelCluster>> srcToken_;
  edm::EDGetTokenT<edm::DetSetVector<PixelDigi>> digisrcToken_;

  edm::ESGetToken<TrackerTopology, TrackerTopologyRcd> trackerTopoToken_;
  edm::ESGetToken<TrackerGeometry, TrackerDigiGeometryRecord> trackerGeomToken_;
  edm::ESGetToken<TrackerTopology, TrackerTopologyRcd> trackerTopoTokenBeginRun_;
  edm::ESGetToken<TrackerGeometry, TrackerDigiGeometryRecord> trackerGeomTokenBeginRun_;
};

#endif