CMS 3D CMS Logo

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

#include <GEMDigiSource.h>

Inheritance diagram for GEMDigiSource:
GEMDQMBase DQMEDAnalyzer edm::stream::EDProducer< edm::GlobalCache< DQMEDAnalyzerGlobalCache >, edm::EndRunProducer, edm::EndLuminosityBlockProducer, edm::Accumulator >

Public Member Functions

 GEMDigiSource (const edm::ParameterSet &cfg)
 
 ~GEMDigiSource () override
 
- Public Member Functions inherited from GEMDQMBase
 GEMDQMBase (const edm::ParameterSet &cfg)
 
int readGeometryPhiInfoChamber (const GEMStation *station, MEStationInfo &stationInfo)
 
int readGeometryRadiusInfoChamber (const GEMStation *station, MEStationInfo &stationInfo)
 
 ~GEMDQMBase () override
 
- 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
 

Static Public Member Functions

static void fillDescriptions (edm::ConfigurationDescriptions &descriptions)
 
- 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
< DQMEDAnalyzerGlobalCache
initializeGlobalCache (edm::ParameterSet const &)
 

Protected Member Functions

void analyze (edm::Event const &e, edm::EventSetup const &eSetup) override
 
void bookHistograms (DQMStore::IBooker &, edm::Run const &, edm::EventSetup const &) override
 
void dqmBeginRun (edm::Run const &, edm::EventSetup const &) override
 
- Protected Member Functions inherited from GEMDQMBase
template<typename T >
bool checkRefs (const std::vector< T * > &)
 
dqm::impl::MonitorElementCreateSummaryHist (DQMStore::IBooker &ibooker, TString strName)
 
int GenerateMEPerChamber (DQMStore::IBooker &ibooker)
 
int getDetOccXBin (const int, const int, const int)
 
int getIEtaFromVFAT (const int station, const int vfat)
 
int getIEtaFromVFATGE11 (const int vfat)
 
int getMaxVFAT (const int)
 
std::string getNameDirLayer (ME3IdsKey key3)
 
int getNumEtaPartitions (const GEMStation *)
 
int getVFATNumber (const int, const int, const int)
 
int getVFATNumberByDigi (const int, const int, const int)
 
int getVFATNumberGE11 (const int, const int, const int)
 
int initGeometry (edm::EventSetup const &iSetup)
 
ME2IdsKey key3Tokey2 (ME3IdsKey key)
 
ME3IdsKey key4Tokey3 (ME4IdsKey key)
 
int keyToChamber (ME4IdsKey key)
 
int keyToIEta (ME3IdsKey key)
 
int keyToIEta (ME4IdsKey key)
 
int keyToLayer (ME3IdsKey key)
 
int keyToLayer (ME4IdsKey key)
 
int keyToRegion (ME2IdsKey key)
 
int keyToRegion (ME3IdsKey key)
 
int keyToRegion (ME4IdsKey key)
 
int keyToStation (ME2IdsKey key)
 
int keyToStation (ME3IdsKey key)
 
int keyToStation (ME4IdsKey key)
 
int loadChambers ()
 
virtual int ProcessWithMEMap2AbsReWithEta (BookingHelper &bh, ME3IdsKey key)
 
virtual int ProcessWithMEMap4 (BookingHelper &bh, ME4IdsKey key)
 
Float_t restrictAngle (const Float_t fTheta, const Float_t fStart)
 
int SortingLayers (std::vector< ME3IdsKey > &listLayers)
 
- Protected Member Functions inherited from DQMEDAnalyzer
uint64_t meId () const
 

Private Member Functions

int ProcessWithMEMap2 (BookingHelper &bh, ME2IdsKey key) override
 
int ProcessWithMEMap2WithEta (BookingHelper &bh, ME3IdsKey key) override
 
int ProcessWithMEMap3 (BookingHelper &bh, ME3IdsKey key) override
 
int ProcessWithMEMap3WithChamber (BookingHelper &bh, ME4IdsKey key) override
 

Private Attributes

Float_t fRadiusMax_
 
Float_t fRadiusMin_
 
edm::EDGetTokenT
< LumiScalersCollection
lumiScalers_
 
MEMap2Inf mapBX_
 
MEMap3Inf mapDigiOcc_ieta_
 
MEMap3Inf mapDigiOcc_phi_
 
MEMap4Inf mapDigiOccPerCh_
 
MEMap3Inf mapDigiWheel_layer_
 
