RPCMonitorDigi

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
#ifndef RPCMonitorDigi_h
#define RPCMonitorDigi_h

#include "DQMServices/Core/interface/DQMEDAnalyzer.h"
#include "DQMServices/Core/interface/DQMStore.h"
#include "FWCore/Framework/interface/Event.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"

#include "Geometry/RPCGeometry/interface/RPCGeometry.h"
#include "Geometry/Records/interface/MuonGeometryRecord.h"
#include "DataFormats/Scalers/interface/DcsStatus.h"
#include "DataFormats/MuonDetId/interface/RPCDetId.h"
#include "DataFormats/RPCRecHit/interface/RPCRecHitCollection.h"
#include "DataFormats/MuonReco/interface/Muon.h"

#include <string>
#include <array>
#include <map>

class RPCMonitorDigi : public DQMEDAnalyzer {
public:
  explicit RPCMonitorDigi(const edm::ParameterSet &);
  ~RPCMonitorDigi() override = default;

protected:
  void analyze(const edm::Event &, const edm::EventSetup &) override;
  void bookHistograms(DQMStore::IBooker &, edm::Run const &, edm::EventSetup const &) override;
  /// Booking of MonitoringElement for one RPCDetId (= roll)
  void bookRollME(DQMStore::IBooker &,
                  const RPCDetId &,
                  const RPCGeometry *rpcGeo,
                  const std::string &,
                  std::map<std::string, MonitorElement *> &);
  /// Booking of MonitoringElement at Sector/Ring level
  void bookSectorRingME(DQMStore::IBooker &, const std::string &, std::map<std::string, MonitorElement *> &);
  /// Booking of MonitoringElemnt at Wheel/Disk level
  void bookWheelDiskME(DQMStore::IBooker &, const std::string &, std::map<std::string, MonitorElement *> &);
  /// Booking of MonitoringElemnt at region (Barrel/Endcap) level
  void bookRegionME(DQMStore::IBooker &, const std::string &, std::map<std::string, MonitorElement *> &);

private:
  bool useMuonDigis_;

  void performSourceOperation(std::map<RPCDetId, std::vector<RPCRecHit> > &, std::string);
  int stripsInRoll(const RPCDetId &id, const RPCGeometry *rpcGeo) const;

  static const std::array<std::string, 3> regionNames_;
  std::string muonFolder_;
  std::string noiseFolder_;
  int counter;

  float muPtCut_, muEtaCut_;
  bool useRollInfo_;
  MonitorElement *noiseRPCEvents_;
  MonitorElement *muonRPCEvents_;

  MonitorElement *NumberOfRecHitMuon_;
  MonitorElement *NumberOfMuon_;

  int numberOfDisks_, numberOfInnerRings_;

  std::map<std::string, std::map<std::string, MonitorElement *> > meMuonCollection;
  std::map<std::string, MonitorElement *> wheelDiskMuonCollection;
  std::map<std::string, MonitorElement *> regionMuonCollection;
  std::map<std::string, MonitorElement *> sectorRingMuonCollection;

  std::map<std::string, std::map<std::string, MonitorElement *> > meNoiseCollection;
  std::map<std::string, MonitorElement *> wheelDiskNoiseCollection;
  std::map<std::string, MonitorElement *> regionNoiseCollection;
  std::map<std::string, MonitorElement *> sectorRingNoiseCollection;

  std::string globalFolder_;
  std::string subsystemFolder_;

  edm::EDGetTokenT<reco::CandidateView> muonLabel_;
  edm::EDGetTokenT<RPCRecHitCollection> rpcRecHitLabel_;
  edm::EDGetTokenT<DcsStatusCollection> scalersRawToDigiLabel_;

  edm::ESGetToken<RPCGeometry, MuonGeometryRecord> rpcGeomToken_;
};

#endif