CMS 3D CMS Logo

List of all members | Public Member Functions | Private Attributes
SiPixelDataQuality Class Reference

#include <SiPixelDataQuality.h>

Public Member Functions

void bookGlobalQualityFlag (DQMStore::IBooker &iBooker, bool Tier0Flag, int nFEDs)
 
void computeGlobalQualityFlag (DQMStore::IBooker &iBooker, DQMStore::IGetter &iGetter, bool init, int nFEDs, bool Tier0Flag)
 
void computeGlobalQualityFlagByLumi (DQMStore::IGetter &iGetter, bool init, int nFEDs, bool Tier0Flag, int nEvents_lastLS_, int nErrorsBarrel_lastLS_, int nErrorsEndcap_lastLS_)
 
void fillGlobalQualityPlot (DQMStore::IBooker &iBooker, DQMStore::IGetter &iGetter, bool init, edm::ESHandle< SiPixelFedCablingMap > theCablingMap, int nFEDs, bool Tier0Flag, int lumisec)
 
int getDetId (MonitorElement *mE)
 (Documentation under construction). More...
 
 SiPixelDataQuality (bool offlineXMLfile)
 Constructor of the SiPixelInformationExtractor class. More...
 
 ~SiPixelDataQuality ()
 Destructor of the SiPixelDataQuality class. More...
 

Private Attributes

int allMods_
 
TH2F * allmodsMap
 
TH1D * allmodsVec
 
float barrel_error_flag_
 
int barrelMods_
 
MonitorElementClusterChargeBarrel
 
MonitorElementClusterChargeEndcap
 
int clusterCounterBarrel
 
int clusterCounterEndcap
 
MonitorElementClusterMod1
 
MonitorElementClusterMod2
 
MonitorElementClusterMod3
 
MonitorElementClusterMod4
 
MonitorElementClusterModAll
 
MonitorElementClusterSizeBarrel
 
MonitorElementClusterSizeEndcap
 
bool clusterStatsBarrel
 
bool clusterStatsEndcap
 
int count
 
int count1
 
int count2
 
int count3
 
int count4
 
int count5
 
int count6
 
MonitorElementDigiChargeBarrel
 
MonitorElementDigiChargeEndcap
 
int digiCounterBarrel
 
int digiCounterEndcap
 
bool digiStatsBarrel
 
bool digiStatsEndcap
 
bool DONE_
 
float endcap_error_flag_
 
int endcapMods_
 
bool endOfModules_
 
int errcount
 
TH2F * errmodsMap
 
TH1D * errmodsVec
 
int errorMods_
 
MonitorElementFEDErrReportMap
 
TH2F * goodmodsMap
 
TH1D * goodmodsVec
 
bool gotDigis
 
float lastallmods_ [40]
 
float lasterrmods_ [40]
 
int lastLS_
 
int modCounter_
 
std::ofstream myfile_
 
int n_errors_barrel_
 
int n_errors_endcap_
 
int n_errors_pixel_
 
MonitorElementNClustersBarrel
 
MonitorElementNClustersEndcap
 
MonitorElementNDigisBarrel
 
MonitorElementNDigisEndcap
 
MonitorElementNErrorsBarrel
 
MonitorElementNErrorsEndcap
 
MonitorElementNErrorsFEDs
 
int nevents_
 
MonitorElementNPixelTracks
 
int objectCount_
 
bool offlineXMLfile_
 
float pixel_error_flag_
 
float qflag_
 
MonitorElementSummaryBarrel
 
MonitorElementSummaryEndcap
 
MonitorElementSummaryPixel
 
MonitorElementSummaryReportMap
 
edm::ESHandle< SiPixelFedCablingMaptheCablingMap
 
int timeoutCounter_
 
int trackCounterBarrel
 
int trackCounterEndcap
 
bool trackStatsBarrel
 
bool trackStatsEndcap
 

Detailed Description

Definition at line 39 of file SiPixelDataQuality.h.

Constructor & Destructor Documentation

SiPixelDataQuality::SiPixelDataQuality ( bool  offlineXMLfile)

Constructor of the SiPixelInformationExtractor class.

Definition at line 67 of file SiPixelDataQuality.cc.

References allMods_, allmodsMap, allmodsVec, errmodsMap, errmodsVec, errorMods_, goodmodsMap, goodmodsVec, mps_fire::i, lastallmods_, lasterrmods_, lastLS_, qflag_, and timeoutCounter_.

67  : offlineXMLfile_(offlineXMLfile) {
68  edm::LogInfo("SiPixelDataQuality") <<
69  " Creating SiPixelDataQuality " << "\n" ;
70 
71  allMods_=0;
72  errorMods_=0;
73  qflag_=1.;
74 
75  allmodsMap=nullptr;
76  errmodsMap=nullptr;
77  goodmodsMap=nullptr;
78  allmodsVec=nullptr;
79  errmodsVec=nullptr;
80  goodmodsVec=nullptr;
81  for (int i = 0; i < 40; ++i)
82  {lastallmods_[i] = 0; lasterrmods_[i] = 0;}
84  lastLS_=-1;
85 }
SiPixelDataQuality::~SiPixelDataQuality ( )

Destructor of the SiPixelDataQuality class.

Definition at line 91 of file SiPixelDataQuality.cc.

References allmodsMap, allmodsVec, errmodsMap, errmodsVec, goodmodsMap, and goodmodsVec.

91  {
92  edm::LogInfo("SiPixelDataQuality") <<
93  " Deleting SiPixelDataQuality " << "\n" ;
94  if(allmodsMap) delete allmodsMap;
95  if(errmodsMap) delete errmodsMap;
96  if(goodmodsMap) delete goodmodsMap;
97  if(allmodsVec) delete allmodsVec;
98  if(errmodsVec) delete errmodsVec;
99  if(goodmodsVec) delete goodmodsVec;
100 }

Member Function Documentation

void SiPixelDataQuality::bookGlobalQualityFlag ( DQMStore::IBooker iBooker,
bool  Tier0Flag,
int  nFEDs 
)

Definition at line 128 of file SiPixelDataQuality.cc.

References allmodsMap, allmodsVec, DQMStore::IBooker::book1D(), DQMStore::IBooker::book2D(), DQMStore::IBooker::bookFloat(), DQMStore::IBooker::bookInt(), DQMStore::IBooker::cd(), ClusterChargeBarrel, ClusterChargeEndcap, ClusterMod1, ClusterMod2, ClusterMod3, ClusterMod4, ClusterModAll, ClusterSizeBarrel, ClusterSizeEndcap, DigiChargeBarrel, DigiChargeEndcap, errmodsMap, errmodsVec, MonitorElement::Fill(), goodmodsMap, goodmodsVec, mps_fire::i, NClustersBarrel, NClustersEndcap, NDigisBarrel, NDigisEndcap, NErrorsBarrel, NErrorsEndcap, NErrorsFEDs, NPixelTracks, MonitorElement::setAxisTitle(), MonitorElement::setBinContent(), MonitorElement::setBinLabel(), DQMStore::IBooker::setCurrentFolder(), SummaryBarrel, SummaryEndcap, SummaryPixel, and SummaryReportMap.