MEMap3Inf mapTotalDigi_layer_
 
MEMap3Inf mapTotalDigiPerEvtIEta_
 
MEMap3Inf mapTotalDigiPerEvtLayer_
 
Int_t nBXMax_
 
Int_t nBXMin_
 
std::string strFolderMain_
 
edm::EDGetToken tagDigi_
 

Additional Inherited Members

- Public Types inherited from GEMDQMBase
enum  {
  GEMDQM_RUNTYPE_ONLINE, GEMDQM_RUNTYPE_OFFLINE, GEMDQM_RUNTYPE_RELVAL, GEMDQM_RUNTYPE_ALLPLOTS,
  GEMDQM_RUNTYPE_NONE = -1
}
 
typedef MEMapInfT< MEMap2Ids,
ME2IdsKey
MEMap2Inf
 
typedef MEMapInfT< MEMap3Ids,
ME3IdsKey
MEMap3Inf
 
typedef MEMapInfT< MEMap4Ids,
ME4IdsKey
MEMap4Inf
 
- 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
 
- Public Attributes inherited from GEMDQMBase
std::string log_category_
 
Int_t nRunType_
 
- Protected Attributes inherited from GEMDQMBase
std::vector< GEMChambergemChambers_
 
const GEMGeometryGEMGeometry_
 
edm::ESGetToken< GEMGeometry,
MuonGeometryRecord
geomToken_
 
std::map< ME3IdsKey,
MEStationInfo
mapStationInfo_
 
std::map< ME3IdsKey, int > mapStationToIdx_
 
std::map< ME3IdsKey, bool > MEMap2AbsReWithEtaCheck_
 
std::map< ME2IdsKey, bool > MEMap2Check_
 
std::map< ME3IdsKey, bool > MEMap2WithEtaCheck_
 
std::map< ME3IdsKey, bool > MEMap3Check_
 
std::map< ME4IdsKey, bool > MEMap3WithChCheck_
 
std::map< ME4IdsKey, bool > MEMap4Check_
 
int nMaxNumCh_
 
Int_t nNumEtaPartitionGE0_
 
Int_t nNumEtaPartitionGE11_
 
Int_t nNumEtaPartitionGE21_
 
- Protected Attributes inherited from DQMEDAnalyzer
edm::EDPutTokenT< DQMTokenlumiToken_
 
edm::EDPutTokenT< DQMTokenrunToken_
 
unsigned int streamId_
 

Detailed Description

Definition at line 30 of file GEMDigiSource.h.

Constructor & Destructor Documentation

GEMDigiSource::GEMDigiSource ( const edm::ParameterSet cfg)
explicit

Definition at line 6 of file GEMDigiSource.cc.

References edm::ParameterSet::getParameter(), edm::ParameterSet::getUntrackedParameter(), HLT_FULL_cff::InputTag, lumiScalers_, nBXMax_, nBXMin_, and tagDigi_.

6  : GEMDQMBase(cfg) {
7  tagDigi_ = consumes<GEMDigiCollection>(cfg.getParameter<edm::InputTag>("digisInputLabel"));
8  lumiScalers_ = consumes<LumiScalersCollection>(
9  cfg.getUntrackedParameter<edm::InputTag>("lumiCollection", edm::InputTag("scalersRawToDigi")));
10  nBXMin_ = cfg.getParameter<int>("bxMin");
11  nBXMax_ = cfg.getParameter<int>("bxMax");
12 }
T getUntrackedParameter(std::string const &, T const &) const
edm::EDGetTokenT< LumiScalersCollection > lumiScalers_
Definition: GEMDigiSource.h:49
edm::EDGetToken tagDigi_
Definition: GEMDigiSource.h:47
T getParameter(std::string const &) const
Definition: ParameterSet.h:303
GEMDQMBase(const edm::ParameterSet &cfg)
Definition: GEMDQMBase.cc:7
GEMDigiSource::~GEMDigiSource ( )
inlineoverride

Definition at line 33 of file GEMDigiSource.h.

33 {};

Member Function Documentation

void GEMDigiSource::analyze ( edm::Event const &  e,
edm::EventSetup const &  eSetup 
)
overrideprotectedvirtual

Reimplemented from DQMEDAnalyzer.

Definition at line 153 of file GEMDigiSource.cc.

