CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Private Member Functions | Private Attributes
HcalDeadCellMonitor Class Reference

#include <HcalDeadCellMonitor.h>

Inheritance diagram for HcalDeadCellMonitor:
HcalBaseDQMonitor edm::EDAnalyzer

Public Member Functions

void analyze (edm::Event const &e, edm::EventSetup const &s)
 
void beginRun (const edm::Run &run, const edm::EventSetup &c)
 
void cleanup ()
 
void endJob ()
 
void endLuminosityBlock (const edm::LuminosityBlock &lumiSeg, const edm::EventSetup &c)
 
void endRun (const edm::Run &run, const edm::EventSetup &c)
 
 HcalDeadCellMonitor (const edm::ParameterSet &ps)
 
template<class DIGI >
void process_Digi (DIGI &digi)
 
template<class RECHIT >
void process_RecHit (RECHIT &rechit)
 
void processEvent (const HBHERecHitCollection &hbHits, const HORecHitCollection &hoHits, const HFRecHitCollection &hfHits, const HBHEDigiCollection &hbhedigi, const HODigiCollection &hodigi, const HFDigiCollection &hfdigi)
 
void reset ()
 
void setup ()
 
 ~HcalDeadCellMonitor ()
 
- Public Member Functions inherited from HcalBaseDQMonitor
 HcalBaseDQMonitor (const edm::ParameterSet &ps)
 
 HcalBaseDQMonitor ()
 
 ~HcalBaseDQMonitor ()
 
- Public Member Functions inherited from edm::EDAnalyzer
 EDAnalyzer ()
 
std::string workerType () const
 
virtual ~EDAnalyzer ()
 

Private Member Functions

void fillNevents_problemCells ()
 
void fillNevents_recentdigis ()
 
void fillNevents_recentrechits ()
 
template<class T >
void process_Digi (T &digi)
 
template<class T >
void process_RecHit (T &rechit)
 
void processEvent_HBHEdigi (const HBHEDataFrame digi)
 
void zeroCounters (bool resetpresent=false)
 

Private Attributes

int alarmer_counter_
 
int alarmer_counterHO01_
 
int beamMode_
 
int deadevt_
 
bool deadmon_makeDiagnostics_
 
bool deadmon_test_digis_
 
bool deadmon_test_rechits_
 
edm::InputTag digiLabel_
 
EtaPhiHists DigiPresentByDepth
 
bool doReset_
 
bool endLumiProcessed_
 
double energyThreshold_
 
bool excludeHO1P02_
 
bool excludeHORing2_
 
MonitorElementHBDeadVsEvent
 
double HBenergyThreshold_
 
bool hbhedcsON
 
edm::InputTag hbheRechitLabel_
 
MonitorElementHEDeadVsEvent
 
double HEenergyThreshold_
 
bool hfdcsON
 
MonitorElementHFDeadVsEvent
 
double HFenergyThreshold_
 
edm::InputTag hfRechitLabel_
 
bool hodcsON
 
MonitorElementHODeadVsEvent
 
double HOenergyThreshold_
 
edm::InputTag hoRechitLabel_
 
int is_RBX_loss_
 
bool is_stable_beam
 
HcalLogicalMaplogicalMap_
 
int minDeadEventCount_
 
MonitorElementNevents
 
unsigned int NumBadHB
 
unsigned int NumBadHE
 
unsigned int NumBadHF
 
unsigned int NumBadHFLUMI
 
unsigned int NumBadHO
 
unsigned int NumBadHO0
 
unsigned int NumBadHO01
 
unsigned int NumBadHO12
 
int NumBadHO1P02
 
unsigned int NumBadHO2
 
MonitorElementNumberOfNeverPresentDigis
 
MonitorElementNumberOfNeverPresentDigisHB
 
MonitorElementNumberOfNeverPresentDigisHE
 
MonitorElementNumberOfNeverPresentDigisHF
 
MonitorElementNumberOfNeverPresentDigisHO
 
MonitorElementNumberOfNeverPresentRecHits
 
MonitorElementNumberOfNeverPresentRecHitsHB
 
MonitorElementNumberOfNeverPresentRecHitsHE
 
MonitorElementNumberOfNeverPresentRecHitsHF
 
MonitorElementNumberOfNeverPresentRecHitsHO
 
MonitorElementNumberOfRecentMissingDigis
 
MonitorElementNumberOfRecentMissingDigisHB
 
MonitorElementNumberOfRecentMissingDigisHE
 
MonitorElementNumberOfRecentMissingDigisHF
 
MonitorElementNumberOfRecentMissingDigisHO
 
MonitorElementNumberOfRecentMissingRecHits
 
MonitorElementNumberOfRecentMissingRecHitsHB
 
MonitorElementNumberOfRecentMissingRecHitsHE
 
MonitorElementNumberOfRecentMissingRecHitsHF
 
MonitorElementNumberOfRecentMissingRecHitsHO
 
unsigned int occupancy_RBX [156]
 
bool present_digi [85][72][4]
 
bool present_rechit [85][72][4]
 
MonitorElementProblemsInLastNLB_HBHEHF_alarm
 
MonitorElementProblemsInLastNLB_HO01_alarm
 
MonitorElementProblemsVsLB
 
MonitorElementProblemsVsLB_HB
 
MonitorElementProblemsVsLB_HE
 
MonitorElementProblemsVsLB_HF
 
MonitorElementProblemsVsLB_HO
 
MonitorElementProblemsVsLB_HO2
 
MonitorElementRBX_loss_VS_LB
 
int rbxlost [156]
 
EtaPhiHists RecentMissingDigisByDepth
 
EtaPhiHists RecentMissingRecHitsByDepth
 
unsigned int recentoccupancy_digi [85][72][4]
 
unsigned int recentoccupancy_rechit [85][72][4]
 
EtaPhiHists RecHitPresentByDepth
 

Additional Inherited Members

- Public Types inherited from edm::EDAnalyzer
typedef EDAnalyzer ModuleType
 
typedef WorkerT< EDAnalyzerWorkerType
 
- Static Public Member Functions inherited from edm::EDAnalyzer
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &)
 
- Protected Member Functions inherited from HcalBaseDQMonitor
virtual void beginJob ()
 
virtual void beginLuminosityBlock (const edm::LuminosityBlock &lumiSeg, const edm::EventSetup &c)
 
bool IsAllowedCalibType ()
 
bool LumiInOrder (int lumisec)
 
void SetupEtaPhiHists (EtaPhiHists &hh, std::string Name, std::string Units)
 
- Protected Member Functions inherited from edm::EDAnalyzer
CurrentProcessingContext const * currentContext () const
 
- Protected Attributes inherited from HcalBaseDQMonitor
std::vector< int > AllowedCalibTypes_
 
int badChannelStatusMask_
 
int currentLS
 
int currenttype_
 
DQMStoredbe_
 
int debug_
 
bool enableCleanup_
 
bool eventAllowed_
 
bool HBpresent_
 
bool HEpresent_
 
bool HFpresent_
 
bool HOpresent_
 
int ievt_
 
std::map< unsigned int, int > KnownBadCells_
 
int levt_
 
bool makeDiagnostics_
 
MonitorElementmeIevt_
 
MonitorElementmeLevt_
 
bool mergeRuns_
 
MonitorElementmeTevt_
 
MonitorElementmeTevtHist_
 
int NLumiBlocks_
 
bool Online_
 
std::string prefixME_
 
MonitorElementProblemsCurrentLB
 
MonitorElementProblemsVsLB
 
MonitorElementProblemsVsLB_HB
 
MonitorElementProblemsVsLB_HBHEHF
 
MonitorElementProblemsVsLB_HE
 
MonitorElementProblemsVsLB_HF
 
MonitorElementProblemsVsLB_HO
 
bool skipOutOfOrderLS_
 
std::string subdir_
 
int tevt_
 

Detailed Description

Date:
2012/06/21 13:40:22
Revision:
1.60
Author
J. Temple - Univ. of Maryland

Definition at line 33 of file HcalDeadCellMonitor.h.

Constructor & Destructor Documentation

HcalDeadCellMonitor::HcalDeadCellMonitor ( const edm::ParameterSet ps)

Definition at line 4 of file HcalDeadCellMonitor.cc.

References HcalBaseDQMonitor::AllowedCalibTypes_, HcalBaseDQMonitor::badChannelStatusMask_, deadmon_test_digis_, deadmon_test_rechits_, HcalBaseDQMonitor::debug_, digiLabel_, HcalBaseDQMonitor::enableCleanup_, endLumiProcessed_, energyThreshold_, excludeHO1P02_, excludeHORing2_, relval_steps::gen(), edm::ParameterSet::getUntrackedParameter(), HBenergyThreshold_, hbheRechitLabel_, HcalChannelStatus::HcalCellDead, HEenergyThreshold_, HFenergyThreshold_, hfRechitLabel_, HOenergyThreshold_, hoRechitLabel_, logicalMap_, HcalBaseDQMonitor::makeDiagnostics_, HcalBaseDQMonitor::mergeRuns_, minDeadEventCount_, HcalBaseDQMonitor::NLumiBlocks_, HcalBaseDQMonitor::Online_, HcalBaseDQMonitor::prefixME_, HcalBaseDQMonitor::skipOutOfOrderLS_, and HcalBaseDQMonitor::subdir_.

5 {
6  Online_ = ps.getUntrackedParameter<bool>("online",false);
7  mergeRuns_ = ps.getUntrackedParameter<bool>("mergeRuns",false);
8  enableCleanup_ = ps.getUntrackedParameter<bool>("enableCleanup",false);
9  debug_ = ps.getUntrackedParameter<int>("debug",0);
10  makeDiagnostics_ = ps.getUntrackedParameter<bool>("makeDiagnostics",false);
11  prefixME_ = ps.getUntrackedParameter<std::string>("subSystemFolder","Hcal/");
12  if (prefixME_.substr(prefixME_.size()-1,prefixME_.size())!="/")
13  prefixME_.append("/");
14  subdir_ = ps.getUntrackedParameter<std::string>("TaskFolder","DeadCellMonitor_Hcal"); // DeadCellMonitor_Hcal
15  if (subdir_.size()>0 && subdir_.substr(subdir_.size()-1,subdir_.size())!="/")
16  subdir_.append("/");
17  subdir_=prefixME_+subdir_;
18  AllowedCalibTypes_ = ps.getUntrackedParameter<std::vector<int> > ("AllowedCalibTypes");
19  skipOutOfOrderLS_ = ps.getUntrackedParameter<bool>("skipOutOfOrderLS",true);
20  NLumiBlocks_ = ps.getUntrackedParameter<int>("NLumiBlocks",4000);
21 
22  badChannelStatusMask_ = ps.getUntrackedParameter<int>("BadChannelStatusMask",
23  ps.getUntrackedParameter<int>("BadChannelStatusMask",
24  (1<<HcalChannelStatus::HcalCellDead))); // identify channel status values to mask
25  // DeadCell-specific parameters
26 
27  // Collection type info
29  hbheRechitLabel_ = ps.getUntrackedParameter<edm::InputTag>("hbheRechitLabel");
30  hoRechitLabel_ = ps.getUntrackedParameter<edm::InputTag>("hoRechitLabel");
31  hfRechitLabel_ = ps.getUntrackedParameter<edm::InputTag>("hfRechitLabel");
32 
33  // minimum number of events required for lumi section-based dead cell checks
34  minDeadEventCount_ = ps.getUntrackedParameter<int>("minDeadEventCount",1000);
35  excludeHORing2_ = ps.getUntrackedParameter<bool>("excludeHORing2",false);
36  excludeHO1P02_ = ps.getUntrackedParameter<bool>("excludeHO1P02",false);
37  endLumiProcessed_ = false;
38 
39  // Set which dead cell checks will be performed
40  /* Dead cells can be defined in the following ways:
41  1) never present digi -- digi is never present in run
42  2) digis -- digi is absent for one or more lumi section
43  3) never present rechit -- rechit > threshold energy never present (NOT redundant, since it requires not just that a rechit be present, but that it be above threshold as well. )
44  4) rechits -- rechit is present, but rechit energy below threshold for one or more lumi sections
45 
46  Of these tests, never-present digis are always checked.
47  Occasional digis are checked only if deadmon_test_digis_ is true,
48  and both rechit tests are made only if deadmon_test_rechits_ is true
49  */
50 
51  deadmon_test_digis_ = ps.getUntrackedParameter<bool>("test_digis",true);
52  deadmon_test_rechits_ = ps.getUntrackedParameter<bool>("test_rechits",false);
53 
54  // rechit energy test -- cell must be below threshold value for a number of consecutive events to be considered dead
55  energyThreshold_ = ps.getUntrackedParameter<double>("MissingRechitEnergyThreshold",0);
56  HBenergyThreshold_ = ps.getUntrackedParameter<double>("HB_energyThreshold",energyThreshold_);
57  HEenergyThreshold_ = ps.getUntrackedParameter<double>("HE_energyThreshold",energyThreshold_);
58  HOenergyThreshold_ = ps.getUntrackedParameter<double>("HO_energyThreshold",energyThreshold_);
59  HFenergyThreshold_ = ps.getUntrackedParameter<double>("HF_energyThreshold",energyThreshold_);
60 
62  logicalMap_=new HcalLogicalMap(gen.createMap());
63 } //constructor
edm::InputTag hfRechitLabel_
T getUntrackedParameter(std::string const &, T const &) const
edm::InputTag hbheRechitLabel_
std::vector< int > AllowedCalibTypes_
edm::InputTag hoRechitLabel_
HcalLogicalMap * logicalMap_
HcalDeadCellMonitor::~HcalDeadCellMonitor ( )

Definition at line 65 of file HcalDeadCellMonitor.cc.

References logicalMap_.

66 {
67  if (logicalMap_ == 0) delete logicalMap_;
68 } //destructor
HcalLogicalMap * logicalMap_

Member Function Documentation

void HcalDeadCellMonitor::analyze ( edm::Event const &  e,
edm::EventSetup const &  s 
)
virtual

Reimplemented from HcalBaseDQMonitor.

Definition at line 611 of file HcalDeadCellMonitor.cc.

References HcalBaseDQMonitor::analyze(), L1GtfeExtWord::beamMode(), gather_cfg::cout, deadevt_, HcalBaseDQMonitor::debug_, digiLabel_, doReset_, endLumiProcessed_, MonitorElement::Fill(), edm::Event::getByLabel(), DcsStatus::HBHEa, DcsStatus::HBHEb, DcsStatus::HBHEc, hbhedcsON, hbheRechitLabel_, DcsStatus::HF, hfdcsON, hfRechitLabel_, DcsStatus::HO, hodcsON, hoRechitLabel_, i, HcalBaseDQMonitor::ievt_, is_RBX_loss_, is_stable_beam, HcalBaseDQMonitor::IsAllowedCalibType(), edm::HandleBase::isValid(), HcalBaseDQMonitor::levt_, HcalBaseDQMonitor::LumiInOrder(), edm::EventBase::luminosityBlock(), Nevents, occupancy_RBX, processEvent(), edm::Handle< T >::product(), rbxlost, reset(), HcalBaseDQMonitor::tevt_, L1GtfeExtWord::totalIntensityBeam1(), and L1GtfeExtWord::totalIntensityBeam2().