128  {
129 //std::cout<<"BOOK GLOBAL QUALITY FLAG MEs!"<<std::endl;
130  iBooker.cd();
131 
132  iBooker.setCurrentFolder("Pixel/Barrel");
133  if(!Tier0Flag){
134  ClusterModAll = iBooker.book1D("NClustertoChargeRatio_AllMod","Cluster Noise All Modules", 768, 0., 768.);
135  ClusterMod1 = iBooker.book1D("NClustertoChargeRatio_NormMod1", "Normalized N_{Clusters} to Charge Ratio per Module1", 192, 0., 192.);
136  ClusterMod2 = iBooker.book1D("NClustertoChargeRatio_NormMod2", "Normalized N_{Clusters} to Charge Ratio per Module2", 192, 0., 192.);
137  ClusterMod3 = iBooker.book1D("NClustertoChargeRatio_NormMod3", "Normalized N_{Clusters} to Charge Ratio per Module3", 192, 0., 192.);
138  ClusterMod4 = iBooker.book1D("NClustertoChargeRatio_NormMod4", "Normalized N_{Clusters} to Charge Ratio per Module4", 192, 0., 192.);
139  }
140  iBooker.setCurrentFolder("Pixel/EventInfo");
141  if(!Tier0Flag){
142  SummaryReportMap = iBooker.book2D("reportSummaryMap","Pixel Summary Map",3000,0.,3000.,40,0.,40.);
143  SummaryReportMap->setAxisTitle("Lumi Section",1);
144  SummaryReportMap->setAxisTitle("Pixel FED #",2);
145  allmodsVec = new TH1D("allmodsVec","allmodsVec",40,0.,40.);
146  errmodsVec = new TH1D("errmodsVec","errmodsVec",40,0.,40.);
147  goodmodsVec = new TH1D("goodmodsVec","goodmodsVec",40,0.,40.);
148  }else{
149  SummaryReportMap = iBooker.book2D("reportSummaryMap","Pixel Summary Map",2,0.,2.,7,0.,7.);
150  SummaryReportMap->setBinLabel(1,"Barrel",1);
151  SummaryReportMap->setBinLabel(2,"Endcaps",1);
152  SummaryReportMap->setBinLabel(1,"Errors",2);
153  SummaryReportMap->setBinLabel(2,"NDigis",2);
154  SummaryReportMap->setBinLabel(3,"DigiCharge",2);
155  SummaryReportMap->setBinLabel(4,"ClusterSize",2);
156  SummaryReportMap->setBinLabel(5,"NClusters",2);
157  SummaryReportMap->setBinLabel(6,"ClusterCharge",2);
158  SummaryReportMap->setBinLabel(7,"HitEff",2);
159  allmodsMap = new TH2F("allmodsMap","allmodsMap",2,0.,2.,7,0.,7.);
160  errmodsMap = new TH2F("errmodsMap","errmodsMap",2,0.,2.,7,0.,7.);
161  goodmodsMap = new TH2F("goodmodsMap","goodmodsMap",2,0.,2.,7,0.,7.);
162  }
163  SummaryPixel = iBooker.bookFloat("reportSummary");
164  iBooker.setCurrentFolder("Pixel/EventInfo/reportSummaryContents");
165  SummaryBarrel = iBooker.bookFloat("PixelBarrelFraction");
166  SummaryEndcap = iBooker.bookFloat("PixelEndcapFraction");
167  // book the data certification cuts:
168  iBooker.setCurrentFolder("Pixel/AdditionalPixelErrors");
169  NErrorsFEDs = iBooker.bookFloat("FEDsNErrorsCut");
170  iBooker.setCurrentFolder("Pixel/Barrel");
171  NErrorsBarrel = iBooker.bookFloat("BarrelNErrorsCut");
172  NDigisBarrel = iBooker.bookInt("BarrelNDigisCut");
173  DigiChargeBarrel = iBooker.bookInt("BarrelDigiChargeCut");
174  ClusterSizeBarrel = iBooker.bookInt("BarrelClusterSizeCut");
175  NClustersBarrel = iBooker.bookInt("BarrelNClustersCut");
176  ClusterChargeBarrel = iBooker.bookInt("BarrelClusterChargeCut");
177  iBooker.setCurrentFolder("Pixel/Endcap");
178  NErrorsEndcap = iBooker.bookFloat("EndcapNErrorsCut");
179  NDigisEndcap = iBooker.bookInt("EndcapNDigisCut");
180  DigiChargeEndcap = iBooker.bookInt("EndcapDigiChargeCut");
181  ClusterSizeEndcap = iBooker.bookInt("EndcapClusterSizeCut");
182  NClustersEndcap = iBooker.bookInt("EndcapNClustersCut");
183  ClusterChargeEndcap = iBooker.bookInt("EndcapClusterChargeCut");
184  if(Tier0Flag){
185  iBooker.setCurrentFolder("Pixel/Tracks");
186  NPixelTracks = iBooker.bookInt("PixelTracksCut");
187  }
188 
189  // Init MonitoringElements:
190  if(nFEDs>0){
191  if(SummaryPixel) SummaryPixel->Fill(1.);
194  }else{
195  if(SummaryPixel) SummaryPixel->Fill(-1.);
196  if(SummaryBarrel) SummaryBarrel->Fill(-1.);
197  if(SummaryEndcap) SummaryEndcap->Fill(-1.);
198  }
201  if(NErrorsFEDs) NErrorsFEDs->Fill(1.);
212  if(Tier0Flag){
214  }
215 
216  if(SummaryReportMap){
217  if(!Tier0Flag) for(int i=1; i!=3001; i++) for(int j=1; j!=41; j++) SummaryReportMap->setBinContent(i,j,-1.);
218  if(Tier0Flag) for(int i=1; i!=3; i++) for(int j=1; j!=8; j++) SummaryReportMap->setBinContent(i,j,-1.);
219  }
220  if(!Tier0Flag){
221  for(int j=1; j!=41; j++){
222  if(allmodsVec) allmodsVec->SetBinContent(j,0.);
223  if(errmodsVec) errmodsVec->SetBinContent(j,0.);
224  if(goodmodsVec) goodmodsVec->SetBinContent(j,0.);
225  }
226  }
227  if(Tier0Flag){
228  for(int i=1; i!=3; i++) for(int j=1; j!=8; j++){
229  if(allmodsMap) allmodsMap->SetBinContent(i,j,0.);
230  if(errmodsMap) errmodsMap->SetBinContent(i,j,0.);
231  if(goodmodsMap) goodmodsMap->SetBinContent(i,j,0.);
232  }
233  }
234 
235  iBooker.cd();
236 }
void setBinContent(int binx, double content)
set content of bin (1-D)
MonitorElement * ClusterChargeBarrel
MonitorElement * ClusterModAll
MonitorElement * bookInt(Args &&...args)
Definition: DQMStore.h:106
void setBinLabel(int bin, const std::string &label, int axis=1)
set bin label for x, y or z axis (axis=1, 2, 3 respectively)
MonitorElement * SummaryBarrel
MonitorElement * ClusterSizeEndcap
MonitorElement * NPixelTracks
MonitorElement * NErrorsFEDs
void Fill(long long x)
MonitorElement * NDigisEndcap
MonitorElement * SummaryPixel
MonitorElement * NErrorsEndcap
MonitorElement * ClusterMod3
MonitorElement * ClusterMod1
MonitorElement * ClusterMod4
MonitorElement * NErrorsBarrel
MonitorElement * book1D(Args &&...args)
Definition: DQMStore.h:118
MonitorElement * ClusterMod2
MonitorElement * NClustersEndcap
MonitorElement * ClusterSizeBarrel
MonitorElement * SummaryReportMap
void setCurrentFolder(const std::string &fullpath)
Definition: DQMStore.cc:279
MonitorElement * book2D(Args &&...args)
Definition: DQMStore.h:136
MonitorElement * DigiChargeEndcap
MonitorElement * SummaryEndcap
MonitorElement * NDigisBarrel
MonitorElement * bookFloat(Args &&...args)
Definition: DQMStore.h:112
MonitorElement * ClusterChargeEndcap
MonitorElement * DigiChargeBarrel
void setAxisTitle(const std::string &title, int axis=1)
set x-, y- or z-axis title (axis=1, 2, 3 respectively)
MonitorElement * NClustersBarrel
void SiPixelDataQuality::computeGlobalQualityFlag ( DQMStore::IBooker iBooker,
DQMStore::IGetter iGetter,
bool  init,
int  nFEDs,
bool  Tier0Flag 
)

Definition at line 240 of file SiPixelDataQuality.cc.