References GEMDetId::chamber(), ztail::d, GEMDQMBase::MEMapInfT< M, K >::Fill(), GEMDQMBase::MEStationInfo::fMinPhi_, fRadiusMax_, fRadiusMin_, GEMDQMBase::gemChambers_, GEMDQMBase::GEMGeometry_, GEMDQMBase::getVFATNumberByDigi(), GEMGeometry::idToDet(), GEMDetId::ieta(), submitPVResolutionJobs::key, GEMDetId::layer(), lumiScalers_, M_PI, mapBX_, mapDigiOcc_ieta_, mapDigiOcc_phi_, mapDigiOccPerCh_, mapDigiWheel_layer_, GEMDQMBase::mapStationInfo_, mapTotalDigi_layer_, mapTotalDigiPerEvtIEta_, mapTotalDigiPerEvtLayer_, SiStripPI::max, SiStripPI::min, nBXMax_, nBXMin_, GEMDQMBase::MEStationInfo::nNumEtaPartitions_, PV3DBase< T, PVType, FrameType >::phi(), GEMDetId::region(), GEMDQMBase::restrictAngle(), GEMDetId::station(), GeomDet::surface(), and tagDigi_.

153  {
155  event.getByToken(this->tagDigi_, gemDigis);
157  event.getByToken(lumiScalers_, lumiScalers);
158 
159  std::map<ME3IdsKey, Int_t> total_digi_layer;
160  std::map<ME3IdsKey, Int_t> total_digi_eta;
161  for (const auto& ch : gemChambers_) {
162  GEMDetId gid = ch.id();
163  ME2IdsKey key2{gid.region(), gid.station()};
164  ME3IdsKey key3{gid.region(), gid.station(), gid.layer()};
165  ME4IdsKey key4Ch{gid.region(), gid.station(), gid.layer(), gid.chamber()};
166  std::map<Int_t, bool> bTagVFAT;
167  bTagVFAT.clear();
168  MEStationInfo& stationInfo = mapStationInfo_[key3];
169  const BoundPlane& surface = GEMGeometry_->idToDet(gid)->surface();
170  if (total_digi_layer.find(key3) == total_digi_layer.end())
171  total_digi_layer[key3] = 0;
172  for (auto iEta : ch.etaPartitions()) {
173  GEMDetId eId = iEta->id();
174  ME3IdsKey key3IEta{gid.region(), gid.station(), eId.ieta()};
175  if (total_digi_eta.find(key3IEta) == total_digi_eta.end())
176  total_digi_eta[key3IEta] = 0;
177  const auto& digis_in_det = gemDigis->get(eId);
178  for (auto d = digis_in_det.first; d != digis_in_det.second; ++d) {
179  // Filling of digi occupancy
180  Int_t nIdxVFAT = getVFATNumberByDigi(gid.station(), eId.ieta(), d->strip());
181  mapTotalDigi_layer_.Fill(key3, gid.chamber(), nIdxVFAT);
182 
183  // Filling of digi
184  mapDigiOcc_ieta_.Fill(key3, eId.ieta()); // Eta (partition)
185 
186  GlobalPoint digi_global_pos = surface.toGlobal(iEta->centreOfStrip(d->strip()));
187  Float_t fPhi = (Float_t)digi_global_pos.phi();
188  Float_t fPhiShift = restrictAngle(fPhi, stationInfo.fMinPhi_);
189  Float_t fPhiDeg = fPhiShift * 180.0 / M_PI;
190  mapDigiOcc_phi_.Fill(key3, fPhiDeg); // Phi
191 
192  // Filling of R-Phi occupancy
193  Float_t fR = fRadiusMin_ + (fRadiusMax_ - fRadiusMin_) * (eId.ieta() - 0.5) / stationInfo.nNumEtaPartitions_;
194  mapDigiWheel_layer_.Fill(key3, fPhiShift, fR);
195 
196  mapDigiOccPerCh_.Fill(key4Ch, d->strip(), eId.ieta()); // Per chamber
197 
198  // For total digis
199  total_digi_layer[key3]++;
200  total_digi_eta[key3IEta]++;
201 
202  // Filling of bx
203  Int_t nBX = std::min(std::max((Int_t)d->bx(), nBXMin_), nBXMax_); // For under/overflow
204  if (bTagVFAT.find(nIdxVFAT) == bTagVFAT.end()) {
205  mapBX_.Fill(key2, nBX);
206  }
207 
208  bTagVFAT[nIdxVFAT] = true;
209  }
210  }
211  }
212  for (auto [key, num_total_digi] : total_digi_layer)
213  mapTotalDigiPerEvtLayer_.Fill(key, num_total_digi);
214  for (auto [key, num_total_digi] : total_digi_eta)
215  mapTotalDigiPerEvtIEta_.Fill(key, num_total_digi);
216 }
MEMap3Inf mapTotalDigiPerEvtLayer_
Definition: GEMDigiSource.h:55
int getVFATNumberByDigi(const int, const int, const int)
Definition: GEMDQMBase.h:622
std::tuple< Int_t, Int_t, Int_t, Int_t > ME4IdsKey
const GeomDet * idToDet(DetId) const override
Definition: GEMGeometry.cc:25
Float_t fRadiusMax_
Definition: GEMDigiSource.h:65
Geom::Phi< T > phi() const
Definition: PV3DBase.h:66
MEMap3Inf mapDigiOcc_ieta_
Definition: GEMDigiSource.h:53
MEMap4Inf mapDigiOccPerCh_
Definition: GEMDigiSource.h:59
MEMap3Inf mapDigiOcc_phi_
Definition: GEMDigiSource.h:54
std::map< ME3IdsKey, MEStationInfo > mapStationInfo_
Definition: GEMDQMBase.h:585
edm::EDGetTokenT< LumiScalersCollection > lumiScalers_
Definition: GEMDigiSource.h:49
int Fill(K key, Double_t x)
Definition: GEMDQMBase.h:380
edm::EDGetToken tagDigi_
Definition: GEMDigiSource.h:47
const Plane & surface() const
The nominal surface of the GeomDet.
Definition: GeomDet.h:37
MEMap3Inf mapTotalDigiPerEvtIEta_
Definition: GEMDigiSource.h:56
constexpr int ieta() const
Definition: GEMDetId.h:199
MEMap3Inf mapTotalDigi_layer_
Definition: GEMDigiSource.h:51
MEMap2Inf mapBX_
Definition: GEMDigiSource.h:57
tuple d
Definition: ztail.py:151
constexpr int region() const
Definition: GEMDetId.h:171
Float_t restrictAngle(const Float_t fTheta, const Float_t fStart)
Definition: GEMDQMBase.h:639
std::vector< GEMChamber > gemChambers_
Definition: GEMDQMBase.h:574
tuple key
prepare the HTCondor submission files and eventually submit them
#define M_PI
const GEMGeometry * GEMGeometry_
Definition: GEMDQMBase.h:571
constexpr int chamber() const
Definition: GEMDetId.h:183
constexpr int layer() const
Definition: GEMDetId.h:190
constexpr int station() const
Definition: GEMDetId.h:179
std::tuple< Int_t, Int_t > ME2IdsKey
Float_t fRadiusMin_
Definition: GEMDigiSource.h:64
std::tuple< Int_t, Int_t, Int_t > ME3IdsKey
MEMap3Inf mapDigiWheel_layer_
Definition: GEMDigiSource.h:52
void GEMDigiSource::bookHistograms ( DQMStore::IBooker ibooker,
edm::Run const &  ,
edm::EventSetup const &  iSetup 
)
overrideprotectedvirtual