612 {
613  if (!IsAllowedCalibType()) return;
614  endLumiProcessed_=false;
615 
616  if(doReset_)
617  this->reset();
618 
619  Nevents->Fill(0,1); // count all events of allowed calibration type, even if their lumi block is not in the right order
620  if (LumiInOrder(e.luminosityBlock())==false) return;
621  // try to get rechits and digis
625 
629 
631 
633  // check if detectors whether they were ON
635  e.getByLabel("scalersRawToDigi", dcsStatus);
636 
637  if (dcsStatus.isValid() && dcsStatus->size() != 0)
638  {
639  if ((*dcsStatus)[0].ready(DcsStatus::HBHEa) &&
640  (*dcsStatus)[0].ready(DcsStatus::HBHEb) &&
641  (*dcsStatus)[0].ready(DcsStatus::HBHEc))
642  {
643  hbhedcsON = true;
644  if (debug_) std::cout << "hbhe on" << std::endl;
645  }
646  else hbhedcsON = false;
647 
648  if ((*dcsStatus)[0].ready(DcsStatus::HF))
649  {
650  hfdcsON = true;
651  if (debug_) std::cout << "hf on" << std::endl;
652  }
653  else hfdcsON = false;
654 
655  if ((*dcsStatus)[0].ready(DcsStatus::HO))
656  {
657  hodcsON = true;
658  if (debug_) std::cout << "ho on" << std::endl;
659  }
660  else hodcsON = false;
661  }
663 
664  if (!(e.getByLabel(digiLabel_,hbhe_digi)))
665  {
666  edm::LogWarning("HcalDeadCellMonitor")<< digiLabel_<<" hbhe_digi not available";
667  return;
668  }
669  if (!(e.getByLabel(digiLabel_,ho_digi)))
670  {
671  edm::LogWarning("HcalDeadCellMonitor")<< digiLabel_<<" ho_digi not available";
672  return;
673  }
674  if (!(e.getByLabel(digiLabel_,hf_digi)))
675  {
676  edm::LogWarning("HcalDeadCellMonitor")<< digiLabel_<<" hf_digi not available";
677  return;
678  }
679 
680  if (!(e.getByLabel(hbheRechitLabel_,hbhe_rechit)))
681  {
682  edm::LogWarning("HcalDeadCellMonitor")<< hbheRechitLabel_<<" hbhe_rechit not available";
683  return;
684  }
685 
686  if (!(e.getByLabel(hfRechitLabel_,hf_rechit)))
687  {
688  edm::LogWarning("HcalDeadCellMonitor")<< hfRechitLabel_<<" hf_rechit not available";
689  return;
690  }
691  if (!(e.getByLabel(hoRechitLabel_,ho_rechit)))
692  {
693  edm::LogWarning("HcalDeadCellMonitor")<< hoRechitLabel_<<" ho_rechit not available";
694  return;
695  }
696  if (!(e.getByLabel("gtEvmDigis", gtEvm_handle)))
697  {
698  edm::LogWarning("HcalDeadCellMonitor")<< "gtEvmDigis"<<" gtEvmDigis not available";
699  return;
700  }
701  L1GtfeExtWord gtfeEvmExtWord = gtEvm_handle.product()->gtfeWord();
702 
703  if (debug_>1) std::cout <<"\t<HcalDeadCellMonitor::analyze> Processing good event! event # = "<<ievt_<<std::endl;
704  // Good event found; increment counter (via base class analyze method)
705  // This also runs the allowed calibration /lumi in order tests again; remove?
707 
708  ++deadevt_; //increment local counter
709 
710  processEvent(*hbhe_rechit, *ho_rechit, *hf_rechit, *hbhe_digi, *ho_digi, *hf_digi);
711 
712  // check for presence of an RBX data loss
713  if(levt_>10 && tevt_ % 10 == 0 ) //levt_ counts events perLS, but excludes
714  { //"wrong", calibration-type events. Compare with tevt_ instead...
715  for(int i=71; i<132; i++)
716  {
717  // These RBXs in HO are excluded, set to 1 to ignore
718  // HO0: 96-107 (all)
719  // HO1: 85-95, 109-119 (all odd)
720  // HO2: 73, 75, 79, 81, 83, 121-131 (all odd)
721  if(i >= 72 && i < 95 && i%2==0)
722  occupancy_RBX[i] = 1;
723  if(i >=108 && i <= 131 && i%2==0)
724  occupancy_RBX[i] = 1;
725 
726  if(i==117 || i==131) // HO SiPMs have much less hits, 10 events not enough.
727  occupancy_RBX[i] = 1; // Also no RBX loss for SiPMs, so ignore for now.
728  if(i==77)
729  occupancy_RBX[i] = 1;
730  }
731 
732  // RBX loss detected
733  for (unsigned int i=0;i<132;++i)
734  if(occupancy_RBX[i] == 0)
735  {
736  is_RBX_loss_ = 1;
737  rbxlost[i] = 1;
738  }
739 
740  int intensity1_ = gtfeEvmExtWord.totalIntensityBeam1();
741  int intensity2_ = gtfeEvmExtWord.totalIntensityBeam2();
742 
743  is_stable_beam = gtfeEvmExtWord.beamMode() == 11 ? true : false;
744 
745  for (unsigned int i=132;i<156;++i)
746  if(occupancy_RBX[i] == 0 && gtfeEvmExtWord.beamMode() == 11)
747  if(intensity1_>100 && intensity2_>100) // only in stable beam mode (11) and with circulating beams, otherwise
748  { // this check is too sensitive in HF
749  is_RBX_loss_ = 1;
750  rbxlost[i] = 1;
751  }
752 
753  // no RBX loss, reset the counters
754  if (is_RBX_loss_ == 0)
755  for (unsigned int i=0;i<156;++i)
756  occupancy_RBX[i] = 0;
757  }
758 
759  // if RBX is lost any time during the LS, don't allow the counters to increment
760  if(is_RBX_loss_ == 1)
761  for (unsigned int i=0;i<156;++i)
762  if(rbxlost[i]==1) occupancy_RBX[i] = 0;
763 
764 } // void HcalDeadCellMonitor::analyze(...)
edm::InputTag hfRechitLabel_
int i
Definition: DBlmapReader.cc:9
bool LumiInOrder(int lumisec)
virtual void analyze(const edm::Event &e, const edm::EventSetup &c)
edm::InputTag hbheRechitLabel_
void Fill(long long x)
edm::InputTag hoRechitLabel_
unsigned int occupancy_RBX[156]
MonitorElement * Nevents
bool isValid() const
Definition: HandleBase.h:76
const cms_uint32_t totalIntensityBeam2() const
const cms_uint32_t totalIntensityBeam1() const
void processEvent(const HBHERecHitCollection &hbHits, const HORecHitCollection &hoHits, const HFRecHitCollection &hfHits, const HBHEDigiCollection &hbhedigi, const HODigiCollection &hodigi, const HFDigiCollection &hfdigi)
T const * product() const
Definition: Handle.h:74
tuple cout
Definition: gather_cfg.py:121
const cms_uint16_t beamMode() const
void HcalDeadCellMonitor::beginRun ( const edm::Run run,
const edm::EventSetup c 
)
virtual

Reimplemented from HcalBaseDQMonitor.

Definition at line 372 of file HcalDeadCellMonitor.cc.

References HcalBaseDQMonitor::badChannelStatusMask_, HcalBaseDQMonitor::beginRun(), gather_cfg::cout, HcalBaseDQMonitor::debug_, doReset_, edm::EventSetup::get(), HcalCondObjectContainer< Item >::getAllChannels(), reco::JetExtendedAssociation::getValue(), HcalCondObjectContainer< Item >::getValues(), DetId::Hcal, i, HcalBaseDQMonitor::KnownBadCells_, HcalBaseDQMonitor::mergeRuns_, AlCaHLTBitMon_ParallelJobs::p, edm::ESHandle< class >::product(), reset(), setup(), ntuplemaker::status, and HcalBaseDQMonitor::tevt_.

373 {
374  if (debug_>1) std::cout <<"HcalDeadCellMonitor::beginRun"<<std::endl;
376 
377  if (tevt_==0) this->setup(); // set up histograms if they have not been created before
378  if (mergeRuns_==false)
379  this->reset();
380 
381  doReset_ = true;
382 
383  // Get known dead cells for this run
384  KnownBadCells_.clear();
385  if (badChannelStatusMask_>0)
386  {
388  c.get<HcalChannelQualityRcd>().get(p);
389  HcalChannelQuality* chanquality= new HcalChannelQuality(*p.product());
390  std::vector<DetId> mydetids = chanquality->getAllChannels();
391  for (std::vector<DetId>::const_iterator i = mydetids.begin();
392  i!=mydetids.end();
393  ++i)
394  {
395  if (i->det()!=DetId::Hcal) continue; // not an hcal cell
396  HcalDetId id=HcalDetId(*i);
397  int status=(chanquality->getValues(id))->getValue();
398  if ((status & badChannelStatusMask_))
399  KnownBadCells_[id.rawId()]=status;
400  }
401  delete chanquality;
402  } // if (badChannelStatusMask_>0)
403  return;
404 } //void HcalDeadCellMonitor::beginRun(...)
int i
Definition: DBlmapReader.cc:9
std::map< unsigned int, int > KnownBadCells_
virtual void beginRun(const edm::Run &run, const edm::EventSetup &c)
std::vector< DetId > getAllChannels() const
const T & get() const
Definition: EventSetup.h:55
T const * product() const
Definition: ESHandle.h:62
const JetExtendedData & getValue(const Container &, const reco::JetBaseRef &)
get value for the association. Throw exception if no association found
tuple cout
Definition: gather_cfg.py:121
tuple status
Definition: ntuplemaker.py:245
const Item * getValues(DetId fId) const
void HcalDeadCellMonitor::cleanup ( void  )
virtual

Reimplemented from HcalBaseDQMonitor.

Definition at line 484 of file HcalDeadCellMonitor.cc.

References HcalBaseDQMonitor::dbe_, HcalBaseDQMonitor::enableCleanup_, DQMStore::removeContents(), DQMStore::setCurrentFolder(), and HcalBaseDQMonitor::subdir_.

Referenced by endJob().

485 {
486  if (!enableCleanup_) return;
487  if (dbe_)
488  {
490  dbe_->removeContents();
491  dbe_->setCurrentFolder(subdir_+"dead_digi_never_present");
492  dbe_->removeContents();
493  dbe_->setCurrentFolder(subdir_+"dead_digi_often_missing");
494  dbe_->removeContents();
495  dbe_->setCurrentFolder(subdir_+"dead_rechit_neverpresent");
496  dbe_->removeContents();
497  dbe_->setCurrentFolder(subdir_+"dead_rechit_often_missing");
498  dbe_->removeContents();
499  dbe_->setCurrentFolder(subdir_+"dead_cell_parameters");
500  dbe_->removeContents();
501  dbe_->setCurrentFolder(subdir_+"LSvalues");
502  dbe_->removeContents();
503  }
504  return;
505 } // void HcalDeadCellMonitor::cleanup()
void removeContents(void)
erase all monitoring elements in current directory (not including subfolders);
Definition: DQMStore.cc:2564
void setCurrentFolder(const std::string &fullpath)
Definition: DQMStore.cc:429
void HcalDeadCellMonitor::endJob ( void  )
virtual

Reimplemented from HcalBaseDQMonitor.

Definition at line 605 of file HcalDeadCellMonitor.cc.

References cleanup(), gather_cfg::cout, HcalBaseDQMonitor::debug_, and HcalBaseDQMonitor::enableCleanup_.

606 {
607  if (debug_>0) std::cout <<"HcalDeadCellMonitor::endJob()"<<std::endl;
608  if (enableCleanup_) cleanup(); // when do we force cleanup?
609 }
tuple cout
Definition: gather_cfg.py:121
void HcalDeadCellMonitor::endLuminosityBlock ( const edm::LuminosityBlock lumiSeg,
const edm::EventSetup c 
)
virtual

Reimplemented from HcalBaseDQMonitor.

Definition at line 509 of file HcalDeadCellMonitor.cc.

References alarmer_counter_, alarmer_counterHO01_, beamMode_, deadevt_, endLumiProcessed_, fillNevents_problemCells(), fillNevents_recentdigis(), fillNevents_recentrechits(), hbhedcsON, HcalBaseDQMonitor::HBpresent_, HcalBaseDQMonitor::HEpresent_, hfdcsON, HcalBaseDQMonitor::HFpresent_, hodcsON, HcalBaseDQMonitor::HOpresent_, i, is_RBX_loss_, is_stable_beam, HcalBaseDQMonitor::levt_, HcalBaseDQMonitor::LumiInOrder(), edm::LuminosityBlockBase::luminosityBlock(), minDeadEventCount_, NumBadHB, NumBadHE, NumBadHF, NumBadHFLUMI, NumBadHO, NumBadHO0, NumBadHO12, HcalBaseDQMonitor::ProblemsCurrentLB, ProblemsInLastNLB_HBHEHF_alarm, ProblemsInLastNLB_HO01_alarm, rbxlost, MonitorElement::Reset(), MonitorElement::setBinContent(), and zeroCounters().

511 {
512  // skip old lumi sections
513  if (this->LumiInOrder(lumiSeg.luminosityBlock())==false) return;
514 
515  // Reset current LS histogram
516  if (ProblemsCurrentLB)
518 
521 
522  //increase the number of LS counting, for alarmer. Only make alarms for HBHE
523  if(hbhedcsON == true && hfdcsON == true && HBpresent_ == 1 && HEpresent_ == 1 && HFpresent_ == 1)
525  else
526  alarmer_counter_ = 0;
527 
528  if(hodcsON==true && HOpresent_ == 1)
530  else
532 
533  if (!is_stable_beam)
534  {
535  alarmer_counter_ = 0;
537  }
538 
539  // Here is where we determine whether or not to process an event
540  // Not enough events
541  // there are less than minDeadEventCount_ in this LS, but RBXloss is found
542 
544  {
548 
549  endLumiProcessed_=true;
550  is_RBX_loss_=0;
551 
552  for (unsigned int i=0;i<156;++i)
553  rbxlost[i] = 0;
554 
555  if (ProblemsCurrentLB)
556  {
557  ProblemsCurrentLB->setBinContent(0,0, levt_); // underflow bin contains number of events
565  }
566  }
567 
568  if (deadevt_<minDeadEventCount_) // perform normal tasks, since no RBX loss is detected in this lumisections
569  return;
570 
571  endLumiProcessed_=true;
572  // fillNevents_problemCells checks for never-present cells
576 
577  if (ProblemsCurrentLB)
578  {
579  ProblemsCurrentLB->setBinContent(0,0, levt_); // underflow bin contains number of events
587  }
588  zeroCounters();
589  deadevt_=0;
590  is_RBX_loss_=0;
591  beamMode_ = 0;
592  return;
593 } //endLuminosityBlock()
int i
Definition: DBlmapReader.cc:9
bool LumiInOrder(int lumisec)
void setBinContent(int binx, double content)
set content of bin (1-D)
MonitorElement * ProblemsCurrentLB
void zeroCounters(bool resetpresent=false)
MonitorElement * ProblemsInLastNLB_HO01_alarm
LuminosityBlockNumber_t luminosityBlock() const
MonitorElement * ProblemsInLastNLB_HBHEHF_alarm
void Reset(void)
reset ME (ie. contents, errors, etc)
void HcalDeadCellMonitor::endRun ( const edm::Run run,
const edm::EventSetup c 
)
virtual

Reimplemented from HcalBaseDQMonitor.

Definition at line 595 of file HcalDeadCellMonitor.cc.

References endLumiProcessed_, and fillNevents_problemCells().

596 {
597  // Always carry out overall occupancy test at endRun, regardless minimum number of events?
598  // Or should we require an absolute lower bound?
599  // We can always run this test; we'll use the summary client to implement a lower bound before calculating reportSummary values
600  if (endLumiProcessed_==false) fillNevents_problemCells(); // always check for never-present cells
601 
602  return;
603 }
void HcalDeadCellMonitor::fillNevents_problemCells ( )
private

Definition at line 1224 of file HcalDeadCellMonitor.cc.