References allMods_, barrel_error_flag_, barrelMods_, DQMStore::IBooker::cd(), DQMStore::IGetter::cd(), ClusterChargeBarrel, ClusterChargeEndcap, clusterCounterBarrel, clusterCounterEndcap, ClusterSizeBarrel, ClusterSizeEndcap, clusterStatsBarrel, clusterStatsEndcap, pfDeepCMVADiscriminatorsJetTags_cfi::denominator, DigiChargeBarrel, DigiChargeEndcap, digiCounterBarrel, digiCounterEndcap, digiStatsBarrel, digiStatsEndcap, RefreshWebPage::dname, DONE_, endcap_error_flag_, endcapMods_, errorMods_, MonitorElement::Fill(), objects.autophobj::float, DQMStore::IGetter::get(), MonitorElement::getBinContent(), MonitorElement::getEntries(), MonitorElement::getFloatValue(), MonitorElement::getIntValue(), DQMStore::IGetter::getMEs(), DQMStore::IGetter::getSubdirs(), DQMStore::IBooker::goUp(), MonitorElement::hasError(), mps_fire::i, createfilelist::int, gen::k, n_errors_barrel_, n_errors_endcap_, n_errors_pixel_, NClustersBarrel, NClustersEndcap, NDigisBarrel, NDigisEndcap, NErrorsBarrel, NErrorsEndcap, NPixelTracks, pfDeepCMVADiscriminatorsJetTags_cfi::numerator, objectCount_, pixel_error_flag_, DQMStore::IBooker::pwd(), qflag_, DQMStore::IGetter::setCurrentFolder(), SummaryBarrel, SummaryEndcap, SummaryPixel, trackCounterBarrel, trackCounterEndcap, trackStatsBarrel, and trackStatsEndcap.