Implements DQMEDAnalyzer.

Definition at line 24 of file GEMDigiSource.cc.

References dqm::implementation::NavigatorBase::cd(), fRadiusMax_, fRadiusMin_, GEMDQMBase::GEMDQM_RUNTYPE_ALLPLOTS, GEMDQMBase::GEMDQM_RUNTYPE_OFFLINE, GEMDQMBase::GEMDQM_RUNTYPE_RELVAL, GEMDQMBase::GEMGeometry_, GEMDQMBase::GenerateMEPerChamber(), GEMDQMBase::initGeometry(), GEMDQMBase::loadChambers(), M_PI, mapBX_, mapDigiOcc_ieta_, mapDigiOcc_phi_, mapDigiOccPerCh_, mapDigiWheel_layer_, mapTotalDigi_layer_, mapTotalDigiPerEvtIEta_, mapTotalDigiPerEvtLayer_, nBXMax_, nBXMin_, GEMDQMBase::nRunType_, dqm::implementation::NavigatorBase::setCurrentFolder(), GEMDQMBase::MEMapInfT< M, K >::SetNoUnderOverflowBin(), strFolderMain_, and GEMDQMBase::MEMapInfT< M, K >::TurnOff().

24  {
25  initGeometry(iSetup);
26  if (GEMGeometry_ == nullptr)
27  return;
28  loadChambers();
29 
30  strFolderMain_ = "GEM/Digis";
31 
32  fRadiusMin_ = 120.0;
33  fRadiusMax_ = 250.0;
34  float radS = -5.0 / 180 * M_PI;
35  float radL = 355.0 / 180 * M_PI;
36 
37  mapTotalDigi_layer_ = MEMap3Inf(this, "occ", "Digi Occupancy", 36, 0.5, 36.5, 24, -0.5, 24 - 0.5, "Chamber", "VFAT");
39  this, "occ_rphi", "Digi R-Phi Occupancy", 360, radS, radL, 8, fRadiusMin_, fRadiusMax_, "#phi (rad)", "R [cm]");
40  mapDigiOcc_ieta_ = MEMap3Inf(this, "occ_ieta", "Digi iEta Occupancy", 8, 0.5, 8.5, "iEta", "Number of fired digis");
42  MEMap3Inf(this, "occ_phi", "Digi Phi Occupancy", 72, -5, 355, "#phi (degree)", "Number of fired digis");
44  "digis_per_layer",
45  "Total number of digis per event for each layers",
46  50,
47  -0.5,
48  99.5,
49  "Number of fired digis",
50  "Events");
53  "digis_per_ieta",
54  "Total number of digis per event for each eta partitions",
55  50,
56  -0.5,
57  99.5,
58  "Number of fired digis",
59  "Events");
61 
62  mapBX_ = MEMap2Inf(this, "bx", "Digi Bunch Crossing", 21, nBXMin_ - 0.5, nBXMax_ + 0.5, "Bunch crossing");
63 
64  mapDigiOccPerCh_ = MEMap4Inf(this, "occ", "Digi Occupancy", 1, -0.5, 1.5, 1, 0.5, 1.5, "Digi", "iEta");
65 
68  mapBX_.TurnOff();
70  }
71 
76  }
77 
81  }
82 
86  }
87 
88  ibooker.cd();
90  GenerateMEPerChamber(ibooker);
91 }
MEMapInfT< MEMap4Ids, ME4IdsKey > MEMap4Inf
Definition: GEMDQMBase.h:460
Int_t nRunType_
Definition: GEMDQMBase.h:516
MEMap3Inf mapTotalDigiPerEvtLayer_
Definition: GEMDigiSource.h:55
virtual void setCurrentFolder(std::string const &fullpath)
Definition: DQMStore.cc:32
MEMapInfT< MEMap3Ids, ME3IdsKey > MEMap3Inf
Definition: GEMDQMBase.h:459
int initGeometry(edm::EventSetup const &iSetup)
Definition: GEMDQMBase.cc:31
Float_t fRadiusMax_
Definition: GEMDigiSource.h:65
MEMap3Inf mapDigiOcc_ieta_
Definition: GEMDigiSource.h:53
MEMap4Inf mapDigiOccPerCh_
Definition: GEMDigiSource.h:59
MEMap3Inf mapDigiOcc_phi_
Definition: GEMDigiSource.h:54
int loadChambers()
Definition: GEMDQMBase.cc:62
std::string strFolderMain_
Definition: GEMDigiSource.h:61
MEMap3Inf mapTotalDigiPerEvtIEta_
Definition: GEMDigiSource.h:56
MEMap3Inf mapTotalDigi_layer_
Definition: GEMDigiSource.h:51
MEMap2Inf mapBX_
Definition: GEMDigiSource.h:57
int GenerateMEPerChamber(DQMStore::IBooker &ibooker)
Definition: GEMDQMBase.cc:174
MEMapInfT< MEMap2Ids, ME2IdsKey > MEMap2Inf
Definition: GEMDQMBase.h:458
#define M_PI
const GEMGeometry * GEMGeometry_
Definition: GEMDQMBase.h:571
void SetNoUnderOverflowBin()
Definition: GEMDQMBase.h:247
Float_t fRadiusMin_
Definition: GEMDigiSource.h:64
MEMap3Inf mapDigiWheel_layer_
Definition: GEMDigiSource.h:52
void GEMDigiSource::dqmBeginRun ( edm::Run const &  ,
edm::EventSetup const &   
)
inlineoverrideprotectedvirtual