References abs, alarmer_counter_, alarmer_counterHO01_, HcalObjRepresent::CalcIeta(), gather_cfg::cout, HcalBaseDQMonitor::currentLS, deadevt_, deadmon_test_digis_, deadmon_test_rechits_, HcalBaseDQMonitor::debug_, EtaPhiHists::depth, DigiPresentByDepth, eta(), excludeHO1P02_, excludeHORing2_, MonitorElement::Fill(), HcalBarrel, HcalEndcap, HcalForward, HcalOuter, i, HcalBaseDQMonitor::ievt_, is_RBX_loss_, isSiPM(), HcalBaseDQMonitor::KnownBadCells_, min, minDeadEventCount_, Nevents, NumBadHB, NumBadHE, NumBadHF, NumBadHFLUMI, NumBadHO, NumBadHO01, NumBadHO12, NumBadHO1P02, NumBadHO2, NumberOfNeverPresentDigis, NumberOfNeverPresentDigisHB, NumberOfNeverPresentDigisHE, NumberOfNeverPresentDigisHF, NumberOfNeverPresentDigisHO, NumberOfNeverPresentRecHits, NumberOfNeverPresentRecHitsHB, NumberOfNeverPresentRecHitsHE, NumberOfNeverPresentRecHitsHF, NumberOfNeverPresentRecHitsHO, NumberOfRecentMissingDigis, NumberOfRecentMissingDigisHB, NumberOfRecentMissingDigisHE, NumberOfRecentMissingDigisHF, NumberOfRecentMissingDigisHO, NumberOfRecentMissingRecHits, NumberOfRecentMissingRecHitsHB, NumberOfRecentMissingRecHitsHE, NumberOfRecentMissingRecHitsHF, NumberOfRecentMissingRecHitsHO, occupancy_RBX, phi, present_digi, present_rechit, ProblemsInLastNLB_HBHEHF_alarm, ProblemsInLastNLB_HO01_alarm, ProblemsVsLB, ProblemsVsLB_HB, HcalBaseDQMonitor::ProblemsVsLB_HBHEHF, ProblemsVsLB_HE, ProblemsVsLB_HF, ProblemsVsLB_HO, ProblemsVsLB_HO2, DetId::rawId(), RBX_loss_VS_LB, recentoccupancy_digi, recentoccupancy_rechit, and validDetId().

Referenced by endLuminosityBlock(), and endRun().

1225 {
1226  //fillNevents_problemCells now only performs checks of never-present cells
1227 
1228  if (debug_>0)
1229  std::cout <<"<HcalDeadCellMonitor::fillNevents_problemCells> FILLING PROBLEM CELL PLOTS"<<std::endl;
1230 
1231  int ieta=0;
1232  int iphi=0;
1233 
1234  // Count problem cells in each subdetector
1235 
1236  NumBadHB=0;
1237  NumBadHE=0;
1238  NumBadHO=0;
1239  NumBadHF=0;
1240  NumBadHFLUMI=0;
1241  NumBadHO01=0;
1242  NumBadHO2=0;
1243  NumBadHO12=0;
1244  NumBadHO1P02=0;
1245 
1246  int knownBadHB=0;
1247  int knownBadHE=0;
1248  int knownBadHF=0;
1249  int knownBadHO=0;
1250  int knownBadHFLUMI=0;
1251  int knownBadHO01=0;
1252  int knownBadHO2=0;
1253  int knownBadHO12=0;
1254 
1255 
1256  unsigned int neverpresentHB=0;
1257  unsigned int neverpresentHE=0;
1258  unsigned int neverpresentHO=0;
1259  unsigned int neverpresentHF=0;
1260 
1261  unsigned int unoccupiedHB=0;
1262  unsigned int unoccupiedHE=0;
1263  unsigned int unoccupiedHO=0;
1264  unsigned int unoccupiedHF=0;
1265 
1266  unsigned int belowenergyHB=0;
1267  unsigned int belowenergyHE=0;
1268  unsigned int belowenergyHO=0;
1269  unsigned int belowenergyHF=0;
1270 
1271  unsigned int energyneverpresentHB=0;
1272  unsigned int energyneverpresentHE=0;
1273  unsigned int energyneverpresentHO=0;
1274  unsigned int energyneverpresentHF=0;
1275 
1277  Nevents->Fill(1,deadevt_);
1278 
1279  int etabins=0;
1280  int phibins=0;
1281 
1282  // Store values for number of bad channels in each lumi section, for plots of ProblemsVsLS.
1283  // This is different than the NumBadHB, etc. values, which must included even known bad channels
1284  // in order to calculate reportSummaryByLS values correctly.
1285 
1287  //Check for RBX data loss
1288  unsigned int RBX_loss_HB=0;
1289  unsigned int RBX_loss_HE=0;
1290  unsigned int RBX_loss_HO01=0;
1291  unsigned int RBX_loss_HO2=0;
1292  unsigned int RBX_loss_HF=0;
1293 
1294  unsigned int counter_HB = 0;
1295  unsigned int counter_HE = 0;
1296  unsigned int counter_HO01 = 0;
1297  unsigned int counter_HO2 = 0;
1298  unsigned int counter_HF = 0;
1299 
1300  for(int i=0; i<156; i++)
1301  {
1302  if(occupancy_RBX[i]==0 && is_RBX_loss_ == 1)
1303  {
1304  if(i<=35) //HB
1305  { counter_HB ++ ; RBX_loss_HB = 72*(counter_HB); }
1306  if(i>=36 && i<=71) //HE
1307  { counter_HE ++ ; RBX_loss_HE = 72*(counter_HE); }
1308  if(i>=85 && i<=119) // HO Rings 0, 1
1309  { counter_HO01 ++ ; RBX_loss_HO01 = 72*(counter_HO01); }
1310  if(i>=121 || i<=83) // HO Ring 2
1311  { counter_HO2 ++ ; RBX_loss_HO2 = 72*(counter_HO2); }
1312  if(i>=132 && i<=155) //HF
1313  { counter_HF ++ ; RBX_loss_HF = 72*(counter_HF); }
1314 
1315  if(excludeHO1P02_==true && i==109) NumBadHO1P02 = 72; // exclude HO1P02
1316  }
1317  if(occupancy_RBX[i]>0)
1319  if(occupancy_RBX[i]==0 && is_RBX_loss_ == 1)
1320  RBX_loss_VS_LB->Fill(currentLS, i, 1);
1321  }
1322 
1323  if (deadevt_ >= 10 && deadevt_<minDeadEventCount_) // maybe not enough events to run the standard test
1324  if( is_RBX_loss_ == 1 ) // but enough to detect RBX loss
1325  {
1326  NumBadHB+=RBX_loss_HB;
1327  NumBadHE+=RBX_loss_HE;
1328  NumBadHO+=RBX_loss_HO01+RBX_loss_HO2;
1329  NumBadHO01+=RBX_loss_HO01;
1330  NumBadHO2+=RBX_loss_HO2;
1331  NumBadHF+=RBX_loss_HF;
1332 
1333  belowenergyHB+=RBX_loss_HB;
1334  belowenergyHE+=RBX_loss_HE;
1335  belowenergyHO+=RBX_loss_HO01+RBX_loss_HO2;
1336  belowenergyHF+=RBX_loss_HF;
1337 
1338  unoccupiedHB+=RBX_loss_HB;
1339  unoccupiedHE+=RBX_loss_HE;
1340  unoccupiedHO+=RBX_loss_HO01+RBX_loss_HO2;
1341  unoccupiedHF+=RBX_loss_HF;
1342  }
1344 
1345  for (unsigned int depth=0;depth<DigiPresentByDepth.depth.size();++depth)
1346  {
1347  DigiPresentByDepth.depth[depth]->setBinContent(0,0,ievt_);
1348  etabins=DigiPresentByDepth.depth[depth]->getNbinsX();
1349  phibins=DigiPresentByDepth.depth[depth]->getNbinsY();
1350  for (int eta=0;eta<etabins;++eta)
1351  {
1352  for (int phi=0;phi<phibins;++phi)
1353  {
1354  iphi=phi+1;
1355  for (int subdet=1;subdet<=4;++subdet)
1356  {
1357  ieta=CalcIeta((HcalSubdetector)subdet,eta,depth+1);
1358  if (ieta==-9999) continue;
1359  if (!validDetId((HcalSubdetector)subdet, ieta, iphi, depth+1))
1360  continue;
1361  // Ignore subdetectors that weren't in run?
1362  /*
1363  if ((subdet==HcalBarrel && !HBpresent_) ||
1364  (subdet==HcalEndcap &&!HEpresent_) ||
1365  (subdet==HcalOuter &&!HOpresent_) ||
1366  (subdet==HcalForward &&!HFpresent_)) continue;
1367  */
1368 
1369  /*
1370  if ((!checkHB_ && subdet==HcalBarrel) ||
1371  (!checkHE_ && subdet==HcalEndcap) ||
1372  (!checkHO_ && subdet==HcalOuter) ||
1373  (!checkHF_ && subdet==HcalForward)) continue;
1374  */
1375 
1376  // now check which dead cell tests failed; increment counter if any failed
1377  if ((present_digi[eta][phi][depth]==0) ||
1380  )
1381  {
1382  HcalDetId TempID((HcalSubdetector)subdet, ieta, iphi, (int)depth+1);
1383  if (subdet==HcalBarrel)
1384  {
1385  ++NumBadHB;
1386  if (KnownBadCells_.find(TempID.rawId())!=KnownBadCells_.end())
1387  ++knownBadHB;
1388  }
1389  else if (subdet==HcalEndcap)
1390  {
1391  ++NumBadHE;
1392  if (KnownBadCells_.find(TempID.rawId())!=KnownBadCells_.end())
1393  ++knownBadHE;
1394  }
1395 
1396  else if (subdet==HcalOuter)
1397  {
1398  ++NumBadHO;
1399  if (abs(ieta)<=10) ++NumBadHO01;
1400  else ++NumBadHO2;
1401  // Don't include HORing2 if boolean set; subtract away those counters
1402  if (excludeHORing2_==true && abs(ieta)>10 && isSiPM(ieta,iphi,depth+1)==false)
1403  {
1404  --NumBadHO;
1405  --NumBadHO2;
1406  --NumBadHO12;
1407  }
1408  // Don't include HO1P02 if boolean set, RBX does not repsond well to resets,; subtract away those counters
1409  if (excludeHO1P02_==true && ( (ieta>4 && ieta<10) && (iphi<=10 || iphi>70) ) )
1410  ++NumBadHO1P02;
1411 
1412  if (KnownBadCells_.find(TempID.rawId())!=KnownBadCells_.end())
1413  {
1414  ++knownBadHO;
1415  if (abs(ieta)<=10) ++knownBadHO01;
1416  else ++knownBadHO2;
1417  // Don't include HORing2 if boolean set; subtract away those counters
1418  if (excludeHORing2_==true && abs(ieta)>10 && isSiPM(ieta,iphi,depth+1)==false)
1419  {
1420  --knownBadHO;
1421  --knownBadHO12;
1422  }
1423  }
1424  }
1425  else if (subdet==HcalForward)
1426  {
1427  ++NumBadHF;
1428  if (depth==1 && (abs(ieta)==33 || abs(ieta)==34))
1429  ++NumBadHFLUMI;
1430  else if (depth==2 && (abs(ieta)==35 || abs(ieta)==36))
1431  ++NumBadHFLUMI;
1432  if (KnownBadCells_.find(TempID.rawId())!=KnownBadCells_.end())
1433  {
1434  ++knownBadHF;
1435  if (depth==1 && (abs(ieta)==33 || abs(ieta)==34))
1436  ++knownBadHFLUMI;
1437  else if (depth==2 && (abs(ieta)==35 || abs(ieta)==36))
1438  ++knownBadHFLUMI;
1439  }
1440  }
1441  }
1442  if (present_digi[eta][phi][depth]==0 )
1443  {
1444  if (subdet==HcalBarrel) ++neverpresentHB;
1445  else if (subdet==HcalEndcap) ++neverpresentHE;
1446  else if (subdet==HcalOuter)
1447  {
1448  ++neverpresentHO;
1449  if (excludeHORing2_==true && abs(ieta)>10 && isSiPM(ieta,iphi,depth+1)==false)
1450  --neverpresentHO;
1451  }
1452  else if (subdet==HcalForward) ++neverpresentHF;
1453  }
1454  // Count recent unoccupied digis if the total events in this lumi section is > minEvents_
1456  {
1457  HcalDetId TempID((HcalSubdetector)subdet, ieta, iphi, (int)depth+1);
1458  if (subdet==HcalBarrel) ++unoccupiedHB;
1459  else if (subdet==HcalEndcap) ++unoccupiedHE;
1460  else if (subdet==HcalOuter)
1461  {
1462  ++unoccupiedHO;
1463  if (excludeHORing2_==true && abs(ieta)>10 && isSiPM(ieta,iphi,depth+1)==false)
1464  --unoccupiedHO;
1465  if (KnownBadCells_.find(TempID.rawId())!=KnownBadCells_.end() && abs(ieta)<=10)
1466  --unoccupiedHO;
1467  }
1468  else if (subdet==HcalForward) ++unoccupiedHF;
1469  }
1470  // Look at rechit checks
1472  {
1473  if (present_rechit[eta][phi][depth]==0)
1474  {
1475  if (subdet==HcalBarrel) ++energyneverpresentHB;
1476  else if (subdet==HcalEndcap) ++energyneverpresentHE;
1477  else if (subdet==HcalOuter)
1478  {
1479  ++energyneverpresentHO;
1480  if (excludeHORing2_==true && abs(ieta)>10 && isSiPM(ieta,iphi,depth+1)==false)
1481  --energyneverpresentHO;
1482  }
1483  else if (subdet==HcalForward) ++energyneverpresentHF;
1484  }
1486  {
1487  HcalDetId TempID((HcalSubdetector)subdet, ieta, iphi, (int)depth+1);
1488  if (subdet==HcalBarrel) ++belowenergyHB;
1489  else if (subdet==HcalEndcap) ++belowenergyHE;
1490  else if (subdet==HcalOuter)
1491  {
1492  ++belowenergyHO;
1493  if (excludeHORing2_==true && abs(ieta)>10 && isSiPM(ieta,iphi,depth+1)==false)
1494  --belowenergyHO;
1495  if (KnownBadCells_.find(TempID.rawId())!=KnownBadCells_.end() && abs(ieta)<=10)
1496  --belowenergyHO;
1497  }
1498  else if (subdet==HcalForward) ++belowenergyHF;
1499  }
1500  }
1501  } // subdet loop
1502  } // phi loop
1503  } //eta loop
1504  } // depth loop
1505 
1506  // Fill with number of problem cells found on this pass
1507  NumberOfNeverPresentDigisHB->Fill(currentLS,neverpresentHB);
1508  NumberOfNeverPresentDigisHE->Fill(currentLS,neverpresentHE);
1509  NumberOfNeverPresentDigisHO->Fill(currentLS,neverpresentHO);
1510  NumberOfNeverPresentDigisHF->Fill(currentLS,neverpresentHF);
1511  NumberOfNeverPresentDigis->Fill(currentLS,neverpresentHB+neverpresentHE+neverpresentHO+neverpresentHF);
1512 
1514  {
1515  if( NumBadHB<RBX_loss_HB )
1516  NumBadHB+=RBX_loss_HB;
1517  if( NumBadHE<RBX_loss_HE )
1518  NumBadHE+=RBX_loss_HE;
1519  if( NumBadHO01<RBX_loss_HO01 )
1520  NumBadHO01+=RBX_loss_HO01;
1521  if( NumBadHO2<RBX_loss_HO2 )
1522  NumBadHO2+=RBX_loss_HO2;
1523  if( NumBadHF<RBX_loss_HF )
1524  NumBadHF+=RBX_loss_HF;
1525 
1526  if( belowenergyHB<RBX_loss_HB )
1527  belowenergyHB+=RBX_loss_HB;
1528  if( belowenergyHE<RBX_loss_HE )
1529  belowenergyHE+=RBX_loss_HE;
1530  if( belowenergyHO<RBX_loss_HO01+RBX_loss_HO2)
1531  belowenergyHO+=RBX_loss_HO01+RBX_loss_HO2;
1532  if( belowenergyHF<RBX_loss_HF )
1533  belowenergyHF+=RBX_loss_HF;
1534 
1535  if( unoccupiedHB<RBX_loss_HB )
1536  unoccupiedHB+=RBX_loss_HB;
1537  if( unoccupiedHE<RBX_loss_HE )
1538  unoccupiedHE+=RBX_loss_HE;
1539  if( unoccupiedHO<RBX_loss_HO01+RBX_loss_HO2 )
1540  unoccupiedHO+=RBX_loss_HO01+RBX_loss_HO2;
1541  if( unoccupiedHF<RBX_loss_HF )
1542  unoccupiedHF+=RBX_loss_HF;
1543 
1544  // is_RBX_loss_ = 0;
1545  }
1546 
1547  ProblemsVsLB_HB->Fill(currentLS,NumBadHB-knownBadHB+0.0001); // add a small offset, so that the histograms reset when no errors follow
1548  ProblemsVsLB_HE->Fill(currentLS,NumBadHE-knownBadHE+0.0001); // problematic LSs
1549  ProblemsVsLB_HO->Fill(currentLS,NumBadHO01-knownBadHO01+0.0001);
1550  ProblemsVsLB_HO2->Fill(currentLS,NumBadHO2-knownBadHO2+0.0001);
1551  ProblemsVsLB_HF->Fill(currentLS,NumBadHF-knownBadHF+0.0001);
1552  ProblemsVsLB_HBHEHF->Fill(currentLS,NumBadHB+NumBadHE+NumBadHF-knownBadHB-knownBadHE-knownBadHF+0.0001);
1553  ProblemsVsLB->Fill(currentLS,NumBadHB+NumBadHE+NumBadHO01+NumBadHO2+NumBadHF-knownBadHB-knownBadHE-knownBadHO01-knownBadHO2-knownBadHF+0.0001);
1554 
1555  if(excludeHO1P02_==true)
1557 
1558  if( NumBadHB+NumBadHE+NumBadHF-knownBadHB-knownBadHE-knownBadHF < 30 )
1559  alarmer_counter_ = 0;
1560  if( NumBadHO01-knownBadHO01 < 30 )
1562 
1563  if( alarmer_counter_ >= 10 )
1564  ProblemsInLastNLB_HBHEHF_alarm->Fill( std::min(int(NumBadHB+NumBadHE+NumBadHF-knownBadHB-knownBadHE-knownBadHF), 99) );
1565  if( alarmer_counterHO01_ >= 10 )
1566  ProblemsInLastNLB_HO01_alarm->Fill( std::min(int(NumBadHO01-knownBadHO01), 99) );
1567 
1568  // if (deadevt_<minDeadEventCount_)
1569  // return;
1570 
1571  if (deadmon_test_digis_)
1572  {
1577  NumberOfRecentMissingDigis->Fill(currentLS,unoccupiedHB+unoccupiedHE+unoccupiedHO+unoccupiedHF);
1578  }
1579 
1581  {
1582  NumberOfNeverPresentRecHitsHB->Fill(currentLS,energyneverpresentHB);
1583  NumberOfNeverPresentRecHitsHE->Fill(currentLS,energyneverpresentHE);
1584  NumberOfNeverPresentRecHitsHO->Fill(currentLS,energyneverpresentHO);
1585  NumberOfNeverPresentRecHitsHF->Fill(currentLS,energyneverpresentHF);
1586  NumberOfNeverPresentRecHits->Fill(currentLS,energyneverpresentHB+energyneverpresentHE+energyneverpresentHO+energyneverpresentHF);
1587 
1592  NumberOfRecentMissingRecHits->Fill(currentLS,belowenergyHB+belowenergyHE+belowenergyHO+belowenergyHF);
1593  }
1594 
1595  return;
1596 } // void HcalDeadCellMonitor::fillNevents_problemCells(void)
int i
Definition: DBlmapReader.cc:9
MonitorElement * NumberOfNeverPresentRecHitsHO
MonitorElement * NumberOfRecentMissingRecHitsHF
MonitorElement * NumberOfNeverPresentRecHits
MonitorElement * NumberOfNeverPresentDigisHB
MonitorElement * NumberOfRecentMissingRecHits
bool present_digi[85][72][4]
MonitorElement * NumberOfNeverPresentDigisHE
std::map< unsigned int, int > KnownBadCells_
#define abs(x)
Definition: mlp_lapack.h:159
MonitorElement * NumberOfRecentMissingDigisHB
#define min(a, b)
Definition: mlp_lapack.h:161
T eta() const
MonitorElement * ProblemsInLastNLB_HO01_alarm
MonitorElement * NumberOfRecentMissingDigisHE
bool present_rechit[85][72][4]
void Fill(long long x)
bool isSiPM(int ieta, int iphi, int depth)
MonitorElement * RBX_loss_VS_LB
std::vector< MonitorElement * > depth
int CalcIeta(int subdet, int eta, int depth)
MonitorElement * ProblemsVsLB
MonitorElement * NumberOfNeverPresentDigisHF
MonitorElement * ProblemsVsLB_HBHEHF
unsigned int occupancy_RBX[156]
MonitorElement * NumberOfNeverPresentDigisHO
MonitorElement * NumberOfNeverPresentRecHitsHB
HcalSubdetector
Definition: HcalAssistant.h:32
MonitorElement * Nevents
unsigned int recentoccupancy_rechit[85][72][4]
MonitorElement * NumberOfRecentMissingRecHitsHE
MonitorElement * ProblemsVsLB_HF
MonitorElement * NumberOfRecentMissingDigisHO
MonitorElement * NumberOfNeverPresentRecHitsHF
MonitorElement * ProblemsVsLB_HB
unsigned int recentoccupancy_digi[85][72][4]
MonitorElement * NumberOfRecentMissingRecHitsHO
EtaPhiHists DigiPresentByDepth
MonitorElement * NumberOfNeverPresentRecHitsHE
MonitorElement * ProblemsVsLB_HE
MonitorElement * NumberOfNeverPresentDigis
MonitorElement * NumberOfRecentMissingDigis
MonitorElement * NumberOfRecentMissingDigisHF
tuple cout
Definition: gather_cfg.py:121
MonitorElement * ProblemsInLastNLB_HBHEHF_alarm
MonitorElement * ProblemsVsLB_HO2
bool validDetId(HcalSubdetector sd, int ies, int ip, int dp)
MonitorElement * NumberOfRecentMissingRecHitsHB
MonitorElement * ProblemsVsLB_HO
Definition: DDAxes.h:10
void HcalDeadCellMonitor::fillNevents_recentdigis ( )
private