244  {
245  if(init){
246  allMods_=0; errorMods_=0; qflag_=0.;
248  objectCount_=0;
249  DONE_ = false;
250 
251  //Error counters and flags:
255  digiStatsBarrel = false, clusterStatsBarrel = false, trackStatsBarrel = false;
257  digiStatsEndcap = false, clusterStatsEndcap = false, trackStatsEndcap = false;
259  init=false;
260  }
261  if(nFEDs==0) return;
262 
263  string currDir = iBooker.pwd();
264  string dname = currDir.substr(currDir.find_last_of("/")+1);
265 
266  if((!Tier0Flag && dname.find("Module_")!=string::npos) ||
267  (Tier0Flag && (dname.find("Ladder_")!=string::npos || dname.find("Blade_")!=string::npos))){
268 
269  objectCount_++;
270 
271  if(currDir.find("Pixel")!=string::npos) allMods_++;
272  if(currDir.find("Barrel")!=string::npos) barrelMods_++;
273  if(currDir.find("Endcap")!=string::npos) endcapMods_++;
274  vector<string> meVec = iGetter.getMEs();
275  for (vector<string>::const_iterator it = meVec.begin(); it != meVec.end(); it++) {
276  string full_path = currDir + "/" + (*it);
277  if(full_path.find("ndigis_")!=string::npos){
278  MonitorElement * me = iGetter.get(full_path);
279  if(!me) continue;
280  if(me->getEntries()>25){
281  if(full_path.find("Barrel")!=string::npos) digiCounterBarrel++;
282  if(full_path.find("Endcap")!=string::npos) digiCounterEndcap++;
283  }
284  }else if(Tier0Flag && full_path.find("nclusters_OnTrack_")!=string::npos){
285  MonitorElement * me = iGetter.get(full_path);
286  if(!me) continue;
287  if(me->getEntries()>25){
288  if(full_path.find("Barrel")!=string::npos) clusterCounterBarrel++;
289  if(full_path.find("Endcap")!=string::npos) clusterCounterEndcap++;
290  }
291  }else if(!Tier0Flag && full_path.find("nclusters_")!=string::npos){
292  MonitorElement * me = iGetter.get(full_path);
293  if(!me) continue;
294  if(me->getEntries()>25){
295  if(full_path.find("Barrel")!=string::npos) clusterCounterBarrel++;
296  if(full_path.find("Endcap")!=string::npos) clusterCounterEndcap++;
297  }
298  }
299  }
300  }
301  vector<string> subDirVec = iGetter.getSubdirs();
302  for (vector<string>::const_iterator ic = subDirVec.begin();
303  ic != subDirVec.end(); ic++) {
304  iGetter.cd(*ic);
305  iBooker.cd(*ic);
306  init=false;
307  computeGlobalQualityFlag(iBooker,iGetter,init,nFEDs,Tier0Flag);
308  iBooker.goUp();
309  iGetter.setCurrentFolder(iBooker.pwd());
310  }
311 
312  // Make sure I have finished looping over all Modules/Ladders/Blades:
313  if(!Tier0Flag){ // online case
314  if(objectCount_ == 1440) DONE_ = true;
315  }else{ // offline case
316  if(objectCount_ == 288) DONE_ = true;
317  }
318 
319  if(DONE_ && currDir=="Pixel/EventInfo/reportSummaryContents"){
320 
321  // Evaluate error flag now, only stored in AdditionalPixelErrors:
322  MonitorElement * me_err = iGetter.get("Pixel/AdditionalPixelErrors/FedETypeNErr");
323  MonitorElement * me_evt = iGetter.get("Pixel/EventInfo/processedEvents");
324  if(me_err && me_evt){
325  for(int i=1; i!=41; i++)for(int j=1; j!=22; j++)
326  if(me_err->getBinContent(i,j)>0){
330  }
331  int NProcEvts = me_evt->getIntValue();
332  if(NProcEvts>0){
333  barrel_error_flag_ = (float(NProcEvts)-float(n_errors_barrel_))/float(NProcEvts);
334  endcap_error_flag_ = (float(NProcEvts)-float(n_errors_endcap_))/float(NProcEvts);
335  pixel_error_flag_ = (float(NProcEvts)-float(n_errors_barrel_)-float(n_errors_endcap_))/float(NProcEvts);
336  }
337  }
338  NErrorsBarrel = iGetter.get("Pixel/Barrel/BarrelNErrorsCut");
340  NErrorsEndcap = iGetter.get("Pixel/Endcap/EndcapNErrorsCut");
342 
343  string meName0;
344  MonitorElement * me;
345 
346  // Fill the Digi flags:
347  if(!Tier0Flag){
348  meName0 = "Pixel/Barrel/SUMDIG_ndigis_Barrel";
349  if(digiCounterBarrel/768 > 0.5) digiStatsBarrel = true;
350  if(digiCounterEndcap/672 > 0.5) digiStatsEndcap = true;
351  }else{
352  meName0 = "Pixel/Barrel/SUMOFF_ndigis_Barrel";
353  if(digiCounterBarrel/192 > 0.5) digiStatsBarrel = true;
354  if(digiCounterEndcap/96 > 0.5) digiStatsEndcap = true;
355  }
356  me = iGetter.get(meName0);
357  if(me){
358  NDigisBarrel = iGetter.get("Pixel/Barrel/BarrelNDigisCut");
360  if(me->hasError()) NDigisBarrel->Fill(0);
361  else NDigisBarrel->Fill(1);
362  }
363  }
364  if(!Tier0Flag) meName0 = "Pixel/Endcap/SUMDIG_ndigis_Endcap";
365  else meName0 = "Pixel/Endcap/SUMOFF_ndigis_Endcap";
366  me = iGetter.get(meName0);
367  if(me){
368  NDigisEndcap = iGetter.get("Pixel/Endcap/EndcapNDigisCut");
370  if(me->hasError()) NDigisEndcap->Fill(0);
371  else NDigisEndcap->Fill(1);
372  }
373  }
374  if(!Tier0Flag) meName0 = "Pixel/Barrel/SUMDIG_adc_Barrel";
375  else meName0 = "Pixel/Barrel/SUMOFF_adc_Barrel";
376  me = iGetter.get(meName0);
377  if(me){
378  DigiChargeBarrel = iGetter.get("Pixel/Barrel/BarrelDigiChargeCut");
380  if(me->hasError()) DigiChargeBarrel->Fill(0);
381  else DigiChargeBarrel->Fill(1);
382  }
383  }
384  if(!Tier0Flag) meName0 = "Pixel/Endcap/SUMDIG_adc_Endcap";
385  else meName0 = "Pixel/Endcap/SUMOFF_adc_Endcap";
386  me = iGetter.get(meName0);
387  if(me){
388  DigiChargeEndcap = iGetter.get("Pixel/Endcap/EndcapDigiChargeCut");
390  if(me->hasError()) DigiChargeEndcap->Fill(0);
391  else DigiChargeEndcap->Fill(1);
392  }
393  }
394 
395 
396  // Fill the Cluster flags:
397  if(!Tier0Flag){
398  meName0 = "Pixel/Barrel/SUMCLU_size_Barrel";
399  if(clusterCounterBarrel/768 > 0.5) clusterStatsBarrel = true;
400  if(clusterCounterEndcap/672 > 0.5) clusterStatsEndcap = true;
401  }else{
402  meName0 = "Pixel/Barrel/SUMOFF_size_OnTrack_Barrel";
403  if(clusterCounterBarrel/192 > 0.5) clusterStatsBarrel = true;
404  if(clusterCounterEndcap/96 > 0.5) clusterStatsEndcap = true;
405  }
406  me = iGetter.get(meName0);
407  if(me){
408  ClusterSizeBarrel = iGetter.get("Pixel/Barrel/BarrelClusterSizeCut");
410  if(me->hasError()) ClusterSizeBarrel->Fill(0);
411  else ClusterSizeBarrel->Fill(1);
412  }
413  }
414  if(!Tier0Flag) meName0 = "Pixel/Endcap/SUMCLU_size_Endcap";
415  else meName0 = "Pixel/Endcap/SUMOFF_size_OnTrack_Endcap";
416  me = iGetter.get(meName0);
417  if(me){
418  ClusterSizeEndcap = iGetter.get("Pixel/Endcap/EndcapClusterSizeCut");
420  if(me->hasError()) ClusterSizeEndcap->Fill(0);
421  else ClusterSizeEndcap->Fill(1);
422  }
423  }
424  if(!Tier0Flag) meName0 = "Pixel/Barrel/SUMCLU_charge_Barrel";
425  else meName0 = "Pixel/Barrel/SUMOFF_charge_OnTrack_Barrel";
426  me = iGetter.get(meName0);
427  if(me){
428  ClusterChargeBarrel = iGetter.get("Pixel/Barrel/BarrelClusterChargeCut");
430  if(me->hasError()) ClusterChargeBarrel->Fill(0);
431  else ClusterChargeBarrel->Fill(1);
432  }
433  }
434  if(!Tier0Flag) meName0 = "Pixel/Endcap/SUMCLU_charge_Endcap";
435  else meName0 = "Pixel/Endcap/SUMOFF_charge_OnTrack_Endcap";
436  me = iGetter.get(meName0);
437  if(me){
438  ClusterChargeEndcap = iGetter.get("Pixel/Endcap/EndcapClusterChargeCut");
440  if(me->hasError()) ClusterChargeEndcap->Fill(0);
441  else ClusterChargeEndcap->Fill(1);
442  }
443  }
444  if(!Tier0Flag) meName0 = "Pixel/Barrel/SUMCLU_nclusters_Barrel";
445  else meName0 = "Pixel/Barrel/SUMOFF_nclusters_OnTrack_Barrel";
446  me = iGetter.get(meName0);
447  if(me){
448  NClustersBarrel = iGetter.get("Pixel/Barrel/BarrelNClustersCut");
450  if(me->hasError()) NClustersBarrel->Fill(0);
451  else NClustersBarrel->Fill(1);
452  }
453  }
454  if(!Tier0Flag) meName0 = "Pixel/Endcap/SUMCLU_nclusters_Endcap";
455  else meName0 = "Pixel/Endcap/SUMOFF_nclusters_OnTrack_Endcap";
456  me = iGetter.get(meName0);
457  if(me){
458  NClustersEndcap = iGetter.get("Pixel/Endcap/EndcapNClustersCut");
460  if(me->hasError()) NClustersEndcap->Fill(0);
461  else NClustersEndcap->Fill(1);
462  }
463  }
464  // Pixel Track multiplicity / Pixel hit efficiency
465  meName0 = "Pixel/Tracks/ntracks_generalTracks";
466  me = iGetter.get(meName0);
467  if(me){
468  NPixelTracks = iGetter.get("Pixel/Tracks/PixelTracksCut");
469  if(NPixelTracks && me->getBinContent(1)>1000){
470  if((float)me->getBinContent(2)/(float)me->getBinContent(1)<0.01){
471  NPixelTracks->Fill(0);
472  }else{
473  NPixelTracks->Fill(1);
474  }
475  }
476  }
477 
478 
479 //********************************************************************************************************
480 
481  // Final combination of all Data Quality results:
482  float pixelFlag = -1., barrelFlag = -1., endcapFlag = -1.;
483  float barrel_errors_temp[1]={-1.}; int barrel_cuts_temp[5]={5*-1};
484  float endcap_errors_temp[1]={-1.}; int endcap_cuts_temp[5]={5*-1};
485  int pixel_cuts_temp[1]={-1};
486  float combinedCuts = 1.; int numerator = 0, denominator = 0;
487 
488  // Barrel results:
489  me = iGetter.get("Pixel/Barrel/BarrelNErrorsCut");
490  if(me) barrel_errors_temp[0] = me->getFloatValue();
491  me = iGetter.get("Pixel/Barrel/BarrelNDigisCut");
492  if(me) barrel_cuts_temp[0] = me->getIntValue();
493  me = iGetter.get("Pixel/Barrel/BarrelDigiChargeCut");
494  if(me) barrel_cuts_temp[1] = me->getIntValue();
495  me = iGetter.get("Pixel/Barrel/BarrelClusterSizeCut");
496  if(me) barrel_cuts_temp[2] = me->getIntValue();
497  me = iGetter.get("Pixel/Barrel/BarrelNClustersCut");
498  if(me) barrel_cuts_temp[3] = me->getIntValue();
499  me = iGetter.get("Pixel/Barrel/BarrelClusterChargeCut");
500  if(me) barrel_cuts_temp[4] = me->getIntValue();
501  for(int k=0; k!=5; k++){
502  if(barrel_cuts_temp[k]>=0){
503  numerator = numerator + barrel_cuts_temp[k];
504  denominator++;
505  }
506  }
507  if(denominator!=0) combinedCuts = float(numerator)/float(denominator);
508  barrelFlag = barrel_errors_temp[0] * combinedCuts;
509 
510  // Endcap results:
511  combinedCuts = 1.; numerator = 0; denominator = 0;
512  me = iGetter.get("Pixel/Endcap/EndcapNErrorsCut");
513  if(me) endcap_errors_temp[0] = me->getFloatValue();
514  me = iGetter.get("Pixel/Endcap/EndcapNDigisCut");
515  if(me) endcap_cuts_temp[0] = me->getIntValue();
516  me = iGetter.get("Pixel/Endcap/EndcapDigiChargeCut");
517  if(me) endcap_cuts_temp[1] = me->getIntValue();
518  me = iGetter.get("Pixel/Endcap/EndcapClusterSizeCut");
519  if(me) endcap_cuts_temp[2] = me->getIntValue();
520  me = iGetter.get("Pixel/Endcap/EndcapNClustersCut");
521  if(me) endcap_cuts_temp[3] = me->getIntValue();
522  me = iGetter.get("Pixel/Endcap/EndcapClusterChargeCut");
523  if(me) endcap_cuts_temp[4] = me->getIntValue();
524  for(int k=0; k!=5; k++){
525  if(endcap_cuts_temp[k]>=0){
526  numerator = numerator + endcap_cuts_temp[k];
527  denominator++;
528  }
529  }
530  if(denominator!=0) combinedCuts = float(numerator)/float(denominator);
531  endcapFlag = endcap_errors_temp[0] * combinedCuts;
532 
533  // Track results:
534  combinedCuts = 1.; numerator = 0; denominator = 0;
535  me = iGetter.get("Pixel/Tracks/PixelTracksCut");
536  if(me) pixel_cuts_temp[0] = me->getIntValue();
537 
538  //Combination of all:
539  combinedCuts = 1.; numerator = 0; denominator = 0;
540  for(int k=0; k!=5; k++){
541  if(barrel_cuts_temp[k]>=0){
542  numerator = numerator + barrel_cuts_temp[k];
543  denominator++;
544  }
545  if(endcap_cuts_temp[k]>=0){
546  numerator = numerator + endcap_cuts_temp[k];
547  denominator++;
548  }
549  if(k<1 && pixel_cuts_temp[k]>=0){
550  numerator = numerator + pixel_cuts_temp[k];
551  denominator++;
552  }
553  }
554  if(denominator!=0) combinedCuts = float(numerator)/float(denominator);
555  pixelFlag = float(pixel_error_flag_) * float(combinedCuts);
556 
557 
558  SummaryPixel = iGetter.get("Pixel/EventInfo/reportSummary");
559  if(SummaryPixel) SummaryPixel->Fill(pixelFlag);
560  SummaryBarrel = iGetter.get("Pixel/EventInfo/reportSummaryContents/PixelBarrelFraction");
561  if(SummaryBarrel) SummaryBarrel->Fill(barrelFlag);
562  SummaryEndcap = iGetter.get("Pixel/EventInfo/reportSummaryContents/PixelEndcapFraction");
563  if(SummaryEndcap) SummaryEndcap->Fill(endcapFlag);
564  }
565 }
int64_t getIntValue() const
MonitorElement * ClusterChargeBarrel
double getFloatValue() const
MonitorElement * get(const std::string &path)
Definition: DQMStore.cc:307
int init
Definition: HydjetWrapper.h:67
bool hasError() const
true if at least of one of the quality tests returned an error
MonitorElement * SummaryBarrel
MonitorElement * ClusterSizeEndcap
MonitorElement * NPixelTracks
void Fill(long long x)
MonitorElement * NDigisEndcap
MonitorElement * SummaryPixel
MonitorElement * NErrorsEndcap
MonitorElement * NErrorsBarrel
MonitorElement * NClustersEndcap
MonitorElement * ClusterSizeBarrel
void computeGlobalQualityFlag(DQMStore::IBooker &iBooker, DQMStore::IGetter &iGetter, bool init, int nFEDs, bool Tier0Flag)
int k[5][pyjets_maxn]
double getEntries() const
get # of entries
MonitorElement * DigiChargeEndcap
const std::string & pwd()
Definition: DQMStore.cc:287
MonitorElement * SummaryEndcap
void setCurrentFolder(const std::string &fullpath)
Definition: DQMStore.cc:349
double getBinContent(int binx) const
get content of bin (1-D)
std::vector< std::string > getSubdirs()
Definition: DQMStore.cc:325
MonitorElement * NDigisBarrel
std::vector< std::string > getMEs()
Definition: DQMStore.cc:329
MonitorElement * ClusterChargeEndcap
MonitorElement * DigiChargeBarrel
MonitorElement * NClustersBarrel
void SiPixelDataQuality::computeGlobalQualityFlagByLumi ( DQMStore::IGetter iGetter,
bool  init,
int  nFEDs,
bool  Tier0Flag,
int  nEvents_lastLS_,
int  nErrorsBarrel_lastLS_,
int  nErrorsEndcap_lastLS_ 
)

