CMS 3D CMS Logo

CSCALCTDigiValidation.cc
Go to the documentation of this file.
4 
8 
10  : CSCBaseValidation(inputTag), theTimeBinPlots(), theNDigisPerLayerPlots() {
12 }
13 
15 
17  theNDigisPerEventPlot = iBooker.book1D("CSCALCTDigisPerEvent", "CSC ALCT Digis per event", 100, 0, 100);
18  for (int i = 0; i < 10; ++i) {
19  char title1[200], title2[200];
20  sprintf(title1, "CSCALCTDigiTimeType%d", i + 1);
21  sprintf(title2, "CSCALCTDigisPerLayerType%d", i + 1);
22  theTimeBinPlots[i] = iBooker.book1D(title1, title1, 20, 0, 20);
23  theNDigisPerLayerPlots[i] = iBooker.book1D(title2, title2, 100, 0, 20);
24  }
25 }
26 
29 
30  e.getByToken(alcts_Token_, alcts);
31  if (!alcts.isValid()) {
32  edm::LogError("CSCDigiDump") << "Cannot get alcts by label " << theInputTag.encode();
33  }
34  unsigned nDigisPerEvent = 0;
35 
36  for (CSCALCTDigiCollection::DigiRangeIterator j = alcts->begin(); j != alcts->end(); j++) {
37  std::vector<CSCALCTDigi>::const_iterator beginDigi = (*j).second.first;
38  std::vector<CSCALCTDigi>::const_iterator endDigi = (*j).second.second;
39  CSCDetId detId((*j).first.rawId());
40  int chamberType = detId.iChamberType();
41  int nDigis = endDigi - beginDigi;
42  nDigisPerEvent += nDigis;
43  theNDigisPerLayerPlots[chamberType - 1]->Fill(nDigis);
44 
45  for (std::vector<CSCALCTDigi>::const_iterator digiItr = beginDigi; digiItr != endDigi; ++digiItr) {
46  theTimeBinPlots[chamberType - 1]->Fill(digiItr->getBX());
47  }
48  }
49 }
edm::InputTag theInputTag
MonitorElement * theTimeBinPlots[10]
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:517
void bookHistograms(DQMStore::IBooker &)
CSCALCTDigiValidation(const edm::InputTag &inputTag, edm::ConsumesCollector &&iC)
std::string encode() const
Definition: InputTag.cc:159
void Fill(long long x)
edm::EDGetTokenT< CSCALCTDigiCollection > alcts_Token_
MonitorElement * book1D(Args &&...args)
Definition: DQMStore.h:106
unsigned short iChamberType() const
Definition: CSCDetId.h:107
void analyze(const edm::Event &, const edm::EventSetup &) override
bool isValid() const
Definition: HandleBase.h:74
MonitorElement * theNDigisPerLayerPlots[10]
MonitorElement * theNDigisPerEventPlot