Definition at line 1007 of file HcalDeadCellMonitor.cc.

References abs, HcalObjRepresent::CalcIeta(), gather_cfg::cout, deadevt_, deadmon_test_digis_, HcalBaseDQMonitor::debug_, EtaPhiHists::depth, eta(), excludeHORing2_, HcalObjRepresent::FillUnphysicalHEHFBins(), HcalLogicalMap::getHcalFrontEndId(), HcalForward, HcalBaseDQMonitor::ievt_, getHLTprescales::index, is_RBX_loss_, isSiPM(), logicalMap_, minDeadEventCount_, occupancy_RBX, phi, present_digi, HcalFrontEndId::rbxIndex(), RecentMissingDigisByDepth, recentoccupancy_digi, and validDetId().

Referenced by endLuminosityBlock().

1008 {
1009  // Fill Histograms showing digi cells with no occupancy for the past few lumiblocks
1010  if (!deadmon_test_digis_) return; // extra protection here against calling histograms than don't exist
1011 
1012  if (debug_>0)
1013  std::cout <<"<HcalDeadCellMonitor::fillNevents_recentdigis> CHECKING FOR RECENT MISSING DIGIS evtcount = "<<deadevt_<<std::endl;
1014 
1015  int ieta=0;
1016  int iphi=0;
1017 
1018  int etabins=0;
1019  int phibins=0;
1020 
1022  if ((deadevt_ >= 10 && deadevt_<minDeadEventCount_) || (deadevt_ >= 10 && is_RBX_loss_==1)) // maybe not enough events to run the standard test
1023  // if( is_RBX_loss_ == 1 ) // but enough to detect RBX loss
1024  for (unsigned int depth=0;depth<RecentMissingDigisByDepth.depth.size();++depth)
1025  {
1026  RecentMissingDigisByDepth.depth[depth]->setBinContent(0,0,ievt_);
1027  etabins=RecentMissingDigisByDepth.depth[depth]->getNbinsX();
1028  phibins=RecentMissingDigisByDepth.depth[depth]->getNbinsY();
1029  for (int eta=0;eta<etabins;++eta)
1030  for (int phi=0;phi<phibins;++phi)
1031  {
1032  iphi=phi+1;
1033  for (int subdet=1;subdet<=4;++subdet)
1034  {
1035  ieta=CalcIeta((HcalSubdetector)subdet,eta,depth+1);
1036  if (ieta==-9999) continue;
1037  if (!validDetId((HcalSubdetector)subdet, ieta, iphi, depth+1))
1038  continue;
1039  // now check which dead cell tests failed; increment counter if any failed
1040  HcalDetId TempID((HcalSubdetector)subdet, ieta, iphi, (int)depth+1);
1041 
1042  int index = logicalMap_->getHcalFrontEndId(TempID).rbxIndex();
1043  // if(subdet==HcalForward) continue;
1044 
1045  if(occupancy_RBX[index]==0)
1046  {
1047  recentoccupancy_digi[eta][phi][depth] = 0;
1048  RecentMissingDigisByDepth.depth[depth]->Fill(ieta,iphi,deadevt_);
1049  }
1050  }
1051  }
1052  }
1054 
1055  if (deadevt_ < minDeadEventCount_) return; // not enough entries to make a determination for this LS
1056 
1057  for (unsigned int depth=0;depth<RecentMissingDigisByDepth.depth.size();++depth)
1058  {
1059  RecentMissingDigisByDepth.depth[depth]->setBinContent(0,0,ievt_);
1060  etabins=RecentMissingDigisByDepth.depth[depth]->getNbinsX();
1061  phibins=RecentMissingDigisByDepth.depth[depth]->getNbinsY();
1062  for (int eta=0;eta<etabins;++eta)
1063  {
1064  for (int subdet=1;subdet<=4;++subdet)
1065  {
1066  ieta=CalcIeta((HcalSubdetector)subdet,eta,depth+1);
1067  if (ieta==-9999) continue;
1068  for (int phi=0;phi<phibins;++phi)
1069  {
1070  iphi=phi+1;
1071 
1072  if (!validDetId((HcalSubdetector)subdet, ieta, iphi, depth+1))
1073  continue;
1074 
1075  // Ignore subdetectors that weren't in run?
1076  /*
1077  if ((subdet==HcalBarrel && !HBpresent_) ||
1078  (subdet==HcalEndcap &&!HEpresent_) ||
1079  (subdet==HcalOuter &&!HOpresent_) ||
1080  (subdet==HcalForward &&!HFpresent_)) continue;
1081  */
1082  int zside=0;
1083  if (subdet==HcalForward) // shift HcalForward ieta
1084  ieta<0 ? zside=-1 : zside=+1;
1085 
1086  if (recentoccupancy_digi[eta][phi][depth]==0)
1087  {
1088  if (debug_>0)
1089  {
1090  std::cout <<"DEAD CELL; NO RECENT OCCUPANCY: subdet = "<<subdet<<", ieta = "<<ieta<<", iphi = "<<iphi<<" depth = "<<depth+1<<std::endl;
1091  std::cout <<"\t RAW COORDINATES: eta = "<<eta<< " phi = "<<phi<<" depth = "<<depth<<std::endl;
1092  std::cout <<"\t Present? "<<present_digi[eta][phi][depth]<<std::endl;
1093  }
1094 
1095  // Don't fill HORing2 if boolean enabled
1096  if (excludeHORing2_==true && abs(ieta)>10 && isSiPM(ieta,iphi,depth+1)==false)
1097  continue;
1098 
1099  // no digi was found for the N events; Fill cell as bad for all N events (N = checkN);
1100  if (RecentMissingDigisByDepth.depth[depth]) RecentMissingDigisByDepth.depth[depth]->Fill(ieta+zside,iphi,deadevt_);
1101  }
1102  } // for (int subdet=1;subdet<=4;++subdet)
1103  } // for (int phi=0;...)
1104  } // for (int eta=0;...)
1105  } //for (int depth=1;...)
1107 
1108  return;
1109 
1110 } // void HcalDeadCellMonitor::fillNevents_recentdigis()
bool present_digi[85][72][4]
#define abs(x)
Definition: mlp_lapack.h:159
T eta() const
bool isSiPM(int ieta, int iphi, int depth)
std::vector< MonitorElement * > depth
int CalcIeta(int subdet, int eta, int depth)
unsigned int occupancy_RBX[156]
HcalSubdetector
Definition: HcalAssistant.h:32
const HcalFrontEndId getHcalFrontEndId(const DetId &)
unsigned int recentoccupancy_digi[85][72][4]
EtaPhiHists RecentMissingDigisByDepth
int rbxIndex() const
void FillUnphysicalHEHFBins(std::vector< TH2F > &hh)
tuple cout
Definition: gather_cfg.py:121
HcalLogicalMap * logicalMap_
bool validDetId(HcalSubdetector sd, int ies, int ip, int dp)
Definition: DDAxes.h:10
void HcalDeadCellMonitor::fillNevents_recentrechits ( )
private

Definition at line 1116 of file HcalDeadCellMonitor.cc.

References abs, HcalObjRepresent::CalcIeta(), gather_cfg::cout, deadevt_, deadmon_test_rechits_, HcalBaseDQMonitor::debug_, EtaPhiHists::depth, eta(), excludeHORing2_, HcalObjRepresent::FillUnphysicalHEHFBins(), HcalLogicalMap::getHcalFrontEndId(), HcalForward, HcalBaseDQMonitor::ievt_, getHLTprescales::index, is_RBX_loss_, isSiPM(), logicalMap_, minDeadEventCount_, occupancy_RBX, phi, HcalFrontEndId::rbxIndex(), RecentMissingRecHitsByDepth, recentoccupancy_rechit, RecHitPresentByDepth, and validDetId().

Referenced by endLuminosityBlock().