Definition at line 569 of file SiPixelDataQuality.cc.

References MonitorElement::Fill(), DQMStore::IGetter::get(), MonitorElement::getBinContent(), MonitorElement::getMean(), mps_fire::i, SummaryBarrel, SummaryEndcap, and SummaryPixel.

575  {
576  if(nFEDs==0) return;
577 
578  // evaluate fatal FED errors for data quality:
579  float BarrelRate_LS = 1.;
580  float EndcapRate_LS = 1.;
581  float PixelRate_LS = 1.;
582  MonitorElement * me = iGetter.get("Pixel/AdditionalPixelErrors/byLumiErrors");
583  if(me){
584  double nBarrelErrors_LS = me->getBinContent(1) - nErrorsBarrel_lastLS_;
585  double nEndcapErrors_LS = me->getBinContent(2) - nErrorsEndcap_lastLS_;
586  double nEvents_LS = me->getBinContent(0) - nEvents_lastLS_;
587  if(nBarrelErrors_LS/nEvents_LS>0.5) BarrelRate_LS=0.;
588  if(nEndcapErrors_LS/nEvents_LS>0.5) EndcapRate_LS=0.;
589  if((nBarrelErrors_LS + nEndcapErrors_LS)/nEvents_LS>0.5) PixelRate_LS=0.;
590  }
591 
592  // evaluate mean cluster charge on tracks for data quality:
593  float BarrelClusterCharge = 1.;
594  float EndcapClusterCharge = 1.;
595  float PixelClusterCharge = 1.;
596  MonitorElement * me1 = iGetter.get("Pixel/Clusters/OnTrack/charge_siPixelClusters_Barrel");
597  if(me1 && me1->getMean()<12.) BarrelClusterCharge = 0.;
598  MonitorElement * me2 = iGetter.get("Pixel/Clusters/OnTrack/charge_siPixelClusters_Endcap");
599  if(me2 && me2->getMean()<12.) EndcapClusterCharge = 0.;
600  MonitorElement * me3 = iGetter.get("Pixel/Clusters/OnTrack/charge_siPixelClusters");
601  if(me3 && me3->getMean()<12.) PixelClusterCharge = 0.;
602 
603  // evaluate average FED occupancy for data quality:
604  float BarrelOccupancy = 1.;
605  float EndcapOccupancy = 1.;
606  float PixelOccupancy = 1.;
607  MonitorElement * me4 = iGetter.get("Pixel/averageDigiOccupancy");
608  if(me4){
609  double minBarrelOcc = 999999.;
610  double maxBarrelOcc = -1.;
611  double meanBarrelOcc = 0.;
612  double minEndcapOcc = 999999.;
613  double maxEndcapOcc = -1.;
614  double meanEndcapOcc = 0.;
615  for(int i=1; i!=41; i++){
616  if(i<=32 && me4->getBinContent(i)<minBarrelOcc) minBarrelOcc=me4->getBinContent(i);
617  if(i<=32 && me4->getBinContent(i)>maxBarrelOcc) maxBarrelOcc=me4->getBinContent(i);
618  if(i<=32) meanBarrelOcc+=me4->getBinContent(i);
619  if(i>32 && me4->getBinContent(i)<minEndcapOcc) minEndcapOcc=me4->getBinContent(i);
620  if(i>32 && me4->getBinContent(i)>maxEndcapOcc) maxEndcapOcc=me4->getBinContent(i);
621  if(i>32) meanEndcapOcc+=me4->getBinContent(i);
622  }
623  meanBarrelOcc = meanBarrelOcc/32.;
624  meanEndcapOcc = meanEndcapOcc/8.;
625  if(minBarrelOcc<0.1*meanBarrelOcc || maxBarrelOcc>2.5*meanBarrelOcc) BarrelOccupancy=0.;
626  if(minEndcapOcc<0.2*meanEndcapOcc || maxEndcapOcc>1.8*meanEndcapOcc) EndcapOccupancy=0.;
627  PixelOccupancy=BarrelOccupancy*EndcapOccupancy;
628  }
629 
630  float pixelFlag = PixelRate_LS * PixelClusterCharge * PixelOccupancy;
631  float barrelFlag = BarrelRate_LS * BarrelClusterCharge * BarrelOccupancy;
632  float endcapFlag = EndcapRate_LS * EndcapClusterCharge * EndcapOccupancy;
633  SummaryPixel = iGetter.get("Pixel/EventInfo/reportSummary");
634  if(SummaryPixel) SummaryPixel->Fill(pixelFlag);
635  SummaryBarrel = iGetter.get("Pixel/EventInfo/reportSummaryContents/PixelBarrelFraction");
636  if(SummaryBarrel) SummaryBarrel->Fill(barrelFlag);
637  SummaryEndcap = iGetter.get("Pixel/EventInfo/reportSummaryContents/PixelEndcapFraction");
638  if(SummaryEndcap) SummaryEndcap->Fill(endcapFlag);
639 
640 }
MonitorElement * get(const std::string &path)
Definition: DQMStore.cc:307
MonitorElement * SummaryBarrel
double getMean(int axis=1) const
get mean value of histogram along x, y or z axis (axis=1, 2, 3 respectively)
void Fill(long long x)
MonitorElement * SummaryPixel
MonitorElement * SummaryEndcap
double getBinContent(int binx) const
get content of bin (1-D)
void SiPixelDataQuality::fillGlobalQualityPlot ( DQMStore::IBooker iBooker,
DQMStore::IGetter iGetter,
bool  init,
edm::ESHandle< SiPixelFedCablingMap theCablingMap,
int  nFEDs,
bool  Tier0Flag,
int  lumisec 
)

