CMS 3D CMS Logo

List of all members | Public Member Functions | Protected Member Functions
GEMTnPEfficiencyTask Class Reference
Inheritance diagram for GEMTnPEfficiencyTask:
BaseTnPEfficiencyTask DQMEDAnalyzer edm::stream::EDProducer< edm::GlobalCache< DQMEDAnalyzerGlobalCache >, edm::EndRunProducer, edm::EndLuminosityBlockProducer, edm::Accumulator >

Public Member Functions

 GEMTnPEfficiencyTask (const edm::ParameterSet &config)
 Constructor. More...
 
 ~GEMTnPEfficiencyTask () override
 Destructor. More...
 
- Public Member Functions inherited from BaseTnPEfficiencyTask
 BaseTnPEfficiencyTask (const edm::ParameterSet &config)
 Constructor. More...
 
 ~BaseTnPEfficiencyTask () override
 Destructor. More...
 
- Public Member Functions inherited from DQMEDAnalyzer
void accumulate (edm::Event const &event, edm::EventSetup const &setup) final
 
void beginLuminosityBlock (edm::LuminosityBlock const &lumi, edm::EventSetup const &setup) final
 
void beginRun (edm::Run const &run, edm::EventSetup const &setup) final
 
void beginStream (edm::StreamID id) final
 
 DQMEDAnalyzer ()
 
void endLuminosityBlock (edm::LuminosityBlock const &lumi, edm::EventSetup const &setup) final
 
void endRun (edm::Run const &run, edm::EventSetup const &setup) final
 
virtual bool getCanSaveByLumi ()
 
- Public Member Functions inherited from edm::stream::EDProducer< edm::GlobalCache< DQMEDAnalyzerGlobalCache >, edm::EndRunProducer, edm::EndLuminosityBlockProducer, edm::Accumulator >
 EDProducer ()=default
 
 EDProducer (const EDProducer &)=delete
 
bool hasAbilityToProduceInBeginLumis () const final
 
bool hasAbilityToProduceInBeginProcessBlocks () const final
 
bool hasAbilityToProduceInBeginRuns () const final
 
bool hasAbilityToProduceInEndLumis () const final
 
bool hasAbilityToProduceInEndProcessBlocks () const final
 
bool hasAbilityToProduceInEndRuns () const final
 
const EDProduceroperator= (const EDProducer &)=delete
 

Protected Member Functions

void analyze (const edm::Event &event, const edm::EventSetup &context) override
 Analyze. More...
 
void bookHistograms (DQMStore::IBooker &iBooker, edm::Run const &run, edm::EventSetup const &context) override
 
std::string topFolder () const override
 Return the top folder. More...
 
- Protected Member Functions inherited from BaseTnPEfficiencyTask
void dqmBeginRun (const edm::Run &run, const edm::EventSetup &context) override
 BeginRun. More...
 
bool hasTrigger (std::vector< int > &trigIndices, const trigger::TriggerObjectCollection &trigObjs, edm::Handle< trigger::TriggerEvent > &trigEvent, const reco::Muon &muon)
 
- Protected Member Functions inherited from DQMEDAnalyzer
uint64_t meId () const
 

Additional Inherited Members

- Public Types inherited from DQMEDAnalyzer
typedef dqm::reco::DQMStore DQMStore
 
typedef dqm::reco::MonitorElement MonitorElement
 
- Public Types inherited from edm::stream::EDProducer< edm::GlobalCache< DQMEDAnalyzerGlobalCache >, edm::EndRunProducer, edm::EndLuminosityBlockProducer, edm::Accumulator >
using CacheTypes = CacheContexts< T... >
 
using GlobalCache = typename CacheTypes::GlobalCache
 
using HasAbility = AbilityChecker< T... >
 
using InputProcessBlockCache = typename CacheTypes::InputProcessBlockCache
 
using LuminosityBlockCache = typename CacheTypes::LuminosityBlockCache
 
using LuminosityBlockContext = LuminosityBlockContextT< LuminosityBlockCache, RunCache, GlobalCache >
 
using LuminosityBlockSummaryCache = typename CacheTypes::LuminosityBlockSummaryCache
 
using RunCache = typename CacheTypes::RunCache
 
using RunContext = RunContextT< RunCache, GlobalCache >
 
using RunSummaryCache = typename CacheTypes::RunSummaryCache
 
- Static Public Member Functions inherited from DQMEDAnalyzer
static void globalEndJob (DQMEDAnalyzerGlobalCache const *)
 
static void globalEndLuminosityBlockProduce (edm::LuminosityBlock &lumi, edm::EventSetup const &setup, LuminosityBlockContext const *context)
 
static void globalEndRunProduce (edm::Run &run, edm::EventSetup const &setup, RunContext const *context)
 
static std::unique_ptr< DQMEDAnalyzerGlobalCacheinitializeGlobalCache (edm::ParameterSet const &)
 
- Protected Attributes inherited from BaseTnPEfficiencyTask
const double m_borderCut
 
const bool m_detailedAnalysis
 
const double m_dxCut
 
std::map< std::string, MonitorElement * > m_histos
 
const edm::EDGetTokenT< reco::MuonCollectionm_muToken
 
int m_nEvents
 
std::vector< std::vector< unsigned > > m_probeIndices
 
std::vector< std::vector< unsigned > > m_tagIndices
 
- Protected Attributes inherited from DQMEDAnalyzer
edm::EDPutTokenT< DQMTokenlumiToken_
 
edm::EDPutTokenT< DQMTokenrunToken_
 
unsigned int streamId_
 

Detailed Description

Definition at line 17 of file GEMTnPEfficiencyTask.cc.

Constructor & Destructor Documentation

◆ GEMTnPEfficiencyTask()

GEMTnPEfficiencyTask::GEMTnPEfficiencyTask ( const edm::ParameterSet config)

Constructor.

Definition at line 34 of file GEMTnPEfficiencyTask.cc.

References LogTrace.

35  LogTrace("DQMOffline|MuonDPG|GEMTnPEfficiencyTask") << "[GEMTnPEfficiencyTask]: Constructor" << std::endl;
36 }
Definition: config.py:1
#define LogTrace(id)
BaseTnPEfficiencyTask(const edm::ParameterSet &config)
Constructor.

◆ ~GEMTnPEfficiencyTask()

GEMTnPEfficiencyTask::~GEMTnPEfficiencyTask ( )
override

Destructor.

Definition at line 38 of file GEMTnPEfficiencyTask.cc.

References LogTrace, and BaseTnPEfficiencyTask::m_nEvents.

38  {
39  LogTrace("DQMOffline|MuonDPG|GEMTnPEfficiencyTask")
40  << "[GEMTnPEfficiencyTask]: analyzed " << m_nEvents << " events" << std::endl;
41 }
#define LogTrace(id)

Member Function Documentation

◆ analyze()

void GEMTnPEfficiencyTask::analyze ( const edm::Event event,
const edm::EventSetup context 
)
overrideprotectedvirtual

Analyze.

Reimplemented from BaseTnPEfficiencyTask.

Definition at line 469 of file GEMTnPEfficiencyTask.cc.

References funct::abs(), BaseTnPEfficiencyTask::analyze(), relativeConstraints::chamber, visDQMUpload::context, PVValHelper::dx, PVValHelper::eta, MuonSubdetId::GEM, mps_fire::i, dqmiolumiharvest::j, pixelTopology::layer, BaseTnPEfficiencyTask::m_borderCut, BaseTnPEfficiencyTask::m_detailedAnalysis, BaseTnPEfficiencyTask::m_dxCut, BaseTnPEfficiencyTask::m_histos, BaseTnPEfficiencyTask::m_muToken, BaseTnPEfficiencyTask::m_probeIndices, PDWG_BPHSkim_cff::muons, phi, DiDispStaMuonMonitor_cfi::pt, HLT_2023v12_cff::region, GEMDetId::roll(), relativeConstraints::station, and reco::MuonGEMHitMatch::x.