1117 {
1118  // Fill Histograms showing unoccupied rechits, or rec hits with low energy
1119 
1120  // This test is a bit pointless, unless the energy threshold is greater than the ZS threshold.
1121  // If we require that cells are always < thresh to be flagged by this test, and if
1122  // thresh < ZS, then we will never catch any cells, since they'll show up as dead in the
1123  // neverpresent/occupancy test plots first.
1124  // Only exception is if something strange is going on between ZS ADC value an RecHit energy?
1125 
1126  if (!deadmon_test_rechits_) return;
1128 
1129  if (debug_>0)
1130  std::cout <<"<HcalDeadCellMonitor::fillNevents_energy> BELOW-ENERGY-THRESHOLD PLOTS"<<std::endl;
1131 
1132  int ieta=0;
1133  int iphi=0;
1134 
1135  int etabins=0;
1136  int phibins=0;
1137 
1139  if ((deadevt_ >= 10 && deadevt_<minDeadEventCount_) || (deadevt_ >= 10 && is_RBX_loss_==1)) // maybe not enough events to run the standard test
1140  // if( is_RBX_loss_ == 1 ) // but enough to detect RBX loss
1141  for (unsigned int depth=0;depth<RecentMissingRecHitsByDepth.depth.size();++depth)
1142  {
1143  RecentMissingRecHitsByDepth.depth[depth]->setBinContent(0,0,ievt_);
1144  etabins=RecentMissingRecHitsByDepth.depth[depth]->getNbinsX();
1145  phibins=RecentMissingRecHitsByDepth.depth[depth]->getNbinsY();
1146  for (int eta=0;eta<etabins;++eta)
1147  for (int phi=0;phi<phibins;++phi)
1148  {
1149  iphi=phi+1;
1150  for (int subdet=1;subdet<=4;++subdet)
1151  {
1152  ieta=CalcIeta((HcalSubdetector)subdet,eta,depth+1);
1153  if (ieta==-9999) continue;
1154  if (!validDetId((HcalSubdetector)subdet, ieta, iphi, depth+1))
1155  continue;
1156  // now check which dead cell tests failed; increment counter if any failed
1157  HcalDetId TempID((HcalSubdetector)subdet, ieta, iphi, (int)depth+1);
1158 
1159  int index = logicalMap_->getHcalFrontEndId(TempID).rbxIndex();
1160  // if(subdet==HcalForward) continue;
1161 
1162  if(occupancy_RBX[index]==0)
1163  {
1164  recentoccupancy_rechit[eta][phi][depth] = 0;
1165  RecentMissingRecHitsByDepth.depth[depth]->Fill(ieta,iphi,deadevt_);
1166  }
1167  }
1168  }
1169  }
1171 
1172  if (deadevt_ < minDeadEventCount_) return; // not enough entries to make a determination for this LS
1173 
1174  for (unsigned int depth=0;depth<RecentMissingRecHitsByDepth.depth.size();++depth)
1175  {
1176  RecentMissingRecHitsByDepth.depth[depth]->setBinContent(0,0,ievt_);
1177  etabins=RecentMissingRecHitsByDepth.depth[depth]->getNbinsX();
1178  phibins=RecentMissingRecHitsByDepth.depth[depth]->getNbinsY();
1179  for (int eta=0;eta<etabins;++eta)
1180  {
1181  for (int subdet=1;subdet<=4;++subdet)
1182  {
1183  ieta=CalcIeta((HcalSubdetector)subdet,eta,depth+1);
1184  if (ieta==-9999) continue;
1185  for (int phi=0;phi<phibins;++phi)
1186  {
1187  iphi=phi+1;
1188  if (!validDetId((HcalSubdetector)subdet, ieta, iphi, depth+1))
1189  continue;
1190 
1191  if (recentoccupancy_rechit[eta][phi][depth]>0) continue; // cell exceeded energy at least once, so it's not dead
1192 
1193  // Ignore subdetectors that weren't in run?
1194  /*
1195  if ((subdet==HcalBarrel && !HBpresent_) ||
1196  (subdet==HcalEndcap &&!HEpresent_) ||
1197  (subdet==HcalOuter &&!HOpresent_) ||
1198  (subdet==HcalForward &&!HFpresent_)) continue;
1199  */
1200 
1201  int zside=0;
1202  if (subdet==HcalForward) // shift HcalForward ieta
1203  {
1204  ieta<0 ? zside=-1 : zside=+1;
1205  }
1206 
1207  if (debug_>2)
1208  std::cout <<"DEAD CELL; BELOW ENERGY THRESHOLD; subdet = "<<subdet<<" ieta = "<<ieta<<", phi = "<<iphi<<" depth = "<<depth+1<<std::endl;
1209  if (excludeHORing2_==true && abs(ieta)>10 && isSiPM(ieta,iphi,depth+1)==false)
1210  continue;
1211 
1212  if (RecentMissingRecHitsByDepth.depth[depth]) RecentMissingRecHitsByDepth.depth[depth]->Fill(ieta+zside,iphi,deadevt_);
1213  } // loop on phi bins
1214  } // for (unsigned int depth=1;depth<=4;++depth)
1215  } // // loop on subdetectors
1216  } // for (int eta=0;...)
1217 
1219 
1220  return;
1221 } // void HcalDeadCellMonitor::fillNevents_recentrechits()
#define abs(x)
Definition: mlp_lapack.h:159
T eta() const
bool isSiPM(int ieta, int iphi, int depth)
EtaPhiHists RecHitPresentByDepth
std::vector< MonitorElement * > depth
int CalcIeta(int subdet, int eta, int depth)
unsigned int occupancy_RBX[156]
HcalSubdetector
Definition: HcalAssistant.h:32
unsigned int recentoccupancy_rechit[85][72][4]
const HcalFrontEndId getHcalFrontEndId(const DetId &)
int rbxIndex() const
void FillUnphysicalHEHFBins(std::vector< TH2F > &hh)
EtaPhiHists RecentMissingRecHitsByDepth
tuple cout
Definition: gather_cfg.py:121
HcalLogicalMap * logicalMap_
bool validDetId(HcalSubdetector sd, int ies, int ip, int dp)
Definition: DDAxes.h:10
template<class T >
void HcalDeadCellMonitor::process_Digi ( T digi)
private
template<class DIGI >
void HcalDeadCellMonitor::process_Digi ( DIGI &  digi)

Definition at line 906 of file HcalDeadCellMonitor.cc.

References CalcEtaBin(), EtaPhiHists::depth, DigiPresentByDepth, present_digi, and recentoccupancy_digi.

907 {
908  // Remove the validate check when we figure out how to access bad digis in digi monitor
909  //if (!digi.validate()) return; // digi must be good to be counted
910  int ieta=digi.id().ieta();
911  int iphi=digi.id().iphi();
912  int depth=digi.id().depth();
913 
914  // Fill occupancy counter
915  ++recentoccupancy_digi[CalcEtaBin(digi.id().subdet(),ieta,depth)][iphi-1][depth-1];
916 
917  // If previously-missing digi found, change boolean status and fill histogram
918  if (present_digi[CalcEtaBin(digi.id().subdet(),ieta,depth)][iphi-1][depth-1]==false)
919  {
920  if (DigiPresentByDepth.depth[depth-1])
921  {
922  DigiPresentByDepth.depth[depth-1]->setBinContent(CalcEtaBin(digi.id().subdet(),ieta,depth)+1,iphi,1);
923  }
924  present_digi[CalcEtaBin(digi.id().subdet(),ieta,depth)][iphi-1][depth-1]=true;
925  }
926  return;
927 }
bool present_digi[85][72][4]
std::vector< MonitorElement * > depth
unsigned int recentoccupancy_digi[85][72][4]
EtaPhiHists DigiPresentByDepth
int CalcEtaBin(int subdet, int ieta, int depth)
template<class T >
void HcalDeadCellMonitor::process_RecHit ( T rechit)
private

Referenced by processEvent().

template<class RECHIT >
void HcalDeadCellMonitor::process_RecHit ( RECHIT &  rechit)

Definition at line 932 of file HcalDeadCellMonitor.cc.

References CalcEtaBin(), EtaPhiHists::depth, HcalLogicalMap::getHcalFrontEndId(), HBenergyThreshold_, HcalBarrel, HcalEndcap, HcalForward, HcalOuter, HEenergyThreshold_, HFenergyThreshold_, HOenergyThreshold_, errorMatrix2Lands_multiChannel::id, logicalMap_, occupancy_RBX, present_rechit, recentoccupancy_rechit, and RecHitPresentByDepth.

933 {
934  float en = rechit->energy();
935  HcalDetId id(rechit->detid().rawId());
936  int ieta = id.ieta();
937  int iphi = id.iphi();
938  int depth = id.depth();
939 
940  if (id.subdet()==HcalBarrel)
941  {
942  if (en>=HBenergyThreshold_)
943  {
944  ++recentoccupancy_rechit[CalcEtaBin(id.subdet(),ieta,depth)][iphi-1][depth-1];
945  present_rechit[CalcEtaBin(id.subdet(),ieta,depth)][iphi-1][depth-1]=true;
946  if (RecHitPresentByDepth.depth[depth-1])
947  RecHitPresentByDepth.depth[depth-1]->setBinContent(CalcEtaBin(id.subdet(),ieta,depth)+1,iphi,1);
948  }
950  // RBX index, HB RBX indices are 0-35
951  int RBXindex = logicalMap_->getHcalFrontEndId(rechit->detid()).rbxIndex();
952 
953  occupancy_RBX[RBXindex]++;
955  }
956  else if (id.subdet()==HcalEndcap)
957  {
958  if (en>=HEenergyThreshold_)
959  {
960  ++recentoccupancy_rechit[CalcEtaBin(id.subdet(),ieta,depth)][iphi-1][depth-1];
961  present_rechit[CalcEtaBin(id.subdet(),ieta,depth)][iphi-1][depth-1]=true;
962  if (RecHitPresentByDepth.depth[depth-1])
963  RecHitPresentByDepth.depth[depth-1]->setBinContent(CalcEtaBin(id.subdet(),ieta,depth)+1,iphi,1);
964  }
966  // RBX index, HE RBX indices are 36-71
967  int RBXindex = logicalMap_->getHcalFrontEndId(rechit->detid()).rbxIndex();
968 
969  occupancy_RBX[RBXindex]++;
971  }
972  else if (id.subdet()==HcalForward)
973  {
974  if (en>=HFenergyThreshold_)
975  {
976  ++recentoccupancy_rechit[CalcEtaBin(id.subdet(),ieta,depth)][iphi-1][depth-1];
977 
978  present_rechit[CalcEtaBin(id.subdet(),ieta,depth)][iphi-1][depth-1]=true;
979  if (RecHitPresentByDepth.depth[depth-1])
980  RecHitPresentByDepth.depth[depth-1]->setBinContent(CalcEtaBin(id.subdet(),ieta,depth)+1,iphi,1);
981  }
983  // RBX index, HF RBX indices are 132-155
984  int RBXindex = logicalMap_->getHcalFrontEndId(rechit->detid()).rbxIndex();
985 
986  occupancy_RBX[RBXindex]++;
988  }
989  else if (id.subdet()==HcalOuter)
990  {
991  if (en>=HOenergyThreshold_)
992  {
993  ++recentoccupancy_rechit[CalcEtaBin(id.subdet(),ieta,depth)][iphi-1][depth-1];
994  present_rechit[CalcEtaBin(id.subdet(),ieta,depth)][iphi-1][depth-1]=true;
995  if (RecHitPresentByDepth.depth[depth-1])
996  RecHitPresentByDepth.depth[depth-1]->setBinContent(CalcEtaBin(id.subdet(),ieta,depth)+1,iphi,1);
997  }
999  // RBX index, HO RBX indices are 73-95 (odd), 96-107 (all), 108-119 (odd), 120-130 (EXCL), 131
1000  int RBXindex = logicalMap_->getHcalFrontEndId(rechit->detid()).rbxIndex();
1001 
1002  occupancy_RBX[RBXindex]++;
1004  }
1005 }
bool present_rechit[85][72][4]
EtaPhiHists RecHitPresentByDepth
std::vector< MonitorElement * > depth
unsigned int occupancy_RBX[156]
unsigned int recentoccupancy_rechit[85][72][4]
const HcalFrontEndId getHcalFrontEndId(const DetId &)
int CalcEtaBin(int subdet, int ieta, int depth)
HcalLogicalMap * logicalMap_
void HcalDeadCellMonitor::processEvent ( const HBHERecHitCollection hbHits,
const HORecHitCollection hoHits,
const HFRecHitCollection hfHits,
const HBHEDigiCollection hbhedigi,
const HODigiCollection hodigi,
const HFDigiCollection hfdigi 
)

Definition at line 769 of file HcalDeadCellMonitor.cc.

References abs, edm::SortedCollection< T, SORT >::begin(), binmapd2, gather_cfg::cout, deadmon_test_digis_, deadmon_test_rechits_, HcalBaseDQMonitor::debug_, EtaPhiHists::depth, DigiPresentByDepth, edm::SortedCollection< T, SORT >::end(), eta(), MonitorElement::Fill(), HcalObjRepresent::FillUnphysicalHEHFBins(), HBDeadVsEvent, HEDeadVsEvent, HFDeadVsEvent, HODeadVsEvent, i, j, gen::k, HcalBaseDQMonitor::makeDiagnostics_, HcalBaseDQMonitor::NLumiBlocks_, NumberOfNeverPresentDigis, NumberOfNeverPresentDigisHB, NumberOfNeverPresentDigisHE, NumberOfNeverPresentDigisHF, NumberOfNeverPresentDigisHO, NumberOfRecentMissingDigis, NumberOfRecentMissingDigisHB, NumberOfRecentMissingDigisHE, NumberOfRecentMissingDigisHF, NumberOfRecentMissingDigisHO, NumberOfRecentMissingRecHits, NumberOfRecentMissingRecHitsHB, NumberOfRecentMissingRecHitsHE, NumberOfRecentMissingRecHitsHF, NumberOfRecentMissingRecHitsHO, phi, present_digi, process_Digi(), process_RecHit(), processEvent_HBHEdigi(), RecentMissingDigisByDepth, RecentMissingRecHitsByDepth, HcalBaseDQMonitor::tevt_, and MonitorElement::update().

Referenced by analyze().

775 {
776  if (debug_>1) std::cout <<"<HcalDeadCellMonitor::processEvent> Processing event..."<<std::endl;
777 
778  // Do Digi-Based dead cell searches
779 
780  // Make sure histograms update
781  for (unsigned int i=0;i<DigiPresentByDepth.depth.size();++i)
782  DigiPresentByDepth.depth[i]->update();
783 
789 
791  {
792 
793  for (unsigned int i=0;i<RecentMissingDigisByDepth.depth.size();++i)
794  RecentMissingDigisByDepth.depth[i]->update();
795 
801  }
802 
804  j!=hbhedigi.end(); ++j)
805  {
806  const HBHEDataFrame digi = (const HBHEDataFrame)(*j);
807  processEvent_HBHEdigi(digi);
808  }
809 
811  j!=hodigi.end(); ++j)
812  {
813  const HODataFrame digi = (const HODataFrame)(*j);
814  process_Digi(digi);
815  }
817  j!=hfdigi.end(); ++j)
818  {
819  const HFDataFrame digi = (const HFDataFrame)(*j);
820  process_Digi(digi);
821  }
823 
824  // Search for "dead" cells below a certain energy
826  {
827  // Normalization Fill
828  for (unsigned int i=0;i<RecentMissingRecHitsByDepth.depth.size();++i)
830 
836 
838  j!=hbHits.end(); ++j)
839  process_RecHit(j);
840 
842  k!=hoHits.end(); ++k)
843  process_RecHit(k);
844 
846  j!=hfHits.end(); ++j)
847  process_RecHit(j);
848 
849  } // if (deadmon_test_rechits)
850 
851  if (!makeDiagnostics_) return;
852  if (tevt_>=NLumiBlocks_) return;
853  // Diagnostic plots -- add number of missing channels vs event number
854  int hbpresent=0;
855  int hepresent=0;
856  int hopresent=0;
857  int hfpresent=0;
858  int ieta=0;
859  for (int d=0;d<4;++d)
860  {
861  for (int phi=0;phi<72;++phi)
862  {
863  for (int eta=0;eta<85;++eta)
864  {
865  if (!present_digi[eta][phi][d]) continue;
866  if (d==3) ++hopresent;
867  else if (d==2) ++hepresent;
868  else if (d==1)
869  {
870  ieta=binmapd2[eta];
871  //if (abs(ieta)>29) continue;
872  if (abs(ieta)>29) ++hfpresent;
873  else if (abs(ieta)<17) ++hbpresent; //depths 15&16
874  else ++hepresent;
875  }
876  else if (d==0)
877  {
878  ieta=eta-42;
879  if (abs(ieta)>29) ++hfpresent;
880  else if (abs(ieta)<17) ++hbpresent;
881  else ++hepresent;
882  }
883  }
884  }
885  } // for (int d=0;d<4;++d)
886  HBDeadVsEvent->Fill(tevt_,2592-hbpresent);
887  HEDeadVsEvent->Fill(tevt_,2592-hepresent);
888  HODeadVsEvent->Fill(tevt_,2160-hopresent);
889  HFDeadVsEvent->Fill(tevt_,1728-hfpresent);
890  return;
891 } // void HcalDeadCellMonitor::processEvent(...)
int i
Definition: DBlmapReader.cc:9
MonitorElement * NumberOfRecentMissingRecHitsHF
MonitorElement * NumberOfNeverPresentDigisHB
const int binmapd2[]
MonitorElement * HEDeadVsEvent
MonitorElement * NumberOfRecentMissingRecHits
bool present_digi[85][72][4]
MonitorElement * NumberOfNeverPresentDigisHE
std::vector< T >::const_iterator const_iterator
#define abs(x)
Definition: mlp_lapack.h:159
MonitorElement * NumberOfRecentMissingDigisHB
void update(void)
Mark the object updated.
void process_RecHit(T &rechit)
T eta() const
MonitorElement * NumberOfRecentMissingDigisHE
void Fill(long long x)
std::vector< MonitorElement * > depth
MonitorElement * NumberOfNeverPresentDigisHF
MonitorElement * NumberOfNeverPresentDigisHO
void processEvent_HBHEdigi(const HBHEDataFrame digi)
int j
Definition: DBlmapReader.cc:9
MonitorElement * NumberOfRecentMissingRecHitsHE
MonitorElement * NumberOfRecentMissingDigisHO
int k[5][pyjets_maxn]
const_iterator end() const
EtaPhiHists RecentMissingDigisByDepth
MonitorElement * NumberOfRecentMissingRecHitsHO
EtaPhiHists DigiPresentByDepth
void FillUnphysicalHEHFBins(std::vector< TH2F > &hh)
EtaPhiHists RecentMissingRecHitsByDepth
MonitorElement * HBDeadVsEvent
MonitorElement * NumberOfNeverPresentDigis
MonitorElement * NumberOfRecentMissingDigis
MonitorElement * NumberOfRecentMissingDigisHF
tuple cout
Definition: gather_cfg.py:121
void process_Digi(T &digi)
MonitorElement * HFDeadVsEvent
MonitorElement * HODeadVsEvent
const_iterator begin() const
MonitorElement * NumberOfRecentMissingRecHitsHB
Definition: DDAxes.h:10
void HcalDeadCellMonitor::processEvent_HBHEdigi ( const HBHEDataFrame  digi)
private