Definition at line 644 of file SiPixelDataQuality.cc.

References allmodsMap, allmodsVec, stringResolutionProvider_cfi::bin, DQMStore::IBooker::cd(), DQMStore::IGetter::cd(), ws_sso_content_reader::content, relmon_rootfiles_spy::contents, count, count1, count2, count3, count4, count5, count6, RefreshWebPage::dname, errcount, errmodsMap, errmodsVec, l1t::stage2::layer2::fedId, DQMStore::IGetter::get(), MonitorElement::getBinContent(), getDetId(), MonitorElement::getEntries(), MonitorElement::getFloatValue(), MonitorElement::getIntValue(), DQMStore::IGetter::getMEs(), MonitorElement::getNbinsX(), DQMStore::IGetter::getSubdirs(), goodmodsMap, goodmodsVec, DQMStore::IBooker::goUp(), mps_fire::i, createfilelist::int, gen::k, lastallmods_, lasterrmods_, modCounter_, edm::ESHandle< T >::product(), DQMStore::IBooker::pwd(), MonitorElement::setBinContent(), DQMStore::IGetter::setCurrentFolder(), and SummaryReportMap.

644  {
645 //std::cout<<"Entering SiPixelDataQuality::fillGlobalQualityPlot: "<<nFEDs<<std::endl;
646  if(init){
647  count=0; errcount=0;
648  init=false;
649  count1=0;
650  count2=0;
651  count3=0;
652  count4=0;
653  count5=0;
654  count6=0;
655  modCounter_=0;
656  if(!Tier0Flag){
657 
658  //The plots that these Vecs are integrated throughout a run
659  //So at each lumi section I save their last values (lastmods)
660  //And then subtract them out later when filling the SummaryMap
661  for(int j=1; j!=41; j++){
662  if(allmodsVec) lastallmods_[j-1] = allmodsVec->GetBinContent(j);
663  if(errmodsVec) lasterrmods_[j-1] = errmodsVec->GetBinContent(j);
664  if(allmodsVec) allmodsVec->SetBinContent(j,0.);
665  if(errmodsVec) errmodsVec->SetBinContent(j,0.);
666  if(goodmodsVec) goodmodsVec->SetBinContent(j,0.);
667  }
668  }
669  if(Tier0Flag){
670  for(int i=1; i!=3; i++) for(int j=1; j!=8; j++){
671  if(allmodsMap) allmodsMap->SetBinContent(i,j,0.);
672  if(errmodsMap) errmodsMap->SetBinContent(i,j,0.);
673  if(goodmodsMap) goodmodsMap->SetBinContent(i,j,0.);
674  }
675  }
676  }
677 
678 //^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
679 // Fill Maps:
680  // Online:
681  if(nFEDs==0) return;
682 
683  if(!Tier0Flag){
684  //Not elegant, but not sure where else to put this sweet new plot!
685  MonitorElement * meTmp = iGetter.get("Pixel/Barrel/NClustertoChargeRatio_AllMod");
686  MonitorElement * meTop = iGetter.get("Pixel/Barrel/SUMCLU_nclusters_Barrel");
687  MonitorElement * meBot = iGetter.get("Pixel/Barrel/SUMCLU_charge_Barrel");
688  if(meTop && meBot && meTmp){
689  for (int bin = 1; bin < 769; ++bin){
690  float content = 0.0;
691  if (meBot->getBinContent(bin) > 0.0){
692  content = meTop->getBinContent(bin)/meBot->getBinContent(bin);
693  }
694  meTmp->setBinContent(bin,content);
695  }
696  for (int j = 0; j < 4; ++j){
697  static const char buf[] = "Pixel/Barrel/NClustertoChargeRatio_NormMod%i";
698  char modplot[sizeof(buf)+2];
699  sprintf(modplot,buf,j+1);
700  MonitorElement * meFinal = iGetter.get(modplot);
701  if(!meFinal) continue;
702  for (int i = 1; i < 769; ++i){
703  int k = 3 - j;
704  if (int(i+k)%4 == 0)
705  meFinal->setBinContent(int((i+k)/4), meTmp->getBinContent(i));
706  }
707  //Filling done. Now modification.
708  float SFLay[3], TotLay[3];
709  for (int ll = 0; ll < 3; ++ll) TotLay[ll] = 0.0;
710  for (int bin = 1; bin < (meFinal->getNbinsX()+1);++bin){
711  int layer = int((bin%48)/16);
712  TotLay[layer] += meFinal->getBinContent(bin);
713  }
714  float laynorm = TotLay[1]/64.;
715  for (int ll = 0; ll < 3; ++ll){
716  SFLay[ll] = 0.0; if (TotLay[ll] > 0.0 && TotLay[1] > 0.0) SFLay[ll] = TotLay[1]/TotLay[ll]*(1./laynorm);
717  }
718  //now loop through plot
719  for (int bin = 1; bin < (meFinal->getNbinsX()+1); ++bin){
720  //access the layer number for bin: int((i%48)/16)
721  int layer = int((bin%48)/16);
722  float content = meFinal->getBinContent(bin);
723  //apply scale factor to bin content
724  meFinal->setBinContent(bin,content*SFLay[layer]);
725  }
726  }
727  }
728 
729  string currDir = iBooker.pwd();
730  if(currDir.find("Reference")!=string::npos || currDir.find("Additional")!=string::npos) return;
731  string dname = currDir.substr(currDir.find_last_of("/")+1);
732  if(dname.find("Module_")!=string::npos && currDir.find("Reference")==string::npos){
733  vector<string> meVec = iGetter.getMEs();
734  int detId=-1; int fedId=-1;
735  for (vector<string>::const_iterator it = meVec.begin(); it != meVec.end(); it++){//loop over all modules and fill ndigis into allmodsMap
736  //checking for any digis or FED errors to decide if this module is in DAQ:
737  string full_path = currDir + "/" + (*it);
738  if(detId==-1 && full_path.find("SUMOFF")==string::npos &&
739  (full_path.find("ndigis")!=string::npos && full_path.find("SUMDIG")==string::npos) &&
740  (getDetId(iGetter.get(full_path)) > 100)){
741  MonitorElement * me = iGetter.get(full_path);
742  if (!me) continue;
743  if((full_path.find("ndigis")!=string::npos)){
744  modCounter_++;
745  detId = getDetId(me);
746  for(int fedid=0; fedid!=40; ++fedid){
747  SiPixelFrameConverter converter(theCablingMap.product(),fedid);
748  uint32_t newDetId = detId;
749  if(converter.hasDetUnit(newDetId)){
750  fedId=fedid;
751  break;
752  }
753  }
754  double NDigis = 0;
755  if(full_path.find("ndigis")!=string::npos) NDigis = me->getEntries();
756  float weight = (allmodsVec->GetBinContent(fedId+1))+NDigis;
757  allmodsVec->SetBinContent(fedId+1,weight);
758  }
759  }
760  }//end loop over MEs
761  }//end of module dir's
762  vector<string> subDirVec = iGetter.getSubdirs();
763  for (vector<string>::const_iterator ic = subDirVec.begin();
764  ic != subDirVec.end(); ic++) {
765  iBooker.cd(*ic);
766  iGetter.cd(*ic);
767  init=false;
768  fillGlobalQualityPlot(iBooker,iGetter,init,theCablingMap,nFEDs,Tier0Flag,lumisec);
769  iBooker.goUp();
770  iGetter.setCurrentFolder(iBooker.pwd());
771  }
772  if(modCounter_==1440){
773  iBooker.cd("Pixel/EventInfo/reportSummaryContents");
774  iGetter.cd("Pixel/EventInfo/reportSummaryContents");
775  if(iBooker.pwd()=="Pixel/EventInfo/reportSummaryContents"){
776  for(int i=0; i!=40; i++){//loop over FEDs to fetch the errors
777  static const char buf[] = "Pixel/AdditionalPixelErrors/FED_%d/FedChNErr";
778  char fedplot[sizeof(buf)+4];
779  int NErrors = 0;
780  for(int j=0; j!=37; j++){//loop over FED channels within a FED
781  sprintf(fedplot,buf,i);
782  MonitorElement * me = iGetter.get(fedplot);
783  if(me) NErrors = NErrors + me->getBinContent(j+1);
784  }
785  //If I fill, then I end up majorly overcounting the numbers of errors...
786  if(NErrors>0){ errmodsVec->SetBinContent(i+1,NErrors); }
787  }
788  SummaryReportMap = iGetter.get("Pixel/EventInfo/reportSummaryMap");
789  if(SummaryReportMap){
790  float contents=0.;
791  for(int i=1; i!=41; i++){
792  //Dynamically subtracting previous (integrated) lumi section values
793  //in order to only show current lumi section's numbers
794  float mydigis = allmodsVec->GetBinContent(i) - lastallmods_[i-1];
795  float myerrs = errmodsVec->GetBinContent(i) - lasterrmods_[i-1];
796  if ((mydigis + myerrs) > 0.){
797  contents = mydigis/(mydigis + myerrs);
798  }else{
799  //Changed so that dynamic zooming will still
800  //advance over these bins(in renderplugins)
801  contents = -0.5;
802  }
803  SummaryReportMap->setBinContent(lumisec+1,i,contents);
804  }//end for loop over summaryReportMap bins
805  }//end if reportSummaryMap ME exists
806  }//end if in summary directory
807  }//end if modCounter_
808  }else{ // Offline
809  float barrel_errors_temp[1]={-1.}; int barrel_cuts_temp[6]={6*-1};
810  float endcap_errors_temp[1]={-1.}; int endcap_cuts_temp[6]={6*-1};
811  int pixel_cuts_temp[1]={-1};
812  // Barrel results:
813  MonitorElement * me;
814  me = iGetter.get("Pixel/Barrel/BarrelNErrorsCut");
815  if(me) barrel_errors_temp[0] = me->getFloatValue();
816  me = iGetter.get("Pixel/Endcap/EndcapNErrorsCut");
817  if(me) endcap_errors_temp[0] = me->getFloatValue();
818  SummaryReportMap->setBinContent(1,1,barrel_errors_temp[0]);
819  SummaryReportMap->setBinContent(2,1,endcap_errors_temp[0]);
820  me = iGetter.get("Pixel/Barrel/BarrelNDigisCut");
821  if(me) barrel_cuts_temp[0] = me->getIntValue();
822  me = iGetter.get("Pixel/Barrel/BarrelDigiChargeCut");
823  if(me) barrel_cuts_temp[1] = me->getIntValue();
824  me = iGetter.get("Pixel/Barrel/BarrelClusterSizeCut");
825  if(me) barrel_cuts_temp[2] = me->getIntValue();
826  me = iGetter.get("Pixel/Barrel/BarrelNClustersCut");
827  if(me) barrel_cuts_temp[3] = me->getIntValue();
828  me = iGetter.get("Pixel/Barrel/BarrelClusterChargeCut");
829  if(me) barrel_cuts_temp[4] = me->getIntValue();
830  me = iGetter.get("Pixel/Endcap/EndcapNDigisCut");
831  if(me) endcap_cuts_temp[0] = me->getIntValue();
832  me = iGetter.get("Pixel/Endcap/EndcapDigiChargeCut");
833  if(me) endcap_cuts_temp[1] = me->getIntValue();
834  me = iGetter.get("Pixel/Endcap/EndcapClusterSizeCut");
835  if(me) endcap_cuts_temp[2] = me->getIntValue();
836  me = iGetter.get("Pixel/Endcap/EndcapNClustersCut");
837  if(me) endcap_cuts_temp[3] = me->getIntValue();
838  me = iGetter.get("Pixel/Endcap/EndcapClusterChargeCut");
839  if(me) endcap_cuts_temp[4] = me->getIntValue();
840  for(int j=2; j!=7; j++){
841  SummaryReportMap->setBinContent(1,j,barrel_cuts_temp[j-2]);
842  SummaryReportMap->setBinContent(2,j,endcap_cuts_temp[j-2]);
843  }
844  me = iGetter.get("Pixel/Tracks/PixelTracksCut");
845  if(me) pixel_cuts_temp[0] = me->getIntValue();
846  SummaryReportMap->setBinContent(1,7,pixel_cuts_temp[0]);
847  SummaryReportMap->setBinContent(2,7,pixel_cuts_temp[0]);
848  }//end of offline map
849  if(allmodsMap) allmodsMap->Clear();
850  if(goodmodsMap) goodmodsMap->Clear();
851  if(errmodsMap) errmodsMap->Clear();
852 }
int64_t getIntValue() const
void setBinContent(int binx, double content)
set content of bin (1-D)
double getFloatValue() const
MonitorElement * get(const std::string &path)
Definition: DQMStore.cc:307
int init
Definition: HydjetWrapper.h:67
void fillGlobalQualityPlot(DQMStore::IBooker &iBooker, DQMStore::IGetter &iGetter, bool init, edm::ESHandle< SiPixelFedCablingMap > theCablingMap, int nFEDs, bool Tier0Flag, int lumisec)
Definition: weight.py:1
int getDetId(MonitorElement *mE)
(Documentation under construction).
int k[5][pyjets_maxn]
bin
set the eta bin as selection string.
MonitorElement * SummaryReportMap
double getEntries() const
get # of entries
const std::string & pwd()
Definition: DQMStore.cc:287
void setCurrentFolder(const std::string &fullpath)
Definition: DQMStore.cc:349
double getBinContent(int binx) const
get content of bin (1-D)
std::vector< std::string > getSubdirs()
Definition: DQMStore.cc:325
int getNbinsX() const
get # of bins in X-axis
std::vector< std::string > getMEs()
Definition: DQMStore.cc:329
T const * product() const
Definition: ESHandle.h:86
int SiPixelDataQuality::getDetId ( MonitorElement mE)