469  {
471 
473  event.getByToken(m_muToken, muons);
474 
475  //GEM variables
476  std::vector<std::vector<int>> probe_coll_GEM_region;
477  std::vector<std::vector<int>> probe_coll_GEM_lay;
478  std::vector<std::vector<int>> probe_coll_GEM_chamber;
479  std::vector<std::vector<float>> probe_coll_GEM_pt;
480  std::vector<std::vector<float>> probe_coll_GEM_eta;
481  std::vector<std::vector<float>> probe_coll_GEM_phi;
482  std::vector<std::vector<int>> probe_coll_GEM_sta;
483  std::vector<std::vector<float>> probe_coll_GEM_dx;
484  std::vector<uint8_t> probe_coll_GEM_staMatch;
485 
486  //ME0 variables
487  std::vector<std::vector<int>> probe_coll_ME0_region;
488  std::vector<std::vector<int>> probe_coll_ME0_roll;
489  std::vector<std::vector<int>> probe_coll_ME0_lay;
490  std::vector<std::vector<int>> probe_coll_ME0_chamber;
491  std::vector<std::vector<float>> probe_coll_ME0_pt;
492  std::vector<std::vector<float>> probe_coll_ME0_eta;
493  std::vector<std::vector<float>> probe_coll_ME0_phi;
494  std::vector<std::vector<int>> probe_coll_ME0_sta;
495  std::vector<std::vector<float>> probe_coll_ME0_dx;
496  std::vector<uint8_t> probe_coll_ME0_staMatch;
497 
498  std::vector<unsigned> probe_indices;
499  if (!m_probeIndices.empty())
500  probe_indices = m_probeIndices.back();
501 
502  //Fill probe dx + subdetector coordinates
503  for (const auto i : probe_indices) {
504  //GEM variables
505  std::vector<int> probe_GEM_region;
506  std::vector<int> probe_GEM_sta;
507  std::vector<int> probe_GEM_lay;
508  std::vector<int> probe_GEM_chamber;
509  std::vector<float> probe_GEM_pt;
510  std::vector<float> probe_GEM_eta;
511  std::vector<float> probe_GEM_phi;
512  std::vector<float> probe_GEM_dx;
513  //std::vector<float> probe_GEM_dx_seg;
514  uint8_t GEM_stationMatching = 0;
515  //ME0 variables
516  std::vector<int> probe_ME0_region;
517  std::vector<int> probe_ME0_roll;
518  std::vector<int> probe_ME0_sta;
519  std::vector<int> probe_ME0_lay;
520  std::vector<int> probe_ME0_chamber;
521  std::vector<float> probe_ME0_pt;
522  std::vector<float> probe_ME0_eta;
523  std::vector<float> probe_ME0_phi;
524  std::vector<float> probe_ME0_dx;
525  uint8_t ME0_stationMatching = 0;
526 
527  bool gem_matched = false; // fill detailed plots only for probes matching GEM
528 
529  for (const auto& chambMatch : (*muons).at(i).matches()) {
530  // look in GEMs
531  if (chambMatch.detector() == MuonSubdetId::GEM) {
532  if (chambMatch.edgeX < m_borderCut && chambMatch.edgeY < m_borderCut) {
533  gem_matched = true; //fill detailed plots if at least one GEM match
534 
535  GEMDetId chId(chambMatch.id.rawId());
536 
537  const int roll = chId.roll();
538  const int region = chId.region();
539  const int station = chId.station();
540  const int layer = chId.layer();
541  const int chamber = chId.chamber();
542  const float pt = (*muons).at(i).pt();
543  const float eta = (*muons).at(i).eta();
544  const float phi = (*muons).at(i).phi();
545 
546  reco::MuonGEMHitMatch closest_matchedHit;
547  double smallestDx = 99999.;
548  double matched_GEMHit_x = 99999.;
549 
550  for (auto& gemHit : chambMatch.gemHitMatches) {
551  float dx = std::abs(chambMatch.x - gemHit.x);
552  if (dx < smallestDx) {
553  smallestDx = dx;
554  closest_matchedHit = gemHit;
555  matched_GEMHit_x = gemHit.x;
556  }
557  }
558 
559  reco::MuonSegmentMatch closest_matchedSegment;
560  double smallestDx_seg = 99999.;
561 
562  for (auto& seg : chambMatch.gemMatches) {
563  float dx_seg = std::abs(chambMatch.x - seg.x);
564  if (dx_seg < smallestDx_seg) {
565  smallestDx_seg = dx_seg;
566  closest_matchedSegment = seg;
567  }
568  }
569  if (m_detailedAnalysis && gem_matched) {
570  m_histos.find("GEMhit_dx")->second->Fill(smallestDx);
571  m_histos.find("GEMhit_x")->second->Fill(matched_GEMHit_x);
572  m_histos.find("Cham_x")->second->Fill(chambMatch.x);
573  m_histos.find("GEMseg_dx")->second->Fill(smallestDx_seg);
574  if (station == 2) {
575  m_histos.find("GEMhit_dx_GE2")->second->Fill(smallestDx);
576  m_histos.find("GEMhit_x_GE2")->second->Fill(matched_GEMHit_x);
577  m_histos.find("Cham_x_GE2")->second->Fill(chambMatch.x);
578  }
579  }
580 
581  GEM_stationMatching = GEM_stationMatching | (1 << (station - 1));
582 
583  probe_GEM_region.push_back(region);
584  probe_GEM_sta.push_back(station);
585  probe_GEM_lay.push_back(layer);
586  probe_GEM_chamber.push_back(chamber);
587  probe_GEM_pt.push_back(pt);
588  probe_GEM_eta.push_back(eta);
589  probe_GEM_phi.push_back(phi);
590  probe_GEM_dx.push_back(smallestDx);
591  //probe_GEM_dx.push_back(smallestDx_seg);
592  //probe_GEM_dx_seg.push_back(smallestDx_seg);
593 
594  if (station == 0) {
595  reco::MuonSegmentMatch closest_matchedSegment_ME0;
596  double smallestDx_ME0 = 99999.;
597  for (auto& seg : chambMatch.gemMatches) {
598  float dx = std::abs(chambMatch.x - seg.x);
599  if (dx < smallestDx_ME0) {
600  smallestDx_ME0 = dx;
601  closest_matchedSegment_ME0 = seg;
602  }
603  }
604  ME0_stationMatching = ME0_stationMatching | (1 << (station - 1));
605  probe_ME0_region.push_back(region);
606  probe_ME0_roll.push_back(roll);
607  probe_ME0_sta.push_back(station);
608  probe_ME0_lay.push_back(layer);
609  probe_ME0_chamber.push_back(chamber);
610  probe_ME0_pt.push_back(pt);
611  probe_ME0_eta.push_back(eta);
612  probe_ME0_phi.push_back(phi);
613  probe_ME0_dx.push_back(smallestDx_ME0);
614  }
615  }
616  } else
617  continue;
618  } //loop over chamber matches
619 
620  //Fill detailed plots
621  if (m_detailedAnalysis && gem_matched) {
622  m_histos.find("probeEta")->second->Fill(abs((*muons).at(i).eta()));
623  m_histos.find("probePhi")->second->Fill((*muons).at(i).phi());
624  m_histos.find("probeNumberOfMatchedStations")->second->Fill((*muons).at(i).numberOfMatchedStations());
625  m_histos.find("probePt")->second->Fill((*muons).at(i).pt());
626  //for(int ii=0; i<probe_GEM_dx.size(); ii++)
627  //{
628  // m_histos.find("GEMhit_dx")->second->Fill(probe_GEM_dx[ii]);
629  // m_histos.find("GEMseg_dx")->second->Fill(probe_GEM_dx_seg[ii]);
630  //}
631  }
632 
633  //Fill GEM variables
634  probe_coll_GEM_region.push_back(probe_GEM_region);
635  probe_coll_GEM_sta.push_back(probe_GEM_sta);
636  probe_coll_GEM_lay.push_back(probe_GEM_lay);
637  probe_coll_GEM_chamber.push_back(probe_GEM_chamber);
638  probe_coll_GEM_pt.push_back(probe_GEM_pt);
639  probe_coll_GEM_eta.push_back(probe_GEM_eta);
640  probe_coll_GEM_phi.push_back(probe_GEM_phi);
641  probe_coll_GEM_dx.push_back(probe_GEM_dx);
642  probe_coll_GEM_staMatch.push_back(GEM_stationMatching);
643 
644  //Fill ME0 variables
645  probe_coll_ME0_region.push_back(probe_ME0_region);
646  probe_coll_ME0_roll.push_back(probe_ME0_roll);
647  probe_coll_ME0_sta.push_back(probe_ME0_sta);
648  probe_coll_ME0_lay.push_back(probe_ME0_lay);
649  probe_coll_ME0_chamber.push_back(probe_ME0_chamber);
650  probe_coll_ME0_pt.push_back(probe_ME0_pt);
651  probe_coll_ME0_eta.push_back(probe_ME0_eta);
652  probe_coll_ME0_phi.push_back(probe_ME0_phi);
653  probe_coll_ME0_dx.push_back(probe_ME0_dx);
654  probe_coll_ME0_staMatch.push_back(ME0_stationMatching);
655 
656  } //loop over probe collection
657 
658  //Loop over probes
659  for (unsigned i = 0; i < probe_indices.size(); ++i) {
660  uint8_t GEM_matchPatt = probe_coll_GEM_staMatch.at(i);
661  //uint8_t ME0_matchPatt = probe_coll_ME0_staMatch.at(i);
662 
663  //Loop over ME0 matches
664  unsigned nME0_matches = probe_coll_ME0_region.at(i).size();
665  for (unsigned j = 0; j < nME0_matches; ++j) {
666  //ME0 variables
667  int ME0_region = probe_coll_ME0_region.at(i).at(j);
668  //int ME0_roll = probe_coll_ME0_roll.at(i).at(j);
669  int ME0_sta = probe_coll_ME0_sta.at(i).at(j);
670  //int ME0_lay = probe_coll_ME0_lay.at(i).at(j);
671  int ME0_chamber = probe_coll_ME0_chamber.at(i).at(j);
672  //float ME0_pt = probe_coll_ME0_pt.at(i).at(j);
673  float ME0_dx = probe_coll_ME0_dx.at(i).at(j);
674  //float ME0_eta = probe_coll_ME0_eta.at(i).at(j);
675  //float ME0_phi = probe_coll_ME0_phi.at(i).at(j);
676 
677  if (ME0_sta == 0) {
678  if (ME0_dx < m_dxCut) {
679  m_histos.find("ME0_nPassingProbe_chamber_1D")->second->Fill(ME0_chamber);
680  if (ME0_region < 0)
681  m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(4, ME0_chamber);
682  else if (ME0_region > 0)
683  m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(5, ME0_chamber);
684  } else {
685  m_histos.find("ME0_nFailingProbe_chamber_1D")->second->Fill(ME0_chamber);
686  if (ME0_region < 0)
687  m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(4, ME0_chamber);
688  else if (ME0_region > 0)
689  m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(5, ME0_chamber);
690  }
691  }
692  }
693  //
694 
695  //Loop over GEM matches
696  unsigned nGEM_matches = probe_coll_GEM_region.at(i).size();
697  for (unsigned j = 0; j < nGEM_matches; ++j) {
698  //GEM variables
699  int GEM_region = probe_coll_GEM_region.at(i).at(j);
700  int GEM_sta = probe_coll_GEM_sta.at(i).at(j);
701  int GEM_lay = probe_coll_GEM_lay.at(i).at(j);
702  int GEM_chamber = probe_coll_GEM_chamber.at(i).at(j);
703  float GEM_pt = probe_coll_GEM_pt.at(i).at(j);
704  float GEM_dx = probe_coll_GEM_dx.at(i).at(j);
705  float GEM_eta = probe_coll_GEM_eta.at(i).at(j);
706  float GEM_phi = probe_coll_GEM_phi.at(i).at(j);
707 
708  //Fill GEM plots
709  if (((GEM_matchPatt & (1 << (GEM_sta - 1))) != 0) && GEM_sta != 0) //avoids 0 station matching
710  {
711  if (GEM_dx < m_dxCut) {
712  if (GEM_region == 1 && GEM_lay == 0 && GEM_sta == 2 && GEM_chamber == 16)
713  continue; //exclude GE2 ch16 of Run3
714  m_histos.find("GEM_nPassingProbe_Ch_region")->second->Fill(GEM_region, GEM_chamber);
715  m_histos.find("GEM_nPassingProbe_Ch_eta")->second->Fill(abs(GEM_eta), GEM_chamber);
716  m_histos.find("GEM_nPassingProbe_Ch_phi")->second->Fill(GEM_phi, GEM_chamber);
717  m_histos.find("GEM_nPassingProbe_allCh_1D")->second->Fill(GEM_region);
718  m_histos.find("GEM_nPassingProbe_chamber_1D")->second->Fill(GEM_chamber);
719  if (GEM_region < 0) {
720  if (GEM_sta == 2 and GEM_lay == 2)
721  m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(0, GEM_chamber);
722  else if (GEM_sta == 2 and GEM_lay == 1)
723  m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(1, GEM_chamber);
724  else if (GEM_sta == 1 and GEM_lay == 2)
725  m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(2, GEM_chamber);
726  else if (GEM_sta == 1 and GEM_lay == 1)
727  m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(3, GEM_chamber);
728  }
729  if (GEM_region > 0) {
730  if (GEM_sta == 1 and GEM_lay == 1)
731  m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(6, GEM_chamber);
732  else if (GEM_sta == 1 and GEM_lay == 2)
733  m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(7, GEM_chamber);
734  else if (GEM_sta == 2 and GEM_lay == 1)
735  m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(8, GEM_chamber);
736  else if (GEM_sta == 2 and GEM_lay == 2)
737  m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(9, GEM_chamber);
738  }
739  if (GEM_region == -1 && GEM_sta == 1) {
740  m_histos.find("GEM_nPassingProbe_Ch_region_GE1_NoL")->second->Fill(0, GEM_chamber);
741  } else if (GEM_region == 1 && GEM_sta == 1) {
742  m_histos.find("GEM_nPassingProbe_Ch_region_GE1_NoL")->second->Fill(1, GEM_chamber);
743  }
744 
745  if (GEM_region == 1 && GEM_lay == 1 && GEM_sta == 1) {
746  m_histos.find("GEM_nPassingProbe_chamber_p1_1D")->second->Fill(GEM_chamber);
747  m_histos.find("GEM_nPassingProbe_Ch_region_GE1")->second->Fill(2, GEM_chamber);
748  m_histos.find("GEM_nPassingProbe_pt_p1_1D")->second->Fill(GEM_pt);
749  m_histos.find("GEM_nPassingProbe_eta_p1_1D")->second->Fill(abs(GEM_eta));
750  m_histos.find("GEM_nPassingProbe_phi_p1_1D")->second->Fill(GEM_phi);
751  } else if (GEM_region == 1 && GEM_lay == 2 && GEM_sta == 1) {
752  m_histos.find("GEM_nPassingProbe_chamber_p2_1D")->second->Fill(GEM_chamber);
753  m_histos.find("GEM_nPassingProbe_Ch_region_GE1")->second->Fill(3, GEM_chamber);
754  m_histos.find("GEM_nPassingProbe_pt_p2_1D")->second->Fill(GEM_pt);
755  m_histos.find("GEM_nPassingProbe_eta_p2_1D")->second->Fill(abs(GEM_eta));
756  m_histos.find("GEM_nPassingProbe_phi_p2_1D")->second->Fill(GEM_phi);
757  } else if (GEM_region == -1 && GEM_lay == 1 && GEM_sta == 1) {
758  m_histos.find("GEM_nPassingProbe_chamber_n1_1D")->second->Fill(GEM_chamber);
759  m_histos.find("GEM_nPassingProbe_Ch_region_GE1")->second->Fill(1, GEM_chamber);
760  m_histos.find("GEM_nPassingProbe_pt_n1_1D")->second->Fill(GEM_pt);
761  m_histos.find("GEM_nPassingProbe_eta_n1_1D")->second->Fill(abs(GEM_eta));
762  m_histos.find("GEM_nPassingProbe_phi_n1_1D")->second->Fill(GEM_phi);
763  } else if (GEM_region == -1 && GEM_lay == 2 && GEM_sta == 1) {
764  m_histos.find("GEM_nPassingProbe_chamber_n2_1D")->second->Fill(GEM_chamber);
765  m_histos.find("GEM_nPassingProbe_Ch_region_GE1")->second->Fill(0, GEM_chamber);
766  m_histos.find("GEM_nPassingProbe_pt_n2_1D")->second->Fill(GEM_pt);
767  m_histos.find("GEM_nPassingProbe_eta_n2_1D")->second->Fill(abs(GEM_eta));
768  m_histos.find("GEM_nPassingProbe_phi_n2_1D")->second->Fill(GEM_phi);
769  }
770  m_histos.find("GEM_nPassingProbe_pt_1D")->second->Fill(GEM_pt);
771  m_histos.find("GEM_nPassingProbe_eta_1D")->second->Fill(abs(GEM_eta));
772  m_histos.find("GEM_nPassingProbe_phi_1D")->second->Fill(GEM_phi);
773  } else {
774  if (GEM_region == 1 && GEM_lay == 0 && GEM_sta == 2 && GEM_chamber == 16)
775  continue;
776  m_histos.find("GEM_nFailingProbe_Ch_region")->second->Fill(GEM_region, GEM_chamber);
777  m_histos.find("GEM_nFailingProbe_Ch_eta")->second->Fill(abs(GEM_eta), GEM_chamber);
778  m_histos.find("GEM_nFailingProbe_Ch_phi")->second->Fill(GEM_phi, GEM_chamber);
779  m_histos.find("GEM_nFailingProbe_allCh_1D")->second->Fill(GEM_region);
780  m_histos.find("GEM_nFailingProbe_chamber_1D")->second->Fill(GEM_chamber);
781  if (GEM_region < 0) {
782  if (GEM_sta == 2 and GEM_lay == 2)
783  m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(0, GEM_chamber);
784  else if (GEM_sta == 2 and GEM_lay == 1)
785  m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(1, GEM_chamber);
786  else if (GEM_sta == 1 and GEM_lay == 2)
787  m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(2, GEM_chamber);
788  else if (GEM_sta == 1 and GEM_lay == 1)
789  m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(3, GEM_chamber);
790  }
791  if (GEM_region > 0) {
792  if (GEM_sta == 1 and GEM_lay == 1)
793  m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(6, GEM_chamber);
794  else if (GEM_sta == 1 and GEM_lay == 2)
795  m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(7, GEM_chamber);
796  else if (GEM_sta == 2 and GEM_lay == 1)
797  m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(8, GEM_chamber);
798  else if (GEM_sta == 2 and GEM_lay == 2)
799  m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(9, GEM_chamber);
800  }
801  if (GEM_region == -1 && GEM_sta == 1) {
802  m_histos.find("GEM_nFailingProbe_Ch_region_GE1_NoL")->second->Fill(0, GEM_chamber);
803  } else if (GEM_region == 1 && GEM_sta == 1) {
804  m_histos.find("GEM_nFailingProbe_Ch_region_GE1_NoL")->second->Fill(1, GEM_chamber);
805  }
806  //
807  if (GEM_region == 1 && GEM_lay == 1 && GEM_sta == 1) {
808  m_histos.find("GEM_nFailingProbe_chamber_p1_1D")->second->Fill(GEM_chamber);
809  m_histos.find("GEM_nFailingProbe_Ch_region_GE1")->second->Fill(2, GEM_chamber);
810  m_histos.find("GEM_nFailingProbe_pt_p1_1D")->second->Fill(GEM_pt);
811  m_histos.find("GEM_nFailingProbe_eta_p1_1D")->second->Fill(abs(GEM_eta));
812  m_histos.find("GEM_nFailingProbe_phi_p1_1D")->second->Fill(GEM_phi);
813  } else if (GEM_region == 1 && GEM_lay == 2 && GEM_sta == 1) {
814  m_histos.find("GEM_nFailingProbe_chamber_p2_1D")->second->Fill(GEM_chamber);
815  m_histos.find("GEM_nFailingProbe_Ch_region_GE1")->second->Fill(3, GEM_chamber);
816  m_histos.find("GEM_nFailingProbe_pt_p2_1D")->second->Fill(GEM_pt);
817  m_histos.find("GEM_nFailingProbe_eta_p2_1D")->second->Fill(abs(GEM_eta));
818  m_histos.find("GEM_nFailingProbe_phi_p2_1D")->second->Fill(GEM_phi);
819  } else if (GEM_region == -1 && GEM_lay == 1 && GEM_sta == 1) {
820  m_histos.find("GEM_nFailingProbe_chamber_n1_1D")->second->Fill(GEM_chamber);
821  m_histos.find("GEM_nFailingProbe_Ch_region_GE1")->second->Fill(1, GEM_chamber);
822  m_histos.find("GEM_nFailingProbe_pt_n1_1D")->second->Fill(GEM_pt);
823  m_histos.find("GEM_nFailingProbe_eta_n1_1D")->second->Fill(abs(GEM_eta));
824  m_histos.find("GEM_nFailingProbe_phi_n1_1D")->second->Fill(GEM_phi);
825  } else if (GEM_region == -1 && GEM_lay == 2 && GEM_sta == 1) {
826  m_histos.find("GEM_nFailingProbe_chamber_n2_1D")->second->Fill(GEM_chamber);
827  m_histos.find("GEM_nFailingProbe_Ch_region_GE1")->second->Fill(0, GEM_chamber);
828  m_histos.find("GEM_nFailingProbe_pt_n2_1D")->second->Fill(GEM_pt);
829  m_histos.find("GEM_nFailingProbe_eta_n2_1D")->second->Fill(abs(GEM_eta));
830  m_histos.find("GEM_nFailingProbe_phi_n2_1D")->second->Fill(GEM_phi);
831  }
832  m_histos.find("GEM_nFailingProbe_pt_1D")->second->Fill(GEM_pt);
833  m_histos.find("GEM_nFailingProbe_eta_1D")->second->Fill(abs(GEM_eta));
834  m_histos.find("GEM_nFailingProbe_phi_1D")->second->Fill(GEM_phi);
835  }
836  }
837  }
838  }
839 }
static constexpr int GEM
Definition: MuonSubdetId.h:14
const edm::EDGetTokenT< reco::MuonCollection > m_muToken
constexpr std::array< uint8_t, layerIndexSize< TrackerTraits > > layer
std::vector< std::vector< unsigned > > m_probeIndices
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
std::map< std::string, MonitorElement * > m_histos
void analyze(const edm::Event &event, const edm::EventSetup &context) override
Analyze.
constexpr int roll() const
Definition: GEMDetId.h:194
Definition: event.py:1