Definition at line 898 of file HcalDeadCellMonitor.cc.

References process_Digi().

Referenced by processEvent().

899 {
900  // Simply check whether a digi is present. If so, increment occupancy counter.
901  process_Digi(digi);
902  return;
903 } //void HcalDeadCellMonitor::processEvent_HBHEdigi(HBHEDigiCollection::const_iterator j)
void process_Digi(T &digi)
void HcalDeadCellMonitor::reset ( void  )
virtual

Reimplemented from HcalBaseDQMonitor.

Definition at line 406 of file HcalDeadCellMonitor.cc.

References alarmer_counter_, alarmer_counterHO01_, beamMode_, gather_cfg::cout, deadevt_, deadmon_test_digis_, deadmon_test_rechits_, HcalBaseDQMonitor::debug_, EtaPhiHists::depth, DigiPresentByDepth, doReset_, excludeHORing2_, HcalObjRepresent::FillUnphysicalHEHFBins(), hbhedcsON, hfdcsON, hodcsON, is_RBX_loss_, is_stable_beam, isSiPM(), Nevents, NumberOfNeverPresentDigis, NumberOfNeverPresentDigisHB, NumberOfNeverPresentDigisHE, NumberOfNeverPresentDigisHF, NumberOfNeverPresentDigisHO, NumberOfNeverPresentRecHits, NumberOfNeverPresentRecHitsHB, NumberOfNeverPresentRecHitsHE, NumberOfNeverPresentRecHitsHF, NumberOfNeverPresentRecHitsHO, NumberOfRecentMissingDigis, NumberOfRecentMissingDigisHB, NumberOfRecentMissingDigisHE, NumberOfRecentMissingDigisHF, NumberOfRecentMissingDigisHO, NumberOfRecentMissingRecHits, NumberOfRecentMissingRecHitsHB, NumberOfRecentMissingRecHitsHE, NumberOfRecentMissingRecHitsHF, NumberOfRecentMissingRecHitsHO, ProblemsInLastNLB_HBHEHF_alarm, ProblemsInLastNLB_HO01_alarm, ProblemsVsLB, ProblemsVsLB_HB, HcalBaseDQMonitor::ProblemsVsLB_HBHEHF, ProblemsVsLB_HE, ProblemsVsLB_HF, ProblemsVsLB_HO, ProblemsVsLB_HO2, RBX_loss_VS_LB, RecentMissingDigisByDepth, RecentMissingRecHitsByDepth, RecHitPresentByDepth, HcalBaseDQMonitor::reset(), MonitorElement::Reset(), EtaPhiHists::Reset(), and zeroCounters().

Referenced by analyze(), beginRun(), and setup().

407 {
408  if (debug_>1) std::cout <<"HcalDeadCellMonitor::reset()"<<std::endl;
409  doReset_ = false;
410 
412  zeroCounters();
413  deadevt_=0;
414  is_RBX_loss_ = 0;
415  beamMode_ = 0 ;
416  alarmer_counter_ = 0;
418  is_stable_beam = true;
419  hbhedcsON = true; hfdcsON = true; hodcsON = true;
425 
426  for (unsigned int depth=0;depth<DigiPresentByDepth.depth.size();++depth)
427  DigiPresentByDepth.depth[depth]->Reset();
428 
429  // Mark HORing2 channels as present (fill with a 2, rather than a 1, to distinguish between this setting and actual presence)
430  if (excludeHORing2_==true && DigiPresentByDepth.depth.size()>3)
431  {
432  for (int ieta=11;ieta<=15;++ieta)
433  for (int iphi=1;iphi<=72;++iphi)
434  {
435  // Don't fill ring2 SiPMs, since they will still be active even if the rest of HO is excluded.
436  if (isSiPM(ieta,iphi,4)==false)
437  DigiPresentByDepth.depth[3]->Fill(ieta,iphi,2);
438  //std::cout <<" FILLING ("<<-1*ieta<<", "<<iphi<<") with '2'"<<std::endl;
439  DigiPresentByDepth.depth[3]->Fill(-1*ieta,iphi,2);
440  }
441  }
443 
444 
446  {
449  }
451  {
464 
465  // Mark HORing2 channels as present (fill with a 2, rather than a 1, to distinguish between this setting and actual presence)
466  if (excludeHORing2_==true && RecHitPresentByDepth.depth.size()>3)
467  {
468  for (int ieta=11;ieta<=15;++ieta)
469  for (int iphi=1;iphi<=72;++iphi)
470  {
471  RecHitPresentByDepth.depth[3]->Fill(ieta,iphi,2);
472  RecHitPresentByDepth.depth[3]->Fill(-1*ieta,iphi,2);
473  }
474  }
476  }
477 
478  Nevents->Reset();
479 } // reset function is empty for now
MonitorElement * NumberOfNeverPresentRecHitsHO
MonitorElement * NumberOfRecentMissingRecHitsHF
MonitorElement * NumberOfNeverPresentRecHits
MonitorElement * NumberOfNeverPresentDigisHB
MonitorElement * NumberOfRecentMissingRecHits
void zeroCounters(bool resetpresent=false)
MonitorElement * NumberOfNeverPresentDigisHE
void Reset(void)
MonitorElement * NumberOfRecentMissingDigisHB
MonitorElement * ProblemsInLastNLB_HO01_alarm
MonitorElement * NumberOfRecentMissingDigisHE
bool isSiPM(int ieta, int iphi, int depth)
EtaPhiHists RecHitPresentByDepth
MonitorElement * RBX_loss_VS_LB
std::vector< MonitorElement * > depth
MonitorElement * ProblemsVsLB
MonitorElement * NumberOfNeverPresentDigisHF
MonitorElement * ProblemsVsLB_HBHEHF
MonitorElement * NumberOfNeverPresentDigisHO
MonitorElement * NumberOfNeverPresentRecHitsHB
MonitorElement * Nevents
MonitorElement * NumberOfRecentMissingRecHitsHE
MonitorElement * ProblemsVsLB_HF
MonitorElement * NumberOfRecentMissingDigisHO
MonitorElement * NumberOfNeverPresentRecHitsHF
MonitorElement * ProblemsVsLB_HB
EtaPhiHists RecentMissingDigisByDepth
MonitorElement * NumberOfRecentMissingRecHitsHO
EtaPhiHists DigiPresentByDepth
virtual void reset(void)
void FillUnphysicalHEHFBins(std::vector< TH2F > &hh)
EtaPhiHists RecentMissingRecHitsByDepth
MonitorElement * NumberOfNeverPresentRecHitsHE
MonitorElement * ProblemsVsLB_HE
MonitorElement * NumberOfNeverPresentDigis
MonitorElement * NumberOfRecentMissingDigis
MonitorElement * NumberOfRecentMissingDigisHF
tuple cout
Definition: gather_cfg.py:121
MonitorElement * ProblemsInLastNLB_HBHEHF_alarm
void Reset(void)
reset ME (ie. contents, errors, etc)
MonitorElement * ProblemsVsLB_HO2
MonitorElement * NumberOfRecentMissingRecHitsHB
MonitorElement * ProblemsVsLB_HO
void HcalDeadCellMonitor::setup ( void  )
virtual

Reimplemented from HcalBaseDQMonitor.

Definition at line 73 of file HcalDeadCellMonitor.cc.

References DQMStore::book1D(), DQMStore::book2D(), DQMStore::bookFloat(), DQMStore::bookInt(), DQMStore::bookProfile(), gather_cfg::cout, HcalBaseDQMonitor::dbe_, deadmon_test_digis_, deadmon_test_rechits_, HcalBaseDQMonitor::debug_, EtaPhiHists::depth, DigiPresentByDepth, excludeHORing2_, MonitorElement::Fill(), HcalObjRepresent::FillUnphysicalHEHFBins(), MonitorElement::getTProfile(), HBDeadVsEvent, HBenergyThreshold_, HEDeadVsEvent, HEenergyThreshold_, HFDeadVsEvent, HFenergyThreshold_, HODeadVsEvent, HOenergyThreshold_, HcalBaseDQMonitor::makeDiagnostics_, minDeadEventCount_, mergeVDriftHistosByStation::name, Nevents, HcalBaseDQMonitor::NLumiBlocks_, NumberOfNeverPresentDigis, NumberOfNeverPresentDigisHB, NumberOfNeverPresentDigisHE, NumberOfNeverPresentDigisHF, NumberOfNeverPresentDigisHO, NumberOfNeverPresentRecHits, NumberOfNeverPresentRecHitsHB, NumberOfNeverPresentRecHitsHE, NumberOfNeverPresentRecHitsHF, NumberOfNeverPresentRecHitsHO, NumberOfRecentMissingDigis, NumberOfRecentMissingDigisHB, NumberOfRecentMissingDigisHE, NumberOfRecentMissingDigisHF, NumberOfRecentMissingDigisHO, NumberOfRecentMissingRecHits, NumberOfRecentMissingRecHitsHB, NumberOfRecentMissingRecHitsHE, NumberOfRecentMissingRecHitsHF, NumberOfRecentMissingRecHitsHO, ProblemsInLastNLB_HBHEHF_alarm, ProblemsInLastNLB_HO01_alarm, ProblemsVsLB, ProblemsVsLB_HB, HcalBaseDQMonitor::ProblemsVsLB_HBHEHF, ProblemsVsLB_HE, ProblemsVsLB_HF, ProblemsVsLB_HO, ProblemsVsLB_HO2, RBX_loss_VS_LB, RecentMissingDigisByDepth, RecentMissingRecHitsByDepth, RecHitPresentByDepth, reset(), MonitorElement::setBinLabel(), DQMStore::setCurrentFolder(), HcalBaseDQMonitor::setup(), HcalBaseDQMonitor::SetupEtaPhiHists(), HcalBaseDQMonitor::subdir_, create_public_lumi_plots::units, and zeroCounters().

Referenced by beginRun().