(Documentation under construction).

Given a pointer to ME returns the associated detId

Definition at line 108 of file SiPixelDataQuality.cc.

References MonitorElement::getName().

Referenced by fillGlobalQualityPlot().

109 {
110  const string& mEName = mE->getName() ;
111 
112  int detId = 0;
113 
114  if( mEName.find("_3") != string::npos )
115  {
116  string detIdString = mEName.substr((mEName.find_last_of("_"))+1,9);
117  std::istringstream isst;
118  isst.str(detIdString);
119  isst>>detId;
120  }
121 
122  return detId ;
123 
124 }
const std::string & getName() const
get name of ME

Member Data Documentation

int SiPixelDataQuality::allMods_
private

Definition at line 110 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag(), and SiPixelDataQuality().

TH2F* SiPixelDataQuality::allmodsMap
private
TH1D* SiPixelDataQuality::allmodsVec
private
float SiPixelDataQuality::barrel_error_flag_
private

Definition at line 118 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

int SiPixelDataQuality::barrelMods_
private

Definition at line 110 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

MonitorElement* SiPixelDataQuality::ClusterChargeBarrel
private

Definition at line 134 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag(), and computeGlobalQualityFlag().

MonitorElement* SiPixelDataQuality::ClusterChargeEndcap
private

