CMS 3D CMS Logo

CSCCLCTDigiValidation.cc
Go to the documentation of this file.
4 
8 
11  CSCBaseValidation(inputTag),
12  theTimeBinPlots(),
13  theNDigisPerLayerPlots()
14 {
16 }
17 
19 {
20 }
21 
23 {
24  theNDigisPerEventPlot = iBooker.book1D("CSCCLCTDigisPerEvent", "CSC CLCT Digis per event", 100, 0, 100);
25  for(int i = 0; i < 10; ++i)
26  {
27  char title1[200], title2[200];
28  sprintf(title1, "CSCCLCTDigiTimeType%d", i+1);
29  sprintf(title2, "CSCCLCTDigisPerLayerType%d", i+1);
30  theTimeBinPlots[i] = iBooker.book1D(title1, title1, 20, 0, 20);
31  theNDigisPerLayerPlots[i] = iBooker.book1D(title2, title2, 100, 0, 20);
32  }
33 }
34 
36 {
38 
39  e.getByToken(clcts_Token_, clcts);
40  if (!clcts.isValid()) {
41  edm::LogError("CSCDigiDump") << "Cannot get clcts by label " << theInputTag.encode();
42  }
43 
44  unsigned nDigisPerEvent = 0;
45 
46  for (CSCCLCTDigiCollection::DigiRangeIterator j=clcts->begin(); j!=clcts->end(); j++) {
47  std::vector<CSCCLCTDigi>::const_iterator beginDigi = (*j).second.first;
48  std::vector<CSCCLCTDigi>::const_iterator endDigi = (*j).second.second;
49  CSCDetId detId((*j).first.rawId());
50  int chamberType = detId.iChamberType();
51 
52  int nDigis = endDigi-beginDigi;
53  nDigisPerEvent += nDigis;
54  theNDigisPerLayerPlots[chamberType-1]->Fill(nDigis);
55 
56  for( std::vector<CSCCLCTDigi>::const_iterator digiItr = beginDigi;
57  digiItr != endDigi; ++digiItr)
58  {
59  theTimeBinPlots[chamberType-1]->Fill(digiItr->getBX());
60  }
61 
62  }
63 }
edm::InputTag theInputTag
MonitorElement * theNDigisPerLayerPlots[10]
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:579
MonitorElement * theTimeBinPlots[10]
std::string encode() const
Definition: InputTag.cc:166
void Fill(long long x)
MonitorElement * book1D(Args &&...args)
Definition: DQMStore.h:118
unsigned short iChamberType() const
Definition: CSCDetId.h:107
void analyze(const edm::Event &, const edm::EventSetup &) override
bool isValid() const
Definition: HandleBase.h:74
void bookHistograms(DQMStore::IBooker &)
MonitorElement * theNDigisPerEventPlot
CSCCLCTDigiValidation(const edm::InputTag &inputTag, edm::ConsumesCollector &&iC)
edm::EDGetTokenT< CSCCLCTDigiCollection > clcts_Token_