74 {
76  zeroCounters(1); // make sure arrays are set up
77  if (debug_>0)
78  std::cout <<"<HcalDeadCellMonitor::setup> Setting up histograms"<<std::endl;
79 
80  if (!dbe_) return;
81 
83  MonitorElement* excludeHO2=dbe_->bookInt("ExcludeHOring2");
84  // Fill with 0 if ring is not to be excluded; fill with 1 if it is to be excluded
85  if (excludeHO2) excludeHO2->Fill(excludeHORing2_==true ? 1 : 0);
86 
87  Nevents = dbe_->book1D("NumberOfDeadCellEvents","Number of Events Seen by DeadCellMonitor",2,0,2);
88  Nevents->setBinLabel(1,"allEvents");
89  Nevents->setBinLabel(2,"lumiCheck");
90  // 1D plots count number of bad cells vs. luminosity block
91  ProblemsVsLB=dbe_->bookProfile("TotalDeadCells_HCAL_vs_LS",
92  "Total Number of Dead Hcal Cells (excluding known problems) vs LS;Lumi Section;Dead Cells",
93  NLumiBlocks_,0.5,NLumiBlocks_+0.5,
94  100,0,10000);
95  ProblemsVsLB_HB=dbe_->bookProfile("TotalDeadCells_HB_vs_LS",
96  "Total Number of Dead HB Cells (excluding known problems) vs LS;Lumi Section;Dead Cells",
97  NLumiBlocks_,0.5,NLumiBlocks_+0.5,
98  100,0,10000);
99  ProblemsVsLB_HE=dbe_->bookProfile("TotalDeadCells_HE_vs_LS",
100  "Total Number of Dead HE Cells (excluding known problems) vs LS;Lumi Section;Dead Cells",
101  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
102  ProblemsVsLB_HO=dbe_->bookProfile("TotalDeadCells_HO_vs_LS",
103  "Total Number of Dead HO Cells Ring 0,1 |ieta|<=10 (excluding known problems) vs LS;Lumi Section;Dead Cells",
104  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
105  ProblemsVsLB_HO2=dbe_->bookProfile("TotalDeadCells_HO2_vs_LS",
106  "Total Number of Dead HO Cells Ring 2 |ieta|>10 (excluding known problems) vs LS;Lumi Section;Dead Cells",
107  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
108  ProblemsVsLB_HF=dbe_->bookProfile("TotalDeadCells_HF_vs_LS",
109  "Total Number of Dead HF Cells (excluding known problems) vs LS;Lumi Section;Dead Cells",
110  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
111  ProblemsVsLB_HBHEHF=dbe_->bookProfile("TotalDeadCells_HBHEHF_vs_LS",
112  "Total Number of Dead HBHEHF Cells (excluding known problems) vs LS;Lumi Section;Dead Cells",
113  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
114 
115  (ProblemsVsLB->getTProfile())->SetMarkerStyle(20);
116  (ProblemsVsLB_HB->getTProfile())->SetMarkerStyle(20);
117  (ProblemsVsLB_HE->getTProfile())->SetMarkerStyle(20);
118  (ProblemsVsLB_HO->getTProfile())->SetMarkerStyle(20);
119  (ProblemsVsLB_HO2->getTProfile())->SetMarkerStyle(20);
120  (ProblemsVsLB_HF->getTProfile())->SetMarkerStyle(20);
121  (ProblemsVsLB_HBHEHF->getTProfile())->SetMarkerStyle(20);
122 
123  RBX_loss_VS_LB=dbe_->book2D("RBX_loss_VS_LB",
124  "RBX loss vs LS; Lumi Section; Index of lost RBX",
125  NLumiBlocks_,0.5,NLumiBlocks_+0.5,156,0,156);
126 
127  ProblemsInLastNLB_HBHEHF_alarm=dbe_->book1D("ProblemsInLastNLB_HBHEHF_alarm",
128  "Total Number of Dead HBHEHF Cells in last 10 LS. Last bin contains OverFlow",
129  100,0,100);
130  ProblemsInLastNLB_HO01_alarm=dbe_->book1D("ProblemsInLastNLB_HO01_alarm",
131  "Total Number of Dead Cells Ring 0,1 (abs(ieta)<=10) in last 10 LS. Last bin contains OverFlow",
132  100,0,100);
133 
134 
135  dbe_->setCurrentFolder(subdir_+"dead_cell_parameters");
136  MonitorElement* me=dbe_->bookInt("Test_NeverPresent_Digis");
137  me->Fill(1);
138  me=dbe_->bookInt("Test_DigiMissing_Periodic_Lumi_Check");
140  me->Fill(1);
141  else
142  me->Fill(0);
143  me=dbe_->bookInt("Min_Events_Required_Periodic_Lumi_Check");
145  me=dbe_->bookInt("Test_NeverPresent_RecHits");
146  deadmon_test_rechits_>0 ? me->Fill(1) : me->Fill(0);
147  me=dbe_->bookFloat("HBMinimumRecHitEnergy");
149  me=dbe_->bookFloat("HEMinimumRecHitEnergy");
151  me=dbe_->bookFloat("HOMinimumRecHitEnergy");
153  me=dbe_->bookFloat("HFMinimumRecHitEnergy");
155  me=dbe_->bookInt("Test_RecHitsMissing_Periodic_Lumi_Check");
156  deadmon_test_rechits_>0 ? me->Fill(1) : me->Fill(0);
157 
158  // ProblemCells plots are in HcalDeadCellClient!
159 
160  // Set up plots for each failure mode of dead cells
161  std::stringstream units; // We'll need to set the titles individually, rather than passing units to SetupEtaPhiHists (since this also would affect the name of the histograms)
162  std::stringstream name;
163 
164  // Never-present test will always be called, by definition of dead cell
165 
166  dbe_->setCurrentFolder(subdir_+"dead_digi_never_present");
168  "Digi Present At Least Once","");
169  // 1D plots count number of bad cells
170  NumberOfNeverPresentDigis=dbe_->bookProfile("Problem_NeverPresentDigis_HCAL_vs_LS",
171  "Total Number of Never-Present Hcal Cells vs LS;Lumi Section;Dead Cells",
172  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
173 
174  NumberOfNeverPresentDigisHB=dbe_->bookProfile("Problem_NeverPresentDigis_HB_vs_LS",
175  "Total Number of Never-Present HB Cells vs LS;Lumi Section;Dead Cells",
176  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
177 
178  NumberOfNeverPresentDigisHE=dbe_->bookProfile("Problem_NeverPresentDigis_HE_vs_LS",
179  "Total Number of Never-Present HE Cells vs LS;Lumi Section;Dead Cells",
180  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
181 
182  NumberOfNeverPresentDigisHO=dbe_->bookProfile("Problem_NeverPresentDigis_HO_vs_LS",
183  "Total Number of Never-Present HO Cells vs LS;Lumi Section;Dead Cells",
184  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
185 
186  NumberOfNeverPresentDigisHF=dbe_->bookProfile("Problem_NeverPresentDigis_HF_vs_LS",
187  "Total Number of Never-Present HF Cells vs LS;Lumi Section;Dead Cells",
188  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
189  (NumberOfNeverPresentDigis->getTProfile())->SetMarkerStyle(20);
190  (NumberOfNeverPresentDigisHB->getTProfile())->SetMarkerStyle(20);
191  (NumberOfNeverPresentDigisHE->getTProfile())->SetMarkerStyle(20);
192  (NumberOfNeverPresentDigisHO->getTProfile())->SetMarkerStyle(20);
193  (NumberOfNeverPresentDigisHF->getTProfile())->SetMarkerStyle(20);
194 
196 
198  {
199  dbe_->setCurrentFolder(subdir_+"dead_digi_often_missing");
200  //units<<"("<<deadmon_checkNevents_<<" consec. events)";
201  name<<"Dead Cells with No Digis";
203  name.str(),
204  "");
205  name.str("");
206  name<<"HB HE HF Depth 1 Dead Cells with No Digis for at least 1 Full Luminosity Block";
207  RecentMissingDigisByDepth.depth[0]->setTitle(name.str().c_str());
208 
209  name.str("");
210  name<<"HB HE HF Depth 2 Dead Cells with No Digis for at least 1 Full Luminosity Block";
211  RecentMissingDigisByDepth.depth[1]->setTitle(name.str().c_str());
212 
213  name.str("");
214  name<<"HE Depth 3 Dead Cells with No Digis for at least 1 Full Luminosity Block";
215  RecentMissingDigisByDepth.depth[2]->setTitle(name.str().c_str());
216 
217  name.str("");
218  name<<"HO Depth 4 Dead Cells with No Digis for at least 1 Full Luminosity Block";
219  RecentMissingDigisByDepth.depth[3]->setTitle(name.str().c_str());
220  name.str("");
221 
222  // 1D plots count number of bad cells
223  name<<"Total Number of Hcal Digis Unoccupied for at least 1 Full Luminosity Block";
224  NumberOfRecentMissingDigis=dbe_->bookProfile("Problem_RecentMissingDigis_HCAL_vs_LS",
225  name.str(),
226  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
227  name.str("");
228  name<<"Total Number of HB Digis Unoccupied for at least 1 Full LS vs LS;Lumi Section; Dead Cells";
229  NumberOfRecentMissingDigisHB=dbe_->bookProfile("Problem_RecentMissingDigis_HB_vs_LS",
230  name.str(),
231  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
232  name.str("");
233  name<<"Total Number of HE Digis Unoccupied for at least 1 Full LS vs LS;Lumi Section; Dead Cells";
234  NumberOfRecentMissingDigisHE=dbe_->bookProfile("Problem_RecentMissingDigis_HE_vs_LS",
235  name.str(),
236  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
237  name.str("");
238  name<<"Total Number of HO Digis Unoccupied for at least 1 Full LS vs LS;Lumi Section; Dead Cells";
239  NumberOfRecentMissingDigisHO=dbe_->bookProfile("Problem_RecentMissingDigis_HO_vs_LS",
240  name.str(),
241  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
242  name.str("");
243  name<<"Total Number of HF Digis Unoccupied for at least 1 Full LS vs LS;Lumi Section; Dead Cells";
244  NumberOfRecentMissingDigisHF=dbe_->bookProfile("Problem_RecentMissingDigis_HF_vs_LS",
245  name.str(),
246  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
247  (NumberOfRecentMissingDigis->getTProfile())->SetMarkerStyle(20);
248  (NumberOfRecentMissingDigisHB->getTProfile())->SetMarkerStyle(20);
249  (NumberOfRecentMissingDigisHE->getTProfile())->SetMarkerStyle(20);
250  (NumberOfRecentMissingDigisHO->getTProfile())->SetMarkerStyle(20);
251  (NumberOfRecentMissingDigisHF->getTProfile())->SetMarkerStyle(20);
252 
253  }
254 
256  {
257  // test 1: energy never above threshold
258  dbe_->setCurrentFolder(subdir_+"dead_rechit_neverpresent");
259  SetupEtaPhiHists(RecHitPresentByDepth,"RecHit Above Threshold At Least Once","");
260  // set more descriptive titles for threshold plots
261  units.str("");
262  units<<"Cells Above Energy Threshold At Least Once: Depth 1 -- HB >="<<HBenergyThreshold_<<" GeV, HE >= "<<HEenergyThreshold_<<", HF >="<<HFenergyThreshold_<<" GeV";
263  RecHitPresentByDepth.depth[0]->setTitle(units.str().c_str());
264  units.str("");
265  units<<"Cells Above Energy Threshold At Least Once: Depth 2 -- HB >="<<HBenergyThreshold_<<" GeV, HE >= "<<HEenergyThreshold_<<", HF >="<<HFenergyThreshold_<<" GeV";
266  RecHitPresentByDepth.depth[1]->setTitle(units.str().c_str());
267  units.str("");
268  units<<"Cells Above Energy Threshold At Least Once: Depth 3 -- HE >="<<HEenergyThreshold_<<" GeV";
269  RecHitPresentByDepth.depth[2]->setTitle(units.str().c_str());
270  units.str("");
271  units<<"Cells Above Energy Threshold At Least Once: Depth 4 -- HO >="<<HOenergyThreshold_<<" GeV";
272  RecHitPresentByDepth.depth[3]->setTitle(units.str().c_str());
273  units.str("");
274 
275  // 1D plots count number of bad cells
276  NumberOfNeverPresentRecHits=dbe_->bookProfile("Problem_RecHitsNeverPresent_HCAL_vs_LS",
277  "Total Number of Hcal Rechits with Low Energy;Lumi Section;Dead Cells",
278  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
279  name.str("");
280  name<<"Total Number of HB RecHits with Energy Never >= "<<HBenergyThreshold_<<" GeV;Lumi Section;Dead Cells";
281  NumberOfNeverPresentRecHitsHB=dbe_->bookProfile("Problem_RecHitsNeverPresent_HB_vs_LS",
282  name.str(),
283  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
284  name.str("");
285  name<<"Total Number of HE RecHits with Energy Never >= "<<HEenergyThreshold_<<" GeV;Lumi Section;Dead Cells";
286  NumberOfNeverPresentRecHitsHE=dbe_->bookProfile("Problem_RecHitsNeverPresent_HE_vs_LS",
287  name.str(),
288  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
289  name.str("");
290  name<<"Total Number of HO RecHits with Energy Never >= "<<HOenergyThreshold_<<" GeV;Lumi Section;Dead Cells";
291  NumberOfNeverPresentRecHitsHO=dbe_->bookProfile("Problem_RecHitsNeverPresent_HO_vs_LS",
292  name.str(),
293  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
294  name.str("");
295  name<<"Total Number of HF RecHits with Energy Never >= "<<HFenergyThreshold_<<" GeV;Lumi Section;Dead Cells";
296  NumberOfNeverPresentRecHitsHF=dbe_->bookProfile("Problem_RecHitsNeverPresent_HF_vs_LS",
297  name.str(),
298  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
299  (NumberOfNeverPresentRecHits->getTProfile())->SetMarkerStyle(20);
300  (NumberOfNeverPresentRecHitsHB->getTProfile())->SetMarkerStyle(20);
301  (NumberOfNeverPresentRecHitsHE->getTProfile())->SetMarkerStyle(20);
302  (NumberOfNeverPresentRecHitsHO->getTProfile())->SetMarkerStyle(20);
303  (NumberOfNeverPresentRecHitsHF->getTProfile())->SetMarkerStyle(20);
304 
305  dbe_->setCurrentFolder(subdir_+"dead_rechit_often_missing");
306  SetupEtaPhiHists(RecentMissingRecHitsByDepth,"RecHits Failing Energy Threshold Test","");
307  // set more descriptive titles for threshold plots
308  units.str("");
309  units<<"RecHits with Consistent Low Energy Depth 1 -- HB <"<<HBenergyThreshold_<<" GeV, HE < "<<HEenergyThreshold_<<", HF <"<<HFenergyThreshold_<<" GeV";
310  RecentMissingRecHitsByDepth.depth[0]->setTitle(units.str().c_str());
311  units.str("");
312  units<<"RecHits with Consistent Low Energy Depth 2 -- HB <"<<HBenergyThreshold_<<" GeV, HE < "<<HEenergyThreshold_<<", HF <"<<HFenergyThreshold_<<" GeV";
313  RecentMissingRecHitsByDepth.depth[1]->setTitle(units.str().c_str());
314  units.str("");
315  units<<"RecHits with Consistent Low Energy Depth 3 -- HE <"<<HEenergyThreshold_<<" GeV";
316  RecentMissingRecHitsByDepth.depth[2]->setTitle(units.str().c_str());
317  units.str("");
318  units<<"RecHits with Consistent Low Energy Depth 4 -- HO <"<<HOenergyThreshold_<<" GeV";
319  RecentMissingRecHitsByDepth.depth[3]->setTitle(units.str().c_str());
320  units.str("");
321 
322 
323  // 1D plots count number of bad cells
324  name.str("");
325  name<<"Total Number of Hcal RecHits with Consistent Low Energy;Lumi Section;Dead Cells";
326  NumberOfRecentMissingRecHits=dbe_->bookProfile("Problem_BelowEnergyRecHits_HCAL_vs_LS",
327  name.str(),
328  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
329  name.str("");
330  name<<"Total Number of HB RecHits with Consistent Low Energy < "<<HBenergyThreshold_<<" GeV;Lumi Section;Dead Cells";
331  NumberOfRecentMissingRecHitsHB=dbe_->bookProfile("Problem_BelowEnergyRecHits_HB_vs_LS",
332  name.str(),
333  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
334  name.str("");
335  name<<"Total Number of HE RecHits with Consistent Low Energy < "<<HEenergyThreshold_<<" GeV;Lumi Section;Dead Cells";
336  NumberOfRecentMissingRecHitsHE=dbe_->bookProfile("Problem_BelowEnergyRecHits_HE_vs_LS",
337  name.str(),
338  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
339  name.str("");
340  name<<"Total Number of HO RecHits with Consistent Low Energy < "<<HOenergyThreshold_<<" GeV;Lumi Section;Dead Cells";
341  NumberOfRecentMissingRecHitsHO=dbe_->bookProfile("Problem_BelowEnergyRecHits_HO_vs_LS",
342  name.str(),
343  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
344  name.str("");
345  name<<"Total Number of HF RecHits with Consistent Low Energy < "<<HFenergyThreshold_<<" GeV;Lumi Section;Dead Cells";
346  NumberOfRecentMissingRecHitsHF=dbe_->bookProfile("Problem_BelowEnergyRecHits_HF_vs_LS",
347  name.str(),
348  NLumiBlocks_,0.5,NLumiBlocks_+0.5,100,0,10000);
349  (NumberOfRecentMissingRecHits->getTProfile())->SetMarkerStyle(20);
350  (NumberOfRecentMissingRecHitsHB->getTProfile())->SetMarkerStyle(20);
351  (NumberOfRecentMissingRecHitsHE->getTProfile())->SetMarkerStyle(20);
352  (NumberOfRecentMissingRecHitsHO->getTProfile())->SetMarkerStyle(20);
353  (NumberOfRecentMissingRecHitsHF->getTProfile())->SetMarkerStyle(20);
354 
355  } // if (deadmon_test_rechits)
356 
357 
358  if (makeDiagnostics_)
359  {
360  dbe_->setCurrentFolder(subdir_+"DiagnosticPlots");
361  HBDeadVsEvent=dbe_->book1D("HBDeadVsEvent","HB Total Dead Cells Vs Event", NLumiBlocks_/10,-0.5,NLumiBlocks_-0.5);
362  HEDeadVsEvent=dbe_->book1D("HEDeadVsEvent","HE Total Dead Cells Vs Event", NLumiBlocks_/10,-0.5,NLumiBlocks_-0.5);
363  HODeadVsEvent=dbe_->book1D("HODeadVsEvent","HO Total Dead Cells Vs Event", NLumiBlocks_/10,-0.5,NLumiBlocks_-0.5);
364  HFDeadVsEvent=dbe_->book1D("HFDeadVsEvent","HF Total Dead Cells Vs Event", NLumiBlocks_/10,-0.5,NLumiBlocks_-0.5);
365  }
366 
367  this->reset();
368  return;
369 
370 } // void HcalDeadCellMonitor::setup(...)
MonitorElement * NumberOfNeverPresentRecHitsHO
MonitorElement * NumberOfRecentMissingRecHitsHF
MonitorElement * NumberOfNeverPresentRecHits
MonitorElement * NumberOfNeverPresentDigisHB
MonitorElement * HEDeadVsEvent
MonitorElement * NumberOfRecentMissingRecHits
MonitorElement * book1D(const char *name, const char *title, int nchX, double lowX, double highX)
Book 1D histogram.
Definition: DQMStore.cc:717
void zeroCounters(bool resetpresent=false)
MonitorElement * NumberOfNeverPresentDigisHE
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 * NumberOfRecentMissingDigisHB
MonitorElement * ProblemsInLastNLB_HO01_alarm
MonitorElement * NumberOfRecentMissingDigisHE
MonitorElement * bookFloat(const char *name)
Book float.
Definition: DQMStore.cc:654
void Fill(long long x)
EtaPhiHists RecHitPresentByDepth
MonitorElement * RBX_loss_VS_LB
std::vector< MonitorElement * > depth
MonitorElement * ProblemsVsLB
MonitorElement * NumberOfNeverPresentDigisHF
MonitorElement * ProblemsVsLB_HBHEHF
MonitorElement * NumberOfNeverPresentDigisHO
MonitorElement * NumberOfNeverPresentRecHitsHB
MonitorElement * Nevents
MonitorElement * bookProfile(const char *name, const char *title, int nchX, double lowX, double highX, int nchY, double lowY, double highY, const char *option="s")
Definition: DQMStore.cc:1031
MonitorElement * NumberOfRecentMissingRecHitsHE
MonitorElement * ProblemsVsLB_HF
MonitorElement * NumberOfRecentMissingDigisHO
MonitorElement * NumberOfNeverPresentRecHitsHF
MonitorElement * ProblemsVsLB_HB
EtaPhiHists RecentMissingDigisByDepth
MonitorElement * NumberOfRecentMissingRecHitsHO
EtaPhiHists DigiPresentByDepth
void FillUnphysicalHEHFBins(std::vector< TH2F > &hh)
EtaPhiHists RecentMissingRecHitsByDepth
void SetupEtaPhiHists(EtaPhiHists &hh, std::string Name, std::string Units)
MonitorElement * HBDeadVsEvent
MonitorElement * NumberOfNeverPresentRecHitsHE
MonitorElement * ProblemsVsLB_HE
TProfile * getTProfile(void) const
MonitorElement * NumberOfNeverPresentDigis
MonitorElement * NumberOfRecentMissingDigis
MonitorElement * NumberOfRecentMissingDigisHF
tuple cout
Definition: gather_cfg.py:121
MonitorElement * bookInt(const char *name)
Book int.
Definition: DQMStore.cc:624
MonitorElement * ProblemsInLastNLB_HBHEHF_alarm
MonitorElement * book2D(const char *name, const char *title, int nchX, double lowX, double highX, int nchY, double lowY, double highY)
Book 2D histogram.
Definition: DQMStore.cc:845
virtual void setup(void)
MonitorElement * HFDeadVsEvent
MonitorElement * ProblemsVsLB_HO2
void setCurrentFolder(const std::string &fullpath)
Definition: DQMStore.cc:429
MonitorElement * HODeadVsEvent
MonitorElement * NumberOfRecentMissingRecHitsHB
MonitorElement * ProblemsVsLB_HO
void HcalDeadCellMonitor::zeroCounters ( bool  resetpresent = false)
private

Definition at line 1599 of file HcalDeadCellMonitor.cc.

References i, j, gen::k, occupancy_RBX, present_digi, present_rechit, rbxlost, recentoccupancy_digi, and recentoccupancy_rechit.

Referenced by endLuminosityBlock(), reset(), and setup().

1600 {
1601 
1602  // zero all counters
1603 
1604  // 2D histogram counters
1605  for (unsigned int i=0;i<85;++i)
1606  {
1607  for (unsigned int j=0;j<72;++j)
1608  {
1609  for (unsigned int k=0;k<4;++k)
1610  {
1611  if (resetpresent) present_digi[i][j][k]=false; // keeps track of whether digi was ever present
1612  if (resetpresent) present_rechit[i][j][k]=false;
1613  recentoccupancy_digi[i][j][k]=0; // counts occupancy in last (checkNevents) events
1614  recentoccupancy_rechit[i][j][k]=0; // counts instances of cell above threshold energy in last (checkNevents)
1615  }
1616  }
1617  }
1618 
1619  for (unsigned int i=0;i<156;++i)
1620  {
1621  occupancy_RBX[i] = 0;
1622  rbxlost[i] = 0;
1623  }
1624 
1625  return;
1626 } // void HcalDeadCellMonitor::zeroCounters(bool resetpresent)
int i
Definition: DBlmapReader.cc:9
bool present_digi[85][72][4]
bool present_rechit[85][72][4]
unsigned int occupancy_RBX[156]
int j
Definition: DBlmapReader.cc:9
unsigned int recentoccupancy_rechit[85][72][4]
int k[5][pyjets_maxn]
unsigned int recentoccupancy_digi[85][72][4]

Member Data Documentation

int HcalDeadCellMonitor::alarmer_counter_
private

Definition at line 114 of file HcalDeadCellMonitor.h.

Referenced by endLuminosityBlock(), fillNevents_problemCells(), and reset().

int HcalDeadCellMonitor::alarmer_counterHO01_
private

Definition at line 115 of file HcalDeadCellMonitor.h.

Referenced by endLuminosityBlock(), fillNevents_problemCells(), and reset().

int HcalDeadCellMonitor::beamMode_
private

Definition at line 101 of file HcalDeadCellMonitor.h.

Referenced by endLuminosityBlock(), and reset().

int HcalDeadCellMonitor::deadevt_
private
bool HcalDeadCellMonitor::deadmon_makeDiagnostics_
private

Definition at line 65 of file HcalDeadCellMonitor.h.

bool HcalDeadCellMonitor::deadmon_test_digis_
private
bool HcalDeadCellMonitor::deadmon_test_rechits_
private
edm::InputTag HcalDeadCellMonitor::digiLabel_
private

Definition at line 119 of file HcalDeadCellMonitor.h.

Referenced by analyze(), and HcalDeadCellMonitor().

EtaPhiHists HcalDeadCellMonitor::DigiPresentByDepth
private
bool HcalDeadCellMonitor::doReset_
private

Definition at line 102 of file HcalDeadCellMonitor.h.

Referenced by analyze(), beginRun(), and reset().

bool HcalDeadCellMonitor::endLumiProcessed_
private

Definition at line 122 of file HcalDeadCellMonitor.h.

Referenced by analyze(), endLuminosityBlock(), endRun(), and HcalDeadCellMonitor().

double HcalDeadCellMonitor::energyThreshold_
private

Definition at line 79 of file HcalDeadCellMonitor.h.

Referenced by HcalDeadCellMonitor().

bool HcalDeadCellMonitor::excludeHO1P02_
private

Definition at line 125 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), and HcalDeadCellMonitor().

bool HcalDeadCellMonitor::excludeHORing2_
private
MonitorElement* HcalDeadCellMonitor::HBDeadVsEvent
private

Definition at line 104 of file HcalDeadCellMonitor.h.

Referenced by processEvent(), and setup().

double HcalDeadCellMonitor::HBenergyThreshold_
private

Definition at line 80 of file HcalDeadCellMonitor.h.

Referenced by HcalDeadCellMonitor(), process_RecHit(), and setup().

bool HcalDeadCellMonitor::hbhedcsON
private

Definition at line 117 of file HcalDeadCellMonitor.h.

Referenced by analyze(), endLuminosityBlock(), and reset().

edm::InputTag HcalDeadCellMonitor::hbheRechitLabel_
private

Definition at line 120 of file HcalDeadCellMonitor.h.

Referenced by analyze(), and HcalDeadCellMonitor().

MonitorElement * HcalDeadCellMonitor::HEDeadVsEvent
private

Definition at line 104 of file HcalDeadCellMonitor.h.

Referenced by processEvent(), and setup().

double HcalDeadCellMonitor::HEenergyThreshold_
private

Definition at line 81 of file HcalDeadCellMonitor.h.

Referenced by HcalDeadCellMonitor(), process_RecHit(), and setup().

bool HcalDeadCellMonitor::hfdcsON
private

Definition at line 117 of file HcalDeadCellMonitor.h.

Referenced by analyze(), endLuminosityBlock(), and reset().

MonitorElement * HcalDeadCellMonitor::HFDeadVsEvent
private

Definition at line 104 of file HcalDeadCellMonitor.h.

Referenced by processEvent(), and setup().

double HcalDeadCellMonitor::HFenergyThreshold_
private

Definition at line 83 of file HcalDeadCellMonitor.h.

Referenced by HcalDeadCellMonitor(), process_RecHit(), and setup().

edm::InputTag HcalDeadCellMonitor::hfRechitLabel_
private

Definition at line 120 of file HcalDeadCellMonitor.h.

Referenced by analyze(), and HcalDeadCellMonitor().

bool HcalDeadCellMonitor::hodcsON
private

Definition at line 117 of file HcalDeadCellMonitor.h.

Referenced by analyze(), endLuminosityBlock(), and reset().

MonitorElement * HcalDeadCellMonitor::HODeadVsEvent
private

Definition at line 104 of file HcalDeadCellMonitor.h.

Referenced by processEvent(), and setup().

double HcalDeadCellMonitor::HOenergyThreshold_
private

Definition at line 82 of file HcalDeadCellMonitor.h.

Referenced by HcalDeadCellMonitor(), process_RecHit(), and setup().

edm::InputTag HcalDeadCellMonitor::hoRechitLabel_
private

Definition at line 120 of file HcalDeadCellMonitor.h.

Referenced by analyze(), and HcalDeadCellMonitor().

int HcalDeadCellMonitor::is_RBX_loss_
private
bool HcalDeadCellMonitor::is_stable_beam
private

Definition at line 116 of file HcalDeadCellMonitor.h.

Referenced by analyze(), endLuminosityBlock(), and reset().

HcalLogicalMap* HcalDeadCellMonitor::logicalMap_
private
int HcalDeadCellMonitor::minDeadEventCount_
private
MonitorElement* HcalDeadCellMonitor::Nevents
private

Definition at line 100 of file HcalDeadCellMonitor.h.

Referenced by analyze(), fillNevents_problemCells(), reset(), and setup().

unsigned int HcalDeadCellMonitor::NumBadHB
private

Definition at line 118 of file HcalDeadCellMonitor.h.

Referenced by endLuminosityBlock(), and fillNevents_problemCells().

unsigned int HcalDeadCellMonitor::NumBadHE
private

Definition at line 118 of file HcalDeadCellMonitor.h.

Referenced by endLuminosityBlock(), and fillNevents_problemCells().

unsigned int HcalDeadCellMonitor::NumBadHF
private

Definition at line 118 of file HcalDeadCellMonitor.h.

Referenced by endLuminosityBlock(), and fillNevents_problemCells().

unsigned int HcalDeadCellMonitor::NumBadHFLUMI
private

Definition at line 118 of file HcalDeadCellMonitor.h.

Referenced by endLuminosityBlock(), and fillNevents_problemCells().

unsigned int HcalDeadCellMonitor::NumBadHO
private

Definition at line 118 of file HcalDeadCellMonitor.h.

Referenced by endLuminosityBlock(), and fillNevents_problemCells().

unsigned int HcalDeadCellMonitor::NumBadHO0
private

Definition at line 118 of file HcalDeadCellMonitor.h.

Referenced by endLuminosityBlock().

unsigned int HcalDeadCellMonitor::NumBadHO01
private

Definition at line 118 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells().

unsigned int HcalDeadCellMonitor::NumBadHO12
private

Definition at line 118 of file HcalDeadCellMonitor.h.

Referenced by endLuminosityBlock(), and fillNevents_problemCells().

int HcalDeadCellMonitor::NumBadHO1P02
private

Definition at line 126 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells().

unsigned int HcalDeadCellMonitor::NumBadHO2
private

Definition at line 118 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells().

MonitorElement* HcalDeadCellMonitor::NumberOfNeverPresentDigis
private

Definition at line 95 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), processEvent(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::NumberOfNeverPresentDigisHB
private

Definition at line 95 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), processEvent(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::NumberOfNeverPresentDigisHE
private

Definition at line 95 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), processEvent(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::NumberOfNeverPresentDigisHF
private

Definition at line 95 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), processEvent(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::NumberOfNeverPresentDigisHO
private

Definition at line 95 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), processEvent(), reset(), and setup().

MonitorElement* HcalDeadCellMonitor::NumberOfNeverPresentRecHits
private

Definition at line 98 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::NumberOfNeverPresentRecHitsHB
private

Definition at line 98 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::NumberOfNeverPresentRecHitsHE
private

Definition at line 98 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::NumberOfNeverPresentRecHitsHF
private

Definition at line 98 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::NumberOfNeverPresentRecHitsHO
private

Definition at line 98 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), reset(), and setup().

MonitorElement* HcalDeadCellMonitor::NumberOfRecentMissingDigis
private

Definition at line 96 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), processEvent(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::NumberOfRecentMissingDigisHB
private

Definition at line 96 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), processEvent(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::NumberOfRecentMissingDigisHE
private

Definition at line 96 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), processEvent(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::NumberOfRecentMissingDigisHF
private

Definition at line 96 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), processEvent(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::NumberOfRecentMissingDigisHO
private

Definition at line 96 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), processEvent(), reset(), and setup().

MonitorElement* HcalDeadCellMonitor::NumberOfRecentMissingRecHits
private

Definition at line 97 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), processEvent(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::NumberOfRecentMissingRecHitsHB
private

Definition at line 97 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), processEvent(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::NumberOfRecentMissingRecHitsHE
private

Definition at line 97 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), processEvent(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::NumberOfRecentMissingRecHitsHF
private

Definition at line 97 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), processEvent(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::NumberOfRecentMissingRecHitsHO
private

Definition at line 97 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), processEvent(), reset(), and setup().

unsigned int HcalDeadCellMonitor::occupancy_RBX[156]
private
bool HcalDeadCellMonitor::present_digi[85][72][4]
private
bool HcalDeadCellMonitor::present_rechit[85][72][4]
private

Definition at line 106 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), process_RecHit(), and zeroCounters().

MonitorElement* HcalDeadCellMonitor::ProblemsInLastNLB_HBHEHF_alarm
private

Definition at line 93 of file HcalDeadCellMonitor.h.

Referenced by endLuminosityBlock(), fillNevents_problemCells(), reset(), and setup().

MonitorElement* HcalDeadCellMonitor::ProblemsInLastNLB_HO01_alarm
private

Definition at line 94 of file HcalDeadCellMonitor.h.

Referenced by endLuminosityBlock(), fillNevents_problemCells(), reset(), and setup().

MonitorElement* HcalDeadCellMonitor::ProblemsVsLB
private

Definition at line 91 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::ProblemsVsLB_HB
private

Definition at line 91 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::ProblemsVsLB_HE
private

Definition at line 91 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::ProblemsVsLB_HF
private

Definition at line 91 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::ProblemsVsLB_HO
private

Definition at line 91 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), reset(), and setup().

MonitorElement * HcalDeadCellMonitor::ProblemsVsLB_HO2
private

Definition at line 91 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), reset(), and setup().

MonitorElement* HcalDeadCellMonitor::RBX_loss_VS_LB
private

Definition at line 92 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_problemCells(), reset(), and setup().

int HcalDeadCellMonitor::rbxlost[156]
private

Definition at line 113 of file HcalDeadCellMonitor.h.

Referenced by analyze(), endLuminosityBlock(), and zeroCounters().

EtaPhiHists HcalDeadCellMonitor::RecentMissingDigisByDepth
private

Definition at line 85 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_recentdigis(), processEvent(), reset(), and setup().

EtaPhiHists HcalDeadCellMonitor::RecentMissingRecHitsByDepth
private

Definition at line 87 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_recentrechits(), processEvent(), reset(), and setup().

unsigned int HcalDeadCellMonitor::recentoccupancy_digi[85][72][4]
private
unsigned int HcalDeadCellMonitor::recentoccupancy_rechit[85][72][4]
private
EtaPhiHists HcalDeadCellMonitor::RecHitPresentByDepth
private

Definition at line 88 of file HcalDeadCellMonitor.h.

Referenced by fillNevents_recentrechits(), process_RecHit(), reset(), and setup().