Reimplemented from DQMEDAnalyzer.

Definition at line 37 of file GEMDigiSource.h.

37 {};
void GEMDigiSource::fillDescriptions ( edm::ConfigurationDescriptions descriptions)
static

Definition at line 14 of file GEMDigiSource.cc.

References edm::ConfigurationDescriptions::add(), edm::ParameterSetDescription::add(), edm::ParameterSetDescription::addUntracked(), submitPVResolutionJobs::desc, HLT_FULL_cff::InputTag, and AlCaHLTBitMon_QueryRunRegistry::string.

14  {
16  desc.add<edm::InputTag>("digisInputLabel", edm::InputTag("muonGEMDigis", ""));
17  desc.addUntracked<std::string>("runType", "online");
18  desc.addUntracked<std::string>("logCategory", "GEMDigiSource");
19  desc.add<int>("bxMin", -10);
20  desc.add<int>("bxMax", 10);
21  descriptions.add("GEMDigiSource", desc);
22 }
ParameterDescriptionBase * addUntracked(U const &iLabel, T const &value)
ParameterDescriptionBase * add(U const &iLabel, T const &value)
void add(std::string const &label, ParameterSetDescription const &psetDescription)
int GEMDigiSource::ProcessWithMEMap2 ( BookingHelper bh,
ME2IdsKey  key 
)
overrideprivatevirtual