◆ bookHistograms()

void GEMTnPEfficiencyTask::bookHistograms ( DQMStore::IBooker iBooker,
edm::Run const &  run,
edm::EventSetup const &  context 
)
overrideprotectedvirtual

Reimplemented from BaseTnPEfficiencyTask.

Definition at line 43 of file GEMTnPEfficiencyTask.cc.

References ALCARECODTCalibSynchDQM_cff::baseDir, dqm::implementation::IBooker::book1D(), dqm::implementation::IBooker::book2D(), BaseTnPEfficiencyTask::bookHistograms(), visDQMUpload::context, mps_fire::i, LogTrace, BaseTnPEfficiencyTask::m_histos, Pi, writedatasetfile::run, dqm::impl::MonitorElement::setAxisTitle(), dqm::impl::MonitorElement::setBinLabel(), dqm::implementation::NavigatorBase::setCurrentFolder(), AlCaHLTBitMon_QueryRunRegistry::string, cond::impl::to_string(), and topFolder().

45  {
47 
48  LogTrace("DQMOffline|MuonDPG|GEMTnPEfficiencyTask") << "[GEMTnPEfficiencyTask]: bookHistograms" << std::endl;
49 
50  auto baseDir = topFolder() + "Task/";
51  iBooker.setCurrentFolder(baseDir);
52 
53  MonitorElement* me_GEM_pass_Ch_region =
54  iBooker.book2D("GEM_nPassingProbe_Ch_region", "GEM_nPassingProbe_Ch_region", 2, -1.5, 1.5, 36, 1, 37);
55  MonitorElement* me_GEM_fail_Ch_region =
56  iBooker.book2D("GEM_nFailingProbe_Ch_region", "GEM_nFailingProbe_Ch_region", 2, -1.5, 1.5, 36, 1, 37);
57  MonitorElement* me_GEM_pass_Ch_region_GE1 =
58  iBooker.book2D("GEM_nPassingProbe_Ch_region_GE1", "GEM_nPassingProbe_Ch_region_GE1", 4, 0, 4, 36, 1, 37);
59  MonitorElement* me_GEM_fail_Ch_region_GE1 =
60  iBooker.book2D("GEM_nFailingProbe_Ch_region_GE1", "GEM_nFailingProbe_Ch_region_GE1", 4, 0, 4, 36, 1, 37);
61  MonitorElement* me_GEM_pass_Ch_region_GE1_NoL =
62  iBooker.book2D("GEM_nPassingProbe_Ch_region_GE1_NoL", "GEM_nPassingProbe_Ch_region_GE1_NoL", 2, 0, 2, 36, 1, 37);
63  MonitorElement* me_GEM_fail_Ch_region_GE1_NoL =
64  iBooker.book2D("GEM_nFailingProbe_Ch_region_GE1_NoL", "GEM_nFailingProbe_Ch_region_GE1_NoL", 2, 0, 2, 36, 1, 37);
65  MonitorElement* me_GEM_pass_Ch_eta =
66  iBooker.book2D("GEM_nPassingProbe_Ch_eta", "GEM_nPassingProbe_Ch_eta", 24, 0, 2.4, 36, 1, 37);
67  MonitorElement* me_GEM_fail_Ch_eta =
68  iBooker.book2D("GEM_nFailingProbe_Ch_eta", "GEM_nFailingProbe_Ch_eta", 24, 0, 2.4, 36, 1, 37);
69  MonitorElement* me_GEM_pass_Ch_phi =
70  iBooker.book2D("GEM_nPassingProbe_Ch_phi", "GEM_nPassingProbe_Ch_phi", 20, -TMath::Pi(), TMath::Pi(), 36, 1, 37);
71  MonitorElement* me_GEM_fail_Ch_phi =
72  iBooker.book2D("GEM_nFailingProbe_Ch_phi", "GEM_nFailingProbe_Ch_phi", 20, -TMath::Pi(), TMath::Pi(), 36, 1, 37);
73  MonitorElement* me_GEM_pass_allCh_1D =
74  iBooker.book1D("GEM_nPassingProbe_allCh_1D", "GEM_nPassingProbe_allCh_1D", 2, -1.5, 1.5);
75  MonitorElement* me_GEM_fail_allCh_1D =
76  iBooker.book1D("GEM_nFailingProbe_allCh_1D", "GEM_nFailingProbe_allCh_1D", 2, -1.5, 1.5);
77  MonitorElement* me_GEM_pass_chamber_1D =
78  iBooker.book1D("GEM_nPassingProbe_chamber_1D", "GEM_nPassingProbe_chamber_1D", 36, 1, 37);
79  MonitorElement* me_GEM_fail_chamber_1D =
80  iBooker.book1D("GEM_nFailingProbe_chamber_1D", "GEM_nFailingProbe_chamber_1D", 36, 1, 37);
81  MonitorElement* me_GEM_pass_chamber_p1_1D =
82  iBooker.book1D("GEM_nPassingProbe_chamber_p1_1D", "GEM_nPassingProbe_chamber_p1_1D", 36, 1, 37);
83  MonitorElement* me_GEM_fail_chamber_p1_1D =
84  iBooker.book1D("GEM_nFailingProbe_chamber_p1_1D", "GEM_nFailingProbe_chamber_p1_1D", 36, 1, 37);
85  MonitorElement* me_GEM_pass_chamber_p2_1D =
86  iBooker.book1D("GEM_nPassingProbe_chamber_p2_1D", "GEM_nPassingProbe_chamber_p2_1D", 36, 1, 37);
87  MonitorElement* me_GEM_fail_chamber_p2_1D =
88  iBooker.book1D("GEM_nFailingProbe_chamber_p2_1D", "GEM_nFailingProbe_chamber_p2_1D", 36, 1, 37);
89  MonitorElement* me_GEM_pass_chamber_n1_1D =
90  iBooker.book1D("GEM_nPassingProbe_chamber_n1_1D", "GEM_nPassingProbe_chamber_n1_1D", 36, 1, 37);
91  MonitorElement* me_GEM_fail_chamber_n1_1D =
92  iBooker.book1D("GEM_nFailingProbe_chamber_n1_1D", "GEM_nFailingProbe_chamber_n1_1D", 36, 1, 37);
93  MonitorElement* me_GEM_pass_chamber_n2_1D =
94  iBooker.book1D("GEM_nPassingProbe_chamber_n2_1D", "GEM_nPassingProbe_chamber_n2_1D", 36, 1, 37);
95  MonitorElement* me_GEM_fail_chamber_n2_1D =
96  iBooker.book1D("GEM_nFailingProbe_chamber_n2_1D", "GEM_nFailingProbe_chamber_n2_1D", 36, 1, 37);
97  //
98  MonitorElement* me_GEM_pass_pt_1D = iBooker.book1D("GEM_nPassingProbe_pt_1D", "GEM_nPassingProbe_pt_1D", 20, 0, 100);
99  MonitorElement* me_GEM_fail_pt_1D = iBooker.book1D("GEM_nFailingProbe_pt_1D", "GEM_nFailingProbe_pt_1D", 20, 0, 100);
100  MonitorElement* me_GEM_pass_eta_1D =
101  iBooker.book1D("GEM_nPassingProbe_eta_1D", "GEM_nPassingProbe_eta_1D", 24, 0, 2.4);
102  MonitorElement* me_GEM_fail_eta_1D =
103  iBooker.book1D("GEM_nFailingProbe_eta_1D", "GEM_nFailingProbe_eta_1D", 24, 0, 2.4);
104  MonitorElement* me_GEM_pass_phi_1D =
105  iBooker.book1D("GEM_nPassingProbe_phi_1D", "GEM_nPassingProbe_phi_1D", 20, -TMath::Pi(), TMath::Pi());
106  MonitorElement* me_GEM_fail_phi_1D =
107  iBooker.book1D("GEM_nFailingProbe_phi_1D", "GEM_nFailingProbe_phi_1D", 20, -TMath::Pi(), TMath::Pi());
109  MonitorElement* me_GEM_pass_pt_p1_1D =
110  iBooker.book1D("GEM_nPassingProbe_pt_p1_1D", "GEM_nPassingProbe_pt_p1_1D", 20, 0, 100);
111  MonitorElement* me_GEM_fail_pt_p1_1D =
112  iBooker.book1D("GEM_nFailingProbe_pt_p1_1D", "GEM_nFailingProbe_pt_p1_1D", 20, 0, 100);
113  MonitorElement* me_GEM_pass_eta_p1_1D =
114  iBooker.book1D("GEM_nPassingProbe_eta_p1_1D", "GEM_nPassingProbe_eta_p1_1D", 24, 0, 2.4);
115  MonitorElement* me_GEM_fail_eta_p1_1D =
116  iBooker.book1D("GEM_nFailingProbe_eta_p1_1D", "GEM_nFailingProbe_eta_p1_1D", 24, 0, 2.4);
117  MonitorElement* me_GEM_pass_phi_p1_1D =
118  iBooker.book1D("GEM_nPassingProbe_phi_p1_1D", "GEM_nPassingProbe_phi_p1_1D", 20, -TMath::Pi(), TMath::Pi());
119  MonitorElement* me_GEM_fail_phi_p1_1D =
120  iBooker.book1D("GEM_nFailingProbe_phi_p1_1D", "GEM_nFailingProbe_phi_p1_1D", 20, -TMath::Pi(), TMath::Pi());
121  MonitorElement* me_GEM_pass_pt_p2_1D =
122  iBooker.book1D("GEM_nPassingProbe_pt_p2_1D", "GEM_nPassingProbe_pt_p2_1D", 20, 0, 100);
123  MonitorElement* me_GEM_fail_pt_p2_1D =
124  iBooker.book1D("GEM_nFailingProbe_pt_p2_1D", "GEM_nFailingProbe_pt_p2_1D", 20, 0, 100);
125  MonitorElement* me_GEM_pass_eta_p2_1D =
126  iBooker.book1D("GEM_nPassingProbe_eta_p2_1D", "GEM_nPassingProbe_eta_p2_1D", 24, 0, 2.4);
127  MonitorElement* me_GEM_fail_eta_p2_1D =
128  iBooker.book1D("GEM_nFailingProbe_eta_p2_1D", "GEM_nFailingProbe_eta_p2_1D", 24, 0, 2.4);
129  MonitorElement* me_GEM_pass_phi_p2_1D =
130  iBooker.book1D("GEM_nPassingProbe_phi_p2_1D", "GEM_nPassingProbe_phi_p2_1D", 20, -TMath::Pi(), TMath::Pi());
131  MonitorElement* me_GEM_fail_phi_p2_1D =
132  iBooker.book1D("GEM_nFailingProbe_phi_p2_1D", "GEM_nFailingProbe_phi_p2_1D", 20, -TMath::Pi(), TMath::Pi());
133  MonitorElement* me_GEM_pass_pt_n1_1D =
134  iBooker.book1D("GEM_nPassingProbe_pt_n1_1D", "GEM_nPassingProbe_pt_n1_1D", 20, 0, 100);
135  MonitorElement* me_GEM_fail_pt_n1_1D =
136  iBooker.book1D("GEM_nFailingProbe_pt_n1_1D", "GEM_nFailingProbe_pt_n1_1D", 20, 0, 100);
137  MonitorElement* me_GEM_pass_eta_n1_1D =
138  iBooker.book1D("GEM_nPassingProbe_eta_n1_1D", "GEM_nPassingProbe_eta_n1_1D", 24, 0, 2.4);
139  MonitorElement* me_GEM_fail_eta_n1_1D =
140  iBooker.book1D("GEM_nFailingProbe_eta_n1_1D", "GEM_nFailingProbe_eta_n1_1D", 24, 0, 2.4);
141  MonitorElement* me_GEM_pass_phi_n1_1D =
142  iBooker.book1D("GEM_nPassingProbe_phi_n1_1D", "GEM_nPassingProbe_phi_n1_1D", 20, -TMath::Pi(), TMath::Pi());
143  MonitorElement* me_GEM_fail_phi_n1_1D =
144  iBooker.book1D("GEM_nFailingProbe_phi_n1_1D", "GEM_nFailingProbe_phi_n1_1D", 20, -TMath::Pi(), TMath::Pi());
145  MonitorElement* me_GEM_pass_pt_n2_1D =
146  iBooker.book1D("GEM_nPassingProbe_pt_n2_1D", "GEM_nPassingProbe_pt_n2_1D", 20, 0, 100);
147  MonitorElement* me_GEM_fail_pt_n2_1D =
148  iBooker.book1D("GEM_nFailingProbe_pt_n2_1D", "GEM_nFailingProbe_pt_n2_1D", 20, 0, 100);
149  MonitorElement* me_GEM_pass_eta_n2_1D =
150  iBooker.book1D("GEM_nPassingProbe_eta_n2_1D", "GEM_nPassingProbe_eta_n2_1D", 24, 0, 2.4);
151  MonitorElement* me_GEM_fail_eta_n2_1D =
152  iBooker.book1D("GEM_nFailingProbe_eta_n2_1D", "GEM_nFailingProbe_eta_n2_1D", 24, 0, 2.4);
153  MonitorElement* me_GEM_pass_phi_n2_1D =
154  iBooker.book1D("GEM_nPassingProbe_phi_n2_1D", "GEM_nPassingProbe_phi_n2_1D", 20, -TMath::Pi(), TMath::Pi());
155  MonitorElement* me_GEM_fail_phi_n2_1D =
156  iBooker.book1D("GEM_nFailingProbe_phi_n2_1D", "GEM_nFailingProbe_phi_n2_1D", 20, -TMath::Pi(), TMath::Pi());
158  MonitorElement* me_ME0_pass_chamber_1D =
159  iBooker.book1D("ME0_nPassingProbe_chamber_1D", "ME0_nPassingProbe_chamber_1D", 18, 1, 19);
160  MonitorElement* me_ME0_fail_chamber_1D =
161  iBooker.book1D("ME0_nFailingProbe_chamber_1D", "ME0_nFailingProbe_chamber_1D", 18, 1, 19);
162  MonitorElement* me_GEM_pass_Ch_region_layer_phase2 = iBooker.book2D(
163  "GEM_nPassingProbe_Ch_region_layer_phase2", "GEM_nPassingProbe_Ch_region_layer_phase2", 10, 0, 10, 36, 1, 37);
164  MonitorElement* me_GEM_fail_Ch_region_layer_phase2 = iBooker.book2D(
165  "GEM_nFailingProbe_Ch_region_layer_phase2", "GEM_nFailingProbe_Ch_region_layer_phase2", 10, 0, 10, 36, 1, 37);
166 
167  me_GEM_pass_allCh_1D->setBinLabel(1, "GE-11", 1);
168  me_GEM_pass_allCh_1D->setBinLabel(2, "GE11", 1);
169  me_GEM_pass_allCh_1D->setAxisTitle("Number of passing probes", 2);
170 
171  me_GEM_fail_allCh_1D->setBinLabel(1, "GE-11", 1);
172  me_GEM_fail_allCh_1D->setBinLabel(2, "GE11", 1);
173  me_GEM_fail_allCh_1D->setAxisTitle("Number of failing probes", 2);
174 
175  me_GEM_pass_chamber_1D->setAxisTitle("Chamber", 1);
176  me_GEM_pass_chamber_1D->setAxisTitle("Number of passing probes", 2);
177  me_GEM_fail_chamber_1D->setAxisTitle("Chamber", 1);
178  me_GEM_fail_chamber_1D->setAxisTitle("Number of failing probes", 2);
179 
180  me_GEM_pass_chamber_p1_1D->setAxisTitle("Chamber", 1);
181  me_GEM_pass_chamber_p1_1D->setAxisTitle("Number of passing probes", 2);
182  me_GEM_fail_chamber_p1_1D->setAxisTitle("Chamber", 1);
183  me_GEM_fail_chamber_p1_1D->setAxisTitle("Number of failing probes", 2);
184 
185  me_GEM_pass_chamber_p2_1D->setAxisTitle("Chamber", 1);
186  me_GEM_pass_chamber_p2_1D->setAxisTitle("Number of passing probes", 2);
187  me_GEM_fail_chamber_p2_1D->setAxisTitle("Chamber", 1);
188  me_GEM_fail_chamber_p2_1D->setAxisTitle("Number of failing probes", 2);
189 
190  me_GEM_pass_chamber_n1_1D->setAxisTitle("Chamber", 1);
191  me_GEM_pass_chamber_n1_1D->setAxisTitle("Number of passing probes", 2);
192  me_GEM_fail_chamber_n1_1D->setAxisTitle("Chamber", 1);
193  me_GEM_fail_chamber_n1_1D->setAxisTitle("Number of failing probes", 2);
194 
195  me_GEM_pass_chamber_n2_1D->setAxisTitle("Chamber", 1);
196  me_GEM_pass_chamber_n2_1D->setAxisTitle("Number of passing probes", 2);
197  me_GEM_fail_chamber_n2_1D->setAxisTitle("Chamber", 1);
198  me_GEM_fail_chamber_n2_1D->setAxisTitle("Number of failing probes", 2);
199 
200  me_GEM_pass_pt_1D->setAxisTitle("P_{T}", 1);
201  me_GEM_pass_pt_1D->setAxisTitle("Number of passing probes", 2);
202  me_GEM_fail_pt_1D->setAxisTitle("P_{T}", 1);
203  me_GEM_fail_pt_1D->setAxisTitle("Number of failing probes", 2);
204 
205  me_GEM_pass_eta_1D->setAxisTitle("#eta", 1);
206  me_GEM_pass_eta_1D->setAxisTitle("Number of passing probes", 2);
207  me_GEM_fail_eta_1D->setAxisTitle("#eta", 1);
208  me_GEM_fail_eta_1D->setAxisTitle("Number of failing probes", 2);
209 
210  me_GEM_pass_phi_1D->setAxisTitle("#phi", 1);
211  me_GEM_pass_phi_1D->setAxisTitle("Number of passing probes", 2);
212  me_GEM_fail_phi_1D->setAxisTitle("#phi", 1);
213  me_GEM_fail_phi_1D->setAxisTitle("Number of failing probes", 2);
214 
215  me_GEM_pass_pt_p1_1D->setAxisTitle("P_{T}", 1);
216  me_GEM_pass_pt_p1_1D->setAxisTitle("Number of passing probes", 2);
217  me_GEM_fail_pt_p1_1D->setAxisTitle("P_{T}", 1);
218  me_GEM_fail_pt_p1_1D->setAxisTitle("Number of failing probes", 2);
219 
220  me_GEM_pass_eta_p1_1D->setAxisTitle("#eta", 1);
221  me_GEM_pass_eta_p1_1D->setAxisTitle("Number of passing probes", 2);
222  me_GEM_fail_eta_p1_1D->setAxisTitle("#eta", 1);
223  me_GEM_fail_eta_p1_1D->setAxisTitle("Number of failing probes", 2);
224 
225  me_GEM_pass_phi_p1_1D->setAxisTitle("#phi", 1);
226  me_GEM_pass_phi_p1_1D->setAxisTitle("Number of passing probes", 2);
227  me_GEM_fail_phi_p1_1D->setAxisTitle("#phi", 1);
228  me_GEM_fail_phi_p1_1D->setAxisTitle("Number of failing probes", 2);
229 
230  me_GEM_pass_pt_p2_1D->setAxisTitle("P_{T}", 1);
231  me_GEM_pass_pt_p2_1D->setAxisTitle("Number of passing probes", 2);
232  me_GEM_fail_pt_p2_1D->setAxisTitle("P_{T}", 1);
233  me_GEM_fail_pt_p2_1D->setAxisTitle("Number of failing probes", 2);
234 
235  me_GEM_pass_eta_p2_1D->setAxisTitle("#eta", 1);
236  me_GEM_pass_eta_p2_1D->setAxisTitle("Number of passing probes", 2);
237  me_GEM_fail_eta_p2_1D->setAxisTitle("#eta", 1);
238  me_GEM_fail_eta_p2_1D->setAxisTitle("Number of failing probes", 2);
239 
240  me_GEM_pass_phi_p2_1D->setAxisTitle("#phi", 1);
241  me_GEM_pass_phi_p2_1D->setAxisTitle("Number of passing probes", 2);
242  me_GEM_fail_phi_p2_1D->setAxisTitle("#phi", 1);
243  me_GEM_fail_phi_p2_1D->setAxisTitle("Number of failing probes", 2);
244 
245  me_GEM_pass_pt_n1_1D->setAxisTitle("P_{T}", 1);
246  me_GEM_pass_pt_n1_1D->setAxisTitle("Number of passing probes", 2);
247  me_GEM_fail_pt_n1_1D->setAxisTitle("P_{T}", 1);
248  me_GEM_fail_pt_n1_1D->setAxisTitle("Number of failing probes", 2);
249 
250  me_GEM_pass_eta_n1_1D->setAxisTitle("#eta", 1);
251  me_GEM_pass_eta_n1_1D->setAxisTitle("Number of passing probes", 2);
252  me_GEM_fail_eta_n1_1D->setAxisTitle("#eta", 1);
253  me_GEM_fail_eta_n1_1D->setAxisTitle("Number of failing probes", 2);
254 
255  me_GEM_pass_phi_n1_1D->setAxisTitle("#phi", 1);
256  me_GEM_pass_phi_n1_1D->setAxisTitle("Number of passing probes", 2);
257  me_GEM_fail_phi_n1_1D->setAxisTitle("#phi", 1);
258  me_GEM_fail_phi_n1_1D->setAxisTitle("Number of failing probes", 2);
259 
260  me_GEM_pass_pt_n2_1D->setAxisTitle("P_{T}", 1);
261  me_GEM_pass_pt_n2_1D->setAxisTitle("Number of passing probes", 2);
262  me_GEM_fail_pt_n2_1D->setAxisTitle("P_{T}", 1);
263  me_GEM_fail_pt_n2_1D->setAxisTitle("Number of failing probes", 2);
264 
265  me_GEM_pass_eta_n2_1D->setAxisTitle("#eta", 1);
266  me_GEM_pass_eta_n2_1D->setAxisTitle("Number of passing probes", 2);
267  me_GEM_fail_eta_n2_1D->setAxisTitle("#eta", 1);
268  me_GEM_fail_eta_n2_1D->setAxisTitle("Number of failing probes", 2);
269 
270  me_GEM_pass_phi_n2_1D->setAxisTitle("#phi", 1);
271  me_GEM_pass_phi_n2_1D->setAxisTitle("Number of passing probes", 2);
272  me_GEM_fail_phi_n2_1D->setAxisTitle("#phi", 1);
273  me_GEM_fail_phi_n2_1D->setAxisTitle("Number of failing probes", 2);
274 
275  me_GEM_fail_Ch_region->setBinLabel(1, "GE-11", 1);
276  me_GEM_fail_Ch_region->setBinLabel(2, "GE11", 1);
277  for (int i = 1; i < 37; ++i) {
278  me_GEM_fail_Ch_region->setBinLabel(i, std::to_string(i), 2);
279  }
280  me_GEM_fail_Ch_region->setAxisTitle("Chamber", 2);
281  me_GEM_fail_Ch_region->setAxisTitle("Number of failing probes", 3);
282 
283  me_GEM_pass_Ch_region->setBinLabel(1, "GE-11", 1);
284  me_GEM_pass_Ch_region->setBinLabel(2, "GE11", 1);
285  for (int i = 1; i < 37; ++i) {
286  me_GEM_pass_Ch_region->setBinLabel(i, std::to_string(i), 2);
287  }
288  me_GEM_pass_Ch_region->setAxisTitle("Chamber", 2);
289  me_GEM_pass_Ch_region->setAxisTitle("Number of passing probes", 3);
290 
291  me_GEM_fail_Ch_region_GE1->setBinLabel(1, "GE-1/1_L2", 1);
292  me_GEM_fail_Ch_region_GE1->setBinLabel(2, "GE-1/1_L1", 1);
293  me_GEM_fail_Ch_region_GE1->setBinLabel(3, "GE1/1_L1", 1);
294  me_GEM_fail_Ch_region_GE1->setBinLabel(4, "GE1/1_L2", 1);
295  for (int i = 1; i < 37; ++i) {
296  me_GEM_fail_Ch_region_GE1->setBinLabel(i, std::to_string(i), 2);
297  }
298  me_GEM_fail_Ch_region_GE1->setAxisTitle("Chamber", 2);
299  me_GEM_fail_Ch_region_GE1->setAxisTitle("Number of passing probes", 3);
300 
301  me_GEM_pass_Ch_region_GE1->setBinLabel(1, "GE-1/1_L2", 1);
302  me_GEM_pass_Ch_region_GE1->setBinLabel(2, "GE-1/1_L1", 1);
303  me_GEM_pass_Ch_region_GE1->setBinLabel(3, "GE1/1_L1", 1);
304  me_GEM_pass_Ch_region_GE1->setBinLabel(4, "GE1/1_L2", 1);
305  for (int i = 1; i < 37; ++i) {
306  me_GEM_pass_Ch_region_GE1->setBinLabel(i, std::to_string(i), 2);
307  }
308  me_GEM_pass_Ch_region_GE1->setAxisTitle("Chamber", 2);
309  me_GEM_pass_Ch_region_GE1->setAxisTitle("Number of passing probes", 3);
310 
311  me_GEM_fail_Ch_region_GE1_NoL->setBinLabel(1, "GE-1", 1);
312  me_GEM_fail_Ch_region_GE1_NoL->setBinLabel(2, "GE+1", 1);
313  for (int i = 1; i < 37; ++i) {
314  me_GEM_fail_Ch_region_GE1_NoL->setBinLabel(i, std::to_string(i), 2);
315  }
316  me_GEM_fail_Ch_region_GE1_NoL->setAxisTitle("Chamber", 2);
317  me_GEM_fail_Ch_region_GE1_NoL->setAxisTitle("Number of passing probes", 3);
318 
319  me_GEM_pass_Ch_region_GE1_NoL->setBinLabel(1, "GE-1", 1);
320  me_GEM_pass_Ch_region_GE1_NoL->setBinLabel(2, "GE+1", 1);
321  for (int i = 1; i < 37; ++i) {
322  me_GEM_pass_Ch_region_GE1_NoL->setBinLabel(i, std::to_string(i), 2);
323  }
324  me_GEM_pass_Ch_region_GE1_NoL->setAxisTitle("Chamber", 2);
325  me_GEM_pass_Ch_region_GE1_NoL->setAxisTitle("Number of passing probes", 3);
326 
327  for (int i = 1; i < 37; ++i) {
328  me_GEM_fail_Ch_eta->setBinLabel(i, std::to_string(i), 2);
329  }
330  me_GEM_fail_Ch_eta->setAxisTitle("#eta", 1);
331  me_GEM_fail_Ch_eta->setAxisTitle("Chamber", 2);
332  me_GEM_fail_Ch_eta->setAxisTitle("Number of failing probes", 3);
333 
334  for (int i = 1; i < 37; ++i) {
335  me_GEM_pass_Ch_eta->setBinLabel(i, std::to_string(i), 2);
336  }
337  me_GEM_pass_Ch_eta->setAxisTitle("#eta", 1);
338  me_GEM_pass_Ch_eta->setAxisTitle("Chamber", 2);
339  me_GEM_pass_Ch_eta->setAxisTitle("Number of passing probes", 3);
340 
341  for (int i = 1; i < 37; ++i) {
342  me_GEM_fail_Ch_phi->setBinLabel(i, std::to_string(i), 2);
343  }
344  me_GEM_fail_Ch_phi->setAxisTitle("#phi", 1);
345  me_GEM_fail_Ch_phi->setAxisTitle("Chamber", 2);
346  me_GEM_fail_Ch_phi->setAxisTitle("Number of failing probes", 3);
347 
348  for (int i = 1; i < 37; ++i) {
349  me_GEM_pass_Ch_phi->setBinLabel(i, std::to_string(i), 2);
350  }
351  me_GEM_pass_Ch_phi->setAxisTitle("#phi", 1);
352  me_GEM_pass_Ch_phi->setAxisTitle("Chamber", 2);
353  me_GEM_pass_Ch_phi->setAxisTitle("Number of passing probes", 3);
354 
355  for (int i = 1; i < 19; ++i) {
356  me_ME0_pass_chamber_1D->setBinLabel(i, std::to_string(i), 1);
357  }
358  me_ME0_pass_chamber_1D->setAxisTitle("Chamber", 1);
359  me_ME0_pass_chamber_1D->setAxisTitle("Number of passing probes", 2);
360  for (int i = 1; i < 19; ++i) {
361  me_ME0_fail_chamber_1D->setBinLabel(i, std::to_string(i), 1);
362  }
363  me_ME0_fail_chamber_1D->setAxisTitle("Chamber", 1);
364  me_ME0_fail_chamber_1D->setAxisTitle("Number of failing probes", 2);
365 
366  me_GEM_fail_Ch_region_layer_phase2->setBinLabel(1, "GE-2/1_L2", 1);
367  me_GEM_fail_Ch_region_layer_phase2->setBinLabel(2, "GE-2/1_L1", 1);
368  me_GEM_fail_Ch_region_layer_phase2->setBinLabel(3, "GE-1/1_L2", 1);
369  me_GEM_fail_Ch_region_layer_phase2->setBinLabel(4, "GE-1/1_L1", 1);
370  me_GEM_fail_Ch_region_layer_phase2->setBinLabel(5, "GE0-1", 1);
371  me_GEM_fail_Ch_region_layer_phase2->setBinLabel(6, "GE0+1", 1);
372  me_GEM_fail_Ch_region_layer_phase2->setBinLabel(7, "GE1/1_L1", 1);
373  me_GEM_fail_Ch_region_layer_phase2->setBinLabel(8, "GE1/1_L2", 1);
374  me_GEM_fail_Ch_region_layer_phase2->setBinLabel(9, "GE2/1_L1", 1);
375  me_GEM_fail_Ch_region_layer_phase2->setBinLabel(10, "GE2/1_L2", 1);
376  for (int i = 1; i < 37; ++i) {
377  me_GEM_fail_Ch_region_layer_phase2->setBinLabel(i, std::to_string(i), 2);
378  }
379  me_GEM_fail_Ch_region_layer_phase2->setAxisTitle("Chamber", 2);
380  me_GEM_fail_Ch_region_layer_phase2->setAxisTitle("Number of passing probes", 3);
381 
382  me_GEM_pass_Ch_region_layer_phase2->setBinLabel(1, "GE-2/1_L2", 1);
383  me_GEM_pass_Ch_region_layer_phase2->setBinLabel(2, "GE-2/1_L1", 1);
384  me_GEM_pass_Ch_region_layer_phase2->setBinLabel(3, "GE-1/1_L2", 1);
385  me_GEM_pass_Ch_region_layer_phase2->setBinLabel(4, "GE-1/1_L1", 1);
386  me_GEM_pass_Ch_region_layer_phase2->setBinLabel(5, "GE0-1", 1);
387  me_GEM_pass_Ch_region_layer_phase2->setBinLabel(6, "GE0+1", 1);
388  me_GEM_pass_Ch_region_layer_phase2->setBinLabel(7, "GE1/1_L1", 1);
389  me_GEM_pass_Ch_region_layer_phase2->setBinLabel(8, "GE1/1_L2", 1);
390  me_GEM_pass_Ch_region_layer_phase2->setBinLabel(9, "GE2/1_L1", 1);
391  me_GEM_pass_Ch_region_layer_phase2->setBinLabel(10, "GE2/1_L2", 1);
392 
393  for (int i = 1; i < 37; ++i) {
394  me_GEM_pass_Ch_region_layer_phase2->setBinLabel(i, std::to_string(i), 2);
395  }
396  me_GEM_pass_Ch_region_layer_phase2->setAxisTitle("Chamber", 2);
397  me_GEM_pass_Ch_region_layer_phase2->setAxisTitle("Number of passing probes", 3);
398 
399  m_histos["GEM_nPassingProbe_Ch_region"] = me_GEM_pass_Ch_region;
400  m_histos["GEM_nFailingProbe_Ch_region"] = me_GEM_fail_Ch_region;
401  m_histos["GEM_nPassingProbe_Ch_region_GE1"] = me_GEM_pass_Ch_region_GE1;
402  m_histos["GEM_nFailingProbe_Ch_region_GE1"] = me_GEM_fail_Ch_region_GE1;
403  m_histos["GEM_nPassingProbe_Ch_region_GE1_NoL"] = me_GEM_pass_Ch_region_GE1_NoL;
404  m_histos["GEM_nFailingProbe_Ch_region_GE1_NoL"] = me_GEM_fail_Ch_region_GE1_NoL;
405  m_histos["GEM_nPassingProbe_Ch_eta"] = me_GEM_pass_Ch_eta;
406  m_histos["GEM_nFailingProbe_Ch_eta"] = me_GEM_fail_Ch_eta;
407  m_histos["GEM_nPassingProbe_Ch_phi"] = me_GEM_pass_Ch_phi;
408  m_histos["GEM_nFailingProbe_Ch_phi"] = me_GEM_fail_Ch_phi;
409  m_histos["GEM_nPassingProbe_allCh_1D"] = me_GEM_pass_allCh_1D;
410  m_histos["GEM_nFailingProbe_allCh_1D"] = me_GEM_fail_allCh_1D;
411  m_histos["GEM_nPassingProbe_chamber_1D"] = me_GEM_pass_chamber_1D;
412  m_histos["GEM_nFailingProbe_chamber_1D"] = me_GEM_fail_chamber_1D;
413  m_histos["GEM_nPassingProbe_chamber_p1_1D"] = me_GEM_pass_chamber_p1_1D;
414  m_histos["GEM_nFailingProbe_chamber_p1_1D"] = me_GEM_fail_chamber_p1_1D;
415  m_histos["GEM_nPassingProbe_chamber_p2_1D"] = me_GEM_pass_chamber_p2_1D;
416  m_histos["GEM_nFailingProbe_chamber_p2_1D"] = me_GEM_fail_chamber_p2_1D;
417  m_histos["GEM_nPassingProbe_chamber_n1_1D"] = me_GEM_pass_chamber_n1_1D;
418  m_histos["GEM_nFailingProbe_chamber_n1_1D"] = me_GEM_fail_chamber_n1_1D;
419  m_histos["GEM_nPassingProbe_chamber_n2_1D"] = me_GEM_pass_chamber_n2_1D;
420  m_histos["GEM_nFailingProbe_chamber_n2_1D"] = me_GEM_fail_chamber_n2_1D;
421  m_histos["GEM_nPassingProbe_pt_1D"] = me_GEM_pass_pt_1D;
422  m_histos["GEM_nFailingProbe_pt_1D"] = me_GEM_fail_pt_1D;
423  m_histos["GEM_nPassingProbe_eta_1D"] = me_GEM_pass_eta_1D;
424  m_histos["GEM_nFailingProbe_eta_1D"] = me_GEM_fail_eta_1D;
425  m_histos["GEM_nPassingProbe_phi_1D"] = me_GEM_pass_phi_1D;
426  m_histos["GEM_nFailingProbe_phi_1D"] = me_GEM_fail_phi_1D;
427  m_histos["GEM_nPassingProbe_pt_p1_1D"] = me_GEM_pass_pt_p1_1D;
428  m_histos["GEM_nFailingProbe_pt_p1_1D"] = me_GEM_fail_pt_p1_1D;
429  m_histos["GEM_nPassingProbe_eta_p1_1D"] = me_GEM_pass_eta_p1_1D;
430  m_histos["GEM_nFailingProbe_eta_p1_1D"] = me_GEM_fail_eta_p1_1D;
431  m_histos["GEM_nPassingProbe_phi_p1_1D"] = me_GEM_pass_phi_p1_1D;
432  m_histos["GEM_nFailingProbe_phi_p1_1D"] = me_GEM_fail_phi_p1_1D;
433  m_histos["GEM_nPassingProbe_pt_p2_1D"] = me_GEM_pass_pt_p2_1D;
434  m_histos["GEM_nFailingProbe_pt_p2_1D"] = me_GEM_fail_pt_p2_1D;
435  m_histos["GEM_nPassingProbe_eta_p2_1D"] = me_GEM_pass_eta_p2_1D;
436  m_histos["GEM_nFailingProbe_eta_p2_1D"] = me_GEM_fail_eta_p2_1D;
437  m_histos["GEM_nPassingProbe_phi_p2_1D"] = me_GEM_pass_phi_p2_1D;
438  m_histos["GEM_nFailingProbe_phi_p2_1D"] = me_GEM_fail_phi_p2_1D;
439  m_histos["GEM_nPassingProbe_pt_n1_1D"] = me_GEM_pass_pt_n1_1D;
440  m_histos["GEM_nFailingProbe_pt_n1_1D"] = me_GEM_fail_pt_n1_1D;
441  m_histos["GEM_nPassingProbe_eta_n1_1D"] = me_GEM_pass_eta_n1_1D;
442  m_histos["GEM_nFailingProbe_eta_n1_1D"] = me_GEM_fail_eta_n1_1D;
443  m_histos["GEM_nPassingProbe_phi_n1_1D"] = me_GEM_pass_phi_n1_1D;
444  m_histos["GEM_nFailingProbe_phi_n1_1D"] = me_GEM_fail_phi_n1_1D;
445  m_histos["GEM_nPassingProbe_pt_n2_1D"] = me_GEM_pass_pt_n2_1D;
446  m_histos["GEM_nFailingProbe_pt_n2_1D"] = me_GEM_fail_pt_n2_1D;
447  m_histos["GEM_nPassingProbe_eta_n2_1D"] = me_GEM_pass_eta_n2_1D;
448  m_histos["GEM_nFailingProbe_eta_n2_1D"] = me_GEM_fail_eta_n2_1D;
449  m_histos["GEM_nPassingProbe_phi_n2_1D"] = me_GEM_pass_phi_n2_1D;
450  m_histos["GEM_nFailingProbe_phi_n2_1D"] = me_GEM_fail_phi_n2_1D;
451  m_histos["ME0_nPassingProbe_chamber_1D"] = me_ME0_pass_chamber_1D;
452  m_histos["ME0_nFailingProbe_chamber_1D"] = me_ME0_fail_chamber_1D;
453  m_histos["GEM_nPassingProbe_Ch_region_layer_phase2"] = me_GEM_pass_Ch_region_layer_phase2;
454  m_histos["GEM_nFailingProbe_Ch_region_layer_phase2"] = me_GEM_fail_Ch_region_layer_phase2;
455 
456  std::string baseDir_ = topFolder() + "/detailed/";
457  iBooker.setCurrentFolder(baseDir_);
458  m_histos["GEMhit_dx"] = iBooker.book1D("GEMhit_dx", "GEMhit_dx;probe dx [cm];Events", 100, 0., 10.);
459  m_histos["GEMseg_dx"] = iBooker.book1D("GEMseg_dx", "GEMseg_dx;probe dx [cm];Events", 100, 0., 20.);
460 
461  m_histos["GEMhit_x"] = iBooker.book1D("GEMhit_x", "GEMhit_x;probe x [cm];Events", 100, -10., 10.);
462  m_histos["GEMhit_x_GE2"] = iBooker.book1D("GEMhit_x_GE2", "GEMhit_x;probe x [cm];Events", 100, -10., 10.);
463  m_histos["Cham_x"] = iBooker.book1D("Cham_x", "Cham_x;probe x [cm];Events", 100, -10., 10.);
464  m_histos["Cham_x_GE2"] = iBooker.book1D("Cham_x_GE2", "Cham_x;probe x [cm];Events", 100, -10., 10.);
465 
466  m_histos["GEMhit_dx_GE2"] = iBooker.book1D("GEMhit_dx_GE2", "GEMhit_dx;probe dx [cm];Events", 100, 0., 10.);
467 }
const double Pi
virtual void setCurrentFolder(std::string const &fullpath)
Definition: DQMStore.cc:36
std::string to_string(const V &value)
Definition: OMSAccess.h:71
#define LogTrace(id)
std::map< std::string, MonitorElement * > m_histos
virtual 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)
void bookHistograms(DQMStore::IBooker &iBooker, edm::Run const &run, edm::EventSetup const &context) override
MonitorElement * book2D(TString const &name, TString const &title, int nchX, double lowX, double highX, int nchY, double lowY, double highY, FUNC onbooking=NOOP())
Definition: DQMStore.h:212
std::string topFolder() const override
Return the top folder.
MonitorElement * book1D(TString const &name, TString const &title, int const nchX, double const lowX, double const highX, FUNC onbooking=NOOP())
Definition: DQMStore.h:98
virtual void setAxisTitle(const std::string &title, int axis=1)
set x-, y- or z-axis title (axis=1, 2, 3 respectively)

◆ topFolder()

std::string GEMTnPEfficiencyTask::topFolder ( ) const
overrideprotectedvirtual

Return the top folder.

Implements BaseTnPEfficiencyTask.

Definition at line 841 of file GEMTnPEfficiencyTask.cc.

Referenced by bookHistograms().

841 { return "GEM/Segment_TnP/"; };