Definition at line 135 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag(), and computeGlobalQualityFlag().

int SiPixelDataQuality::clusterCounterBarrel
private

Definition at line 121 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

int SiPixelDataQuality::clusterCounterEndcap
private

Definition at line 123 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

MonitorElement* SiPixelDataQuality::ClusterMod1
private

Definition at line 104 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag().

MonitorElement* SiPixelDataQuality::ClusterMod2
private

Definition at line 105 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag().

MonitorElement* SiPixelDataQuality::ClusterMod3
private

Definition at line 106 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag().

MonitorElement* SiPixelDataQuality::ClusterMod4
private

Definition at line 107 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag().

MonitorElement* SiPixelDataQuality::ClusterModAll
private

Definition at line 103 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag().

MonitorElement* SiPixelDataQuality::ClusterSizeBarrel
private

Definition at line 132 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag(), and computeGlobalQualityFlag().

MonitorElement* SiPixelDataQuality::ClusterSizeEndcap
private

Definition at line 133 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag(), and computeGlobalQualityFlag().

bool SiPixelDataQuality::clusterStatsBarrel
private

Definition at line 120 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

bool SiPixelDataQuality::clusterStatsEndcap
private

Definition at line 122 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

int SiPixelDataQuality::count
private

Definition at line 85 of file SiPixelDataQuality.h.

Referenced by fillGlobalQualityPlot().

int SiPixelDataQuality::count1
private

Definition at line 142 of file SiPixelDataQuality.h.

Referenced by fillGlobalQualityPlot().

int SiPixelDataQuality::count2
private

Definition at line 143 of file SiPixelDataQuality.h.

Referenced by fillGlobalQualityPlot().

int SiPixelDataQuality::count3
private

Definition at line 144 of file SiPixelDataQuality.h.

Referenced by fillGlobalQualityPlot().

int SiPixelDataQuality::count4
private

Definition at line 145 of file SiPixelDataQuality.h.

Referenced by fillGlobalQualityPlot().

int SiPixelDataQuality::count5
private

Definition at line 146 of file SiPixelDataQuality.h.

Referenced by fillGlobalQualityPlot().

int SiPixelDataQuality::count6
private

Definition at line 147 of file SiPixelDataQuality.h.

Referenced by fillGlobalQualityPlot().

MonitorElement* SiPixelDataQuality::DigiChargeBarrel
private

Definition at line 128 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag(), and computeGlobalQualityFlag().

MonitorElement* SiPixelDataQuality::DigiChargeEndcap
private

Definition at line 129 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag(), and computeGlobalQualityFlag().

int SiPixelDataQuality::digiCounterBarrel
private

Definition at line 121 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

int SiPixelDataQuality::digiCounterEndcap
private

Definition at line 123 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

bool SiPixelDataQuality::digiStatsBarrel
private

Definition at line 120 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

bool SiPixelDataQuality::digiStatsEndcap
private

Definition at line 122 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

bool SiPixelDataQuality::DONE_
private

Definition at line 90 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

float SiPixelDataQuality::endcap_error_flag_
private

Definition at line 118 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

int SiPixelDataQuality::endcapMods_
private

Definition at line 110 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

bool SiPixelDataQuality::endOfModules_
private

Definition at line 95 of file SiPixelDataQuality.h.

int SiPixelDataQuality::errcount
private

Definition at line 86 of file SiPixelDataQuality.h.

Referenced by fillGlobalQualityPlot().

TH2F* SiPixelDataQuality::errmodsMap
private
TH1D* SiPixelDataQuality::errmodsVec
private
int SiPixelDataQuality::errorMods_
private

Definition at line 110 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag(), and SiPixelDataQuality().

MonitorElement* SiPixelDataQuality::FEDErrReportMap
private

Definition at line 113 of file SiPixelDataQuality.h.

TH2F* SiPixelDataQuality::goodmodsMap
private
TH1D* SiPixelDataQuality::goodmodsVec
private
bool SiPixelDataQuality::gotDigis
private

Definition at line 87 of file SiPixelDataQuality.h.

float SiPixelDataQuality::lastallmods_[40]
private

Definition at line 153 of file SiPixelDataQuality.h.

Referenced by fillGlobalQualityPlot(), and SiPixelDataQuality().

float SiPixelDataQuality::lasterrmods_[40]
private

Definition at line 152 of file SiPixelDataQuality.h.

Referenced by fillGlobalQualityPlot(), and SiPixelDataQuality().

int SiPixelDataQuality::lastLS_
private

Definition at line 151 of file SiPixelDataQuality.h.

Referenced by SiPixelDataQuality().

int SiPixelDataQuality::modCounter_
private

Definition at line 150 of file SiPixelDataQuality.h.

Referenced by fillGlobalQualityPlot().

std::ofstream SiPixelDataQuality::myfile_
private

Definition at line 93 of file SiPixelDataQuality.h.

int SiPixelDataQuality::n_errors_barrel_
private

Definition at line 117 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

int SiPixelDataQuality::n_errors_endcap_
private

Definition at line 117 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

int SiPixelDataQuality::n_errors_pixel_
private

Definition at line 117 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

MonitorElement* SiPixelDataQuality::NClustersBarrel
private

Definition at line 136 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag(), and computeGlobalQualityFlag().

MonitorElement* SiPixelDataQuality::NClustersEndcap
private

Definition at line 137 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag(), and computeGlobalQualityFlag().

MonitorElement* SiPixelDataQuality::NDigisBarrel
private

Definition at line 126 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag(), and computeGlobalQualityFlag().

MonitorElement* SiPixelDataQuality::NDigisEndcap
private

Definition at line 127 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag(), and computeGlobalQualityFlag().

MonitorElement* SiPixelDataQuality::NErrorsBarrel
private

Definition at line 114 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag(), and computeGlobalQualityFlag().

MonitorElement* SiPixelDataQuality::NErrorsEndcap
private

Definition at line 115 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag(), and computeGlobalQualityFlag().

MonitorElement* SiPixelDataQuality::NErrorsFEDs
private

Definition at line 116 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag().

int SiPixelDataQuality::nevents_
private

Definition at line 94 of file SiPixelDataQuality.h.

MonitorElement* SiPixelDataQuality::NPixelTracks
private

Definition at line 140 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag(), and computeGlobalQualityFlag().

int SiPixelDataQuality::objectCount_
private

Definition at line 89 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

bool SiPixelDataQuality::offlineXMLfile_
private

Definition at line 76 of file SiPixelDataQuality.h.

float SiPixelDataQuality::pixel_error_flag_
private

Definition at line 118 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

float SiPixelDataQuality::qflag_
private

Definition at line 109 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag(), and SiPixelDataQuality().

MonitorElement* SiPixelDataQuality::SummaryBarrel
private
MonitorElement* SiPixelDataQuality::SummaryEndcap
private
MonitorElement* SiPixelDataQuality::SummaryPixel
private
MonitorElement* SiPixelDataQuality::SummaryReportMap
private

Definition at line 99 of file SiPixelDataQuality.h.

Referenced by bookGlobalQualityFlag(), and fillGlobalQualityPlot().

edm::ESHandle<SiPixelFedCablingMap> SiPixelDataQuality::theCablingMap
private

Definition at line 96 of file SiPixelDataQuality.h.

int SiPixelDataQuality::timeoutCounter_
private

Definition at line 149 of file SiPixelDataQuality.h.

Referenced by SiPixelDataQuality().

int SiPixelDataQuality::trackCounterBarrel
private

Definition at line 121 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

int SiPixelDataQuality::trackCounterEndcap
private

Definition at line 123 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

bool SiPixelDataQuality::trackStatsBarrel
private

Definition at line 120 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().

bool SiPixelDataQuality::trackStatsEndcap
private

Definition at line 122 of file SiPixelDataQuality.h.

Referenced by computeGlobalQualityFlag().