Reimplemented from GEMDQMBase.

Definition at line 93 of file GEMDigiSource.cc.

References GEMDQMBase::MEMapInfT< M, K >::bookND(), and mapBX_.

93  {
94  mapBX_.bookND(bh, key);
95 
96  return 0;
97 }
MEMap2Inf mapBX_
Definition: GEMDigiSource.h:57
tuple key
prepare the HTCondor submission files and eventually submit them
int bookND(BookingHelper &bh, K key)
Definition: GEMDQMBase.h:307
int GEMDigiSource::ProcessWithMEMap2WithEta ( BookingHelper bh,
ME3IdsKey  key 
)
overrideprivatevirtual

Reimplemented from GEMDQMBase.

Definition at line 99 of file GEMDigiSource.cc.

References GEMDQMBase::MEMapInfT< M, K >::bookND(), and mapTotalDigiPerEvtIEta_.

99  {
101 
102  return 0;
103 }
MEMap3Inf mapTotalDigiPerEvtIEta_
Definition: GEMDigiSource.h:56
tuple key
prepare the HTCondor submission files and eventually submit them
int bookND(BookingHelper &bh, K key)
Definition: GEMDQMBase.h:307
int GEMDigiSource::ProcessWithMEMap3 ( BookingHelper bh,
ME3IdsKey  key 
)
overrideprivatevirtual

Reimplemented from GEMDQMBase.

Definition at line 105 of file GEMDigiSource.cc.

References GEMDQMBase::MEMapInfT< M, K >::bookND(), GEMDQMBase::MEStationInfo::fMinPhi_, submitPVResolutionJobs::key, M_PI, mapDigiOcc_ieta_, mapDigiOcc_phi_, mapDigiWheel_layer_, GEMDQMBase::mapStationInfo_, mapTotalDigi_layer_, mapTotalDigiPerEvtLayer_, GEMDQMBase::MEStationInfo::nMaxVFAT_, GEMDQMBase::MEStationInfo::nNumChambers_, GEMDQMBase::MEStationInfo::nNumEtaPartitions_, GEMDQMBase::MEMapInfT< M, K >::SetBinConfX(), GEMDQMBase::MEMapInfT< M, K >::SetBinConfY(), GEMDQMBase::MEMapInfT< M, K >::SetBinHighEdgeX(), GEMDQMBase::MEMapInfT< M, K >::SetBinLowEdgeX(), GEMDQMBase::MEMapInfT< M, K >::SetLabelForChambers(), GEMDQMBase::MEMapInfT< M, K >::SetLabelForIEta(), GEMDQMBase::MEMapInfT< M, K >::SetLabelForVFATs(), GEMDQMBase::MEMapInfT< M, K >::SetNbinsX(), and GEMDQMBase::MEMapInfT< M, K >::SetNbinsY().

