15 geomToken_ = esConsumes<GEMGeometry, MuonGeometryRecord, edm::Transition::BeginRun>();
23 if (!gemH.isValid()) {
24 edm::LogError(
"GEMCheckGeometry") <<
"Failed to initialize GEM geometry.";
30 LogDebug(
"GEMCheckGeometry") <<
"ibooker set current folder\n";
33 TString
title = TString::Format(
"Geometry's phi distribution on Region %d ; #phi(degree); ;",
region->region());
34 TString
name = TString::Format(
"geo_phi_r%d",
region->region());
35 auto temp_me = ibooker.
book2D(
name.Data(),
title.Data(), 360000, -180., 180, 12, 1, 13);
37 temp_me->setBinLabel(2,
"St1,La1_odd", 2);
38 temp_me->setBinLabel(3,
"St1,La2_even", 2);
39 temp_me->setBinLabel(4,
"St1,La2_odd", 2);
40 temp_me->setBinLabel(5,
"St2,La1_even", 2);
41 temp_me->setBinLabel(6,
"St2,La1_odd", 2);
42 temp_me->setBinLabel(7,
"St2,La2_even", 2);
43 temp_me->setBinLabel(8,
"St2,La2_odd", 2);
50 for (
auto sch :
ring->superChambers()) {
51 for (
auto ch : sch->chambers()) {
52 for (
auto roll : ch->etaPartitions()) {
59 double phi =
roll->toGlobal(lEdge).phi().degrees();
62 int region_idx =
id.region();
63 int station_idx =
id.station();
64 int chamber_idx =
id.chamber();
65 int layer_idx =
id.layer();
66 int value = (station_idx - 1) * 4 + (layer_idx - 1) * 2 + (chamber_idx % 2) + 1;
68 if (region_idx == 1) {
69 UInt_t
hash = TString(
"geo_phi_r1").Hash();
72 UInt_t
hash = TString(
"geo_phi_r-1").Hash();
void bookHistograms(DQMStore::IBooker &, edm::Run const &, edm::EventSetup const &) override
std::map< UInt_t, MonitorElement * > theStdPlots
T getParameter(std::string const &) const
virtual void setCurrentFolder(std::string const &fullpath)
~GEMCheckGeometry() override
void analyze(const edm::Event &e, const edm::EventSetup &) override
Log< level::Error, false > LogError
nStrips
1.2 is to make the matching window safely the two nearest strips 0.35 is the size of an ME0 chamber i...
T getUntrackedParameter(std::string const &, T const &) const
GEMCheckGeometry(const edm::ParameterSet &gc)
Container::value_type value_type
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)
ESHandle< T > getHandle(const ESGetToken< T, R > &iToken) const
edm::ESGetToken< GEMGeometry, MuonGeometryRecord > geomToken_
MonitorElement * book2D(TString const &name, TString const &title, int nchX, double lowX, double highX, int nchY, double lowY, double highY, FUNC onbooking=NOOP())
virtual LocalPoint localPosition(float strip) const =0