CMS 3D CMS Logo

RPCMonitorLinkSynchro.cc
Go to the documentation of this file.
1 #include <memory>
2 
5 
7 
12 
15 
17  : theConfig(cfg),
18  theSynchroStat(RPCLinkSynchroStat(theConfig.getUntrackedParameter<bool>("useFirstHitOnly", false)))
19 
20 {
22  consumes<RPCRawSynchro::ProdItem>(cfg.getParameter<edm::InputTag>("rpcRawSynchroProdItemTag"));
23 }
24 
26 
30 }
31 
33  if (theCablingWatcher.check(es)) {
34  edm::ESTransientHandle<RPCEMap> readoutMapping;
35  es.get<RPCEMapRcd>().get(readoutMapping);
36  std::unique_ptr<RPCReadOutMapping const> cabling{readoutMapping->convert()};
37  edm::LogInfo("RPCMonitorLinkSynchro")
38  << "RPCMonitorLinkSynchro - record has CHANGED!!, read map, VERSION: " << cabling->version();
39  theSynchroStat.init(cabling.get(), theConfig.getUntrackedParameter<bool>("dumpDelays"));
40  }
41 }
42 
44  edm::Run const& iRun,
45  edm::EventSetup const& es) {
46  ibooker.cd();
47  ibooker.setCurrentFolder("RPC/LinkMonitor/");
48 
49  me_delaySummary = ibooker.book1D("delaySummary", "LinkDelaySummary", 8, -3.5, 4.5);
50  me_delaySummary->getTH1F()->SetStats(true);
51 
52  me_delaySpread = ibooker.book2D("delaySpread", "LinkDelaySpread", 71, -3.05, 4.05, 31, -0.05, 3.05);
53  me_delaySpread->getTH2F()->SetStats(false);
54 
55  me_notComplete[0] = ibooker.book2D("notComplete790", "FED790: not All Paths hit", 36, -0.5, 35.5, 18, -0.5, 17.5);
56  me_notComplete[1] = ibooker.book2D("notComplete791", "FED791: not All Paths hit", 36, -0.5, 35.5, 18, -0.5, 17.5);
57  me_notComplete[2] = ibooker.book2D("notComplete792", "FED792: not All Paths hit", 36, -0.5, 35.5, 18, -0.5, 17.5);
58  for (unsigned int i = 0; i < 3; ++i) {
59  me_notComplete[i]->getTH2F()->GetXaxis()->SetNdivisions(512);
60  me_notComplete[i]->getTH2F()->GetYaxis()->SetNdivisions(505);
61  me_notComplete[i]->setAxisTitle("rmb");
62  me_notComplete[i]->getTH2F()->SetYTitle("link");
63  me_notComplete[i]->getTH2F()->SetStats(false);
64  }
65  me_topOccup = ibooker.book2D("topOccup", "Top10 LinkBoard occupancy", 8, -0.5, 7.5, 10, 0., 10.);
66  me_topSpread = ibooker.book2D("topSpread", "Top10 LinkBoard delay spread", 8, -0.5, 7.5, 10, 0., 10.);
67  me_topOccup->getTH2F()->GetXaxis()->SetNdivisions(110);
68  me_topSpread->getTH2F()->GetXaxis()->SetNdivisions(110);
69  me_topOccup->getTH2F()->SetStats(false);
70  me_topSpread->getTH2F()->SetStats(false);
71 }
72 
75  ev.getByToken(rpcRawSynchroProdItemTag_, synchroCounts);
76  std::vector<LinkBoardElectronicIndex> problems;
77  const RPCRawSynchro::ProdItem& vItem = select(*synchroCounts.product(), ev, es);
78  theSynchroStat.add(vItem, problems);
79 
80  for (std::vector<LinkBoardElectronicIndex>::const_iterator it = problems.begin(); it != problems.end(); ++it) {
81  me_notComplete[it->dccId - 790]->Fill(it->dccInputChannelNum, it->tbLinkInputNum);
82  }
83 }
MonitorElement * book1D(TString const &name, TString const &title, int const nchX, double const lowX, double const highX)
Definition: DQMStore.cc:239
T getParameter(std::string const &) const
T getUntrackedParameter(std::string const &, T const &) const
void init(const RPCReadOutMapping *theCabling, bool addChamberInfo)
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:525
void setCurrentFolder(std::string const &fullpath)
Definition: DQMStore.cc:418
MonitorElement * me_topOccup
bool ev
void analyze(const edm::Event &, const edm::EventSetup &) override
RPCMonitorLinkSynchro(const edm::ParameterSet &cfg)
MonitorElement * me_topSpread
void bookHistograms(DQMStore::IBooker &, edm::Run const &, edm::EventSetup const &) override
RPCLinkSynchroStat theSynchroStat
virtual const RPCRawSynchro::ProdItem & select(const RPCRawSynchro::ProdItem &v, const edm::Event &, const edm::EventSetup &)
void Fill(long long x)
MonitorElement * me_delaySpread
edm::ESWatcher< RPCEMapRcd > theCablingWatcher
std::vector< std::pair< LinkBoardElectronicIndex, int > > ProdItem
Definition: RPCRawSynchro.h:9
edm::EDGetTokenT< RPCRawSynchro::ProdItem > rpcRawSynchroProdItemTag_
void dqmBeginRun(const edm::Run &r, const edm::EventSetup &c) override
MonitorElement * me_notComplete[3]
void add(const RPCRawSynchro::ProdItem &counts, std::vector< LinkBoardElectronicIndex > &problems)
def ls(path, rec=False)
Definition: eostools.py:349
T const * product() const
Definition: Handle.h:69
edm::ParameterSet theConfig
bool check(const edm::EventSetup &iSetup)
Definition: ESWatcher.h:52
void fill(TH1F *hDelay, TH2F *hDelaySpread, TH2F *hTopOccup, TH2F *hTopSpread) const
MonitorElement * book2D(TString const &name, TString const &title, int nchX, double lowX, double highX, int nchY, double lowY, double highY)
Definition: DQMStore.cc:266
T get() const
Definition: EventSetup.h:73
RPCReadOutMapping const * convert() const
Definition: RPCEMap.h:64
MonitorElement * me_delaySummary
Definition: Run.h:45
void endLuminosityBlock(const edm::LuminosityBlock &, const edm::EventSetup &) override
virtual void setAxisTitle(const std::string &title, int axis=1)
set x-, y- or z-axis title (axis=1, 2, 3 respectively)