CMS 3D CMS Logo

CSCCLCTDigiValidation.cc
Go to the documentation of this file.
4 
8 
10  : CSCBaseValidation(inputTag), theTimeBinPlots(), theNDigisPerLayerPlots() {
12 }
13 
15 
17  theNDigisPerEventPlot = iBooker.book1D("CSCCLCTDigisPerEvent", "CSC CLCT Digis per event", 100, 0, 100);
18  for (int i = 0; i < 10; ++i) {
19  char title1[200], title2[200];
20  sprintf(title1, "CSCCLCTDigiTimeType%d", i + 1);
21  sprintf(title2, "CSCCLCTDigisPerLayerType%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(clcts_Token_, clcts);
31  if (!clcts.isValid()) {
32  edm::LogError("CSCDigiDump") << "Cannot get clcts by label " << theInputTag.encode();
33  }
34 
35  unsigned nDigisPerEvent = 0;
36 
37  for (CSCCLCTDigiCollection::DigiRangeIterator j = clcts->begin(); j != clcts->end(); j++) {
38  std::vector<CSCCLCTDigi>::const_iterator beginDigi = (*j).second.first;
39  std::vector<CSCCLCTDigi>::const_iterator endDigi = (*j).second.second;
40  CSCDetId detId((*j).first.rawId());
41  int chamberType = detId.iChamberType();
42 
43  int nDigis = endDigi - beginDigi;
44  nDigisPerEvent += nDigis;
45  theNDigisPerLayerPlots[chamberType - 1]->Fill(nDigis);
46 
47  for (std::vector<CSCCLCTDigi>::const_iterator digiItr = beginDigi; digiItr != endDigi; ++digiItr) {
48  theTimeBinPlots[chamberType - 1]->Fill(digiItr->getBX());
49  }
50  }
51 }
Handle.h
mps_fire.i
i
Definition: mps_fire.py:355
MessageLogger.h
CSCCLCTDigiValidation::bookHistograms
void bookHistograms(DQMStore::IBooker &)
Definition: CSCCLCTDigiValidation.cc:16
CSCCLCTDigiValidation::~CSCCLCTDigiValidation
~CSCCLCTDigiValidation() override
Definition: CSCCLCTDigiValidation.cc:14
CSCCLCTDigiValidation::CSCCLCTDigiValidation
CSCCLCTDigiValidation(const edm::InputTag &inputTag, edm::ConsumesCollector &&iC)
Definition: CSCCLCTDigiValidation.cc:9
CSCBaseValidation::theInputTag
edm::InputTag theInputTag
Definition: CSCBaseValidation.h:28
DQMStore.h
CSCCLCTDigiValidation::analyze
void analyze(const edm::Event &, const edm::EventSetup &) override
Definition: CSCCLCTDigiValidation.cc:27
edm::Handle< CSCCLCTDigiCollection >
CSCDetId::iChamberType
unsigned short iChamberType() const
Definition: CSCDetId.h:96
CSCCLCTDigiValidation.h
dqm::impl::MonitorElement::Fill
void Fill(long long x)
Definition: MonitorElement.h:290
CSCLayerGeometry.h
CSCCLCTDigiValidation::theNDigisPerEventPlot
MonitorElement * theNDigisPerEventPlot
Definition: CSCCLCTDigiValidation.h:23
edm::LogError
Definition: MessageLogger.h:183
CSCDetId
Definition: CSCDetId.h:26
CSCCLCTDigiValidation::theTimeBinPlots
MonitorElement * theTimeBinPlots[10]
Definition: CSCCLCTDigiValidation.h:21
edm::InputTag::encode
std::string encode() const
Definition: InputTag.cc:159
edm::EventSetup
Definition: EventSetup.h:57
CSCCLCTDigiCollection
CSCCLCTDigiValidation::theNDigisPerLayerPlots
MonitorElement * theNDigisPerLayerPlots[10]
Definition: CSCCLCTDigiValidation.h:22
dqm::implementation::IBooker
Definition: DQMStore.h:43
CSCCLCTDigiValidation::clcts_Token_
edm::EDGetTokenT< CSCCLCTDigiCollection > clcts_Token_
Definition: CSCCLCTDigiValidation.h:19
CSCBaseValidation
Definition: CSCBaseValidation.h:15
dqmiolumiharvest.j
j
Definition: dqmiolumiharvest.py:66
SimL1EmulatorRepack_Full_cff.inputTag
inputTag
Definition: SimL1EmulatorRepack_Full_cff.py:56
edm::HandleBase::isValid
bool isValid() const
Definition: HandleBase.h:70
DigiContainerIterator
Definition: MuonDigiCollection.h:30
edm::Event
Definition: Event.h:73
edm::InputTag
Definition: InputTag.h:15
edm::ConsumesCollector
Definition: ConsumesCollector.h:39
dqm::implementation::IBooker::book1D
MonitorElement * book1D(TString const &name, TString const &title, int const nchX, double const lowX, double const highX, FUNC onbooking=NOOP())
Definition: DQMStore.h:98
CSCGeometry.h
MillePedeFileConverter_cfg.e
e
Definition: MillePedeFileConverter_cfg.py:37