105  {
106  MEStationInfo& stationInfo = mapStationInfo_[key];
107 
108  int nNumVFATPerEta = stationInfo.nMaxVFAT_ / stationInfo.nNumEtaPartitions_;
109 
110  mapTotalDigi_layer_.SetBinConfX(stationInfo.nNumChambers_);
111  mapTotalDigi_layer_.SetBinConfY(stationInfo.nMaxVFAT_, -0.5);
114  mapTotalDigi_layer_.SetLabelForVFATs(key, stationInfo.nNumEtaPartitions_, 2);
115 
116  mapDigiWheel_layer_.SetBinLowEdgeX(stationInfo.fMinPhi_);
117  mapDigiWheel_layer_.SetBinHighEdgeX(stationInfo.fMinPhi_ + 2 * M_PI);
118  mapDigiWheel_layer_.SetNbinsX(nNumVFATPerEta * stationInfo.nNumChambers_);
119  mapDigiWheel_layer_.SetNbinsY(stationInfo.nNumEtaPartitions_);
121 
122  mapDigiOcc_ieta_.SetBinConfX(stationInfo.nNumEtaPartitions_);
125 
126  mapDigiOcc_phi_.SetBinLowEdgeX(stationInfo.fMinPhi_ * 180 / M_PI);
127  mapDigiOcc_phi_.SetBinHighEdgeX(stationInfo.fMinPhi_ * 180 / M_PI + 360);
130 
131  return 0;
132 }
MEMap3Inf mapTotalDigiPerEvtLayer_
Definition: GEMDigiSource.h:55
int SetLabelForChambers(K key, Int_t nAxis, Int_t nNumBin=-1)
Definition: GEMDQMBase.h:337
MEMap3Inf mapDigiOcc_ieta_
Definition: GEMDigiSource.h:53
MEMap3Inf mapDigiOcc_phi_
Definition: GEMDigiSource.h:54
int SetLabelForVFATs(K key, Int_t nNumEtaPartitions, Int_t nAxis, Int_t nNumBin=-1)
Definition: GEMDQMBase.h:359
std::map< ME3IdsKey, MEStationInfo > mapStationInfo_
Definition: GEMDQMBase.h:585
void SetBinHighEdgeX(Double_t dXH)
Definition: GEMDQMBase.h:266
MEMap3Inf mapTotalDigi_layer_
Definition: GEMDigiSource.h:51
void SetBinLowEdgeX(Double_t dXL)
Definition: GEMDQMBase.h:264
tuple key
prepare the HTCondor submission files and eventually submit them
void SetNbinsY(Int_t nBinsY)
Definition: GEMDQMBase.h:270
#define M_PI
int SetLabelForIEta(K key, Int_t nAxis, Int_t nNumBin=-1)
Definition: GEMDQMBase.h:357
int bookND(BookingHelper &bh, K key)
Definition: GEMDQMBase.h:307
void SetNbinsX(Int_t nBinsX)
Definition: GEMDQMBase.h:262
void SetBinConfX(Int_t nBins, Double_t dL=0.5, Double_t dH=-1048576.0)
Definition: GEMDQMBase.h:281
void SetBinConfY(Int_t nBins, Double_t dL=0.5, Double_t dH=-1048576.0)
Definition: GEMDQMBase.h:289
MEMap3Inf mapDigiWheel_layer_
Definition: GEMDigiSource.h:52
int GEMDigiSource::ProcessWithMEMap3WithChamber ( BookingHelper bh,
ME4IdsKey  key 
)
overrideprivatevirtual

Reimplemented from GEMDQMBase.

Definition at line 134 of file GEMDigiSource.cc.

References GEMDQMBase::MEMapInfT< M, K >::bookND(), GEMDQMBase::BookingHelper::getBooker(), GEMDQMBase::getNameDirLayer(), GEMDQMBase::key4Tokey3(), mapDigiOccPerCh_, GEMDQMBase::mapStationInfo_, GEMDQMBase::MEStationInfo::nMaxVFAT_, GEMDQMBase::MEStationInfo::nNumDigi_, GEMDQMBase::MEStationInfo::nNumEtaPartitions_, GEMDQMBase::MEMapInfT< M, K >::SetBinConfX(), GEMDQMBase::MEMapInfT< M, K >::SetBinConfY(), dqm::implementation::NavigatorBase::setCurrentFolder(), GEMDQMBase::MEMapInfT< M, K >::SetLabelForIEta(), and strFolderMain_.

134  {
135  ME3IdsKey key3 = key4Tokey3(key);
136  MEStationInfo& stationInfo = mapStationInfo_[key3];
137 
138  bh.getBooker()->setCurrentFolder(strFolderMain_ + "/occupancy_" + getNameDirLayer(key3));
139 
140  int nNumVFATPerEta = stationInfo.nMaxVFAT_ / stationInfo.nNumEtaPartitions_;
141  int nNumCh = stationInfo.nNumDigi_;
142 
143  mapDigiOccPerCh_.SetBinConfX(nNumCh * nNumVFATPerEta, -0.5);
144  mapDigiOccPerCh_.SetBinConfY(stationInfo.nNumEtaPartitions_);
147 
148  bh.getBooker()->setCurrentFolder(strFolderMain_);
149 
150  return 0;
151 }
MEMap4Inf mapDigiOccPerCh_
Definition: GEMDigiSource.h:59
std::map< ME3IdsKey, MEStationInfo > mapStationInfo_
Definition: GEMDQMBase.h:585
std::string strFolderMain_
Definition: GEMDigiSource.h:61
tuple key
prepare the HTCondor submission files and eventually submit them
int SetLabelForIEta(K key, Int_t nAxis, Int_t nNumBin=-1)
Definition: GEMDQMBase.h:357
std::string getNameDirLayer(ME3IdsKey key3)
Definition: GEMDQMBase.h:645
int bookND(BookingHelper &bh, K key)
Definition: GEMDQMBase.h:307
ME3IdsKey key4Tokey3(ME4IdsKey key)
Definition: GEMDQMBase.h:549
std::tuple< Int_t, Int_t, Int_t > ME3IdsKey
void SetBinConfX(Int_t nBins, Double_t dL=0.5, Double_t dH=-1048576.0)
Definition: GEMDQMBase.h:281
void SetBinConfY(Int_t nBins, Double_t dL=0.5, Double_t dH=-1048576.0)
Definition: GEMDQMBase.h:289

Member Data Documentation

Float_t GEMDigiSource::fRadiusMax_
private

Definition at line 65 of file GEMDigiSource.h.

Referenced by analyze(), and bookHistograms().

Float_t GEMDigiSource::fRadiusMin_
private

Definition at line 64 of file GEMDigiSource.h.

Referenced by analyze(), and bookHistograms().

edm::EDGetTokenT<LumiScalersCollection> GEMDigiSource::lumiScalers_
private

Definition at line 49 of file GEMDigiSource.h.

Referenced by analyze(), and GEMDigiSource().

MEMap2Inf GEMDigiSource::mapBX_
private

Definition at line 57 of file GEMDigiSource.h.

Referenced by analyze(), bookHistograms(), and ProcessWithMEMap2().

MEMap3Inf GEMDigiSource::mapDigiOcc_ieta_
private

Definition at line 53 of file GEMDigiSource.h.

Referenced by analyze(), bookHistograms(), and ProcessWithMEMap3().

MEMap3Inf GEMDigiSource::mapDigiOcc_phi_
private

Definition at line 54 of file GEMDigiSource.h.

Referenced by analyze(), bookHistograms(), and ProcessWithMEMap3().

MEMap4Inf GEMDigiSource::mapDigiOccPerCh_
private

Definition at line 59 of file GEMDigiSource.h.

Referenced by analyze(), bookHistograms(), and ProcessWithMEMap3WithChamber().

MEMap3Inf GEMDigiSource::mapDigiWheel_layer_
private

Definition at line 52 of file GEMDigiSource.h.

Referenced by analyze(), bookHistograms(), and ProcessWithMEMap3().

MEMap3Inf GEMDigiSource::mapTotalDigi_layer_
private

Definition at line 51 of file GEMDigiSource.h.

Referenced by analyze(), bookHistograms(), and ProcessWithMEMap3().

MEMap3Inf GEMDigiSource::mapTotalDigiPerEvtIEta_
private

Definition at line 56 of file GEMDigiSource.h.

Referenced by analyze(), bookHistograms(), and ProcessWithMEMap2WithEta().

MEMap3Inf GEMDigiSource::mapTotalDigiPerEvtLayer_
private

Definition at line 55 of file GEMDigiSource.h.

Referenced by analyze(), bookHistograms(), and ProcessWithMEMap3().

Int_t GEMDigiSource::nBXMax_
private

Definition at line 63 of file GEMDigiSource.h.

Referenced by analyze(), bookHistograms(), and GEMDigiSource().

Int_t GEMDigiSource::nBXMin_
private

Definition at line 63 of file GEMDigiSource.h.

Referenced by analyze(), bookHistograms(), and GEMDigiSource().

std::string GEMDigiSource::strFolderMain_
private

Definition at line 61 of file GEMDigiSource.h.

Referenced by bookHistograms(), and ProcessWithMEMap3WithChamber().

edm::EDGetToken GEMDigiSource::tagDigi_
private

Definition at line 47 of file GEMDigiSource.h.

Referenced by analyze(), and GEMDigiSource().