CMS 3D CMS Logo

All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
ME0NumberingScheme.cc
Go to the documentation of this file.
7 
8 //#define EDM_ML_DEBUG
9 
10 ME0NumberingScheme::ME0NumberingScheme(const MuonGeometryConstants& muonConstants) { initMe(muonConstants); }
11 
13  int theLevelPart = muonConstants.getValue("level");
14  theRegionLevel = muonConstants.getValue("m0_region") / theLevelPart;
15  theLayerLevel = muonConstants.getValue("m0_layer") / theLevelPart;
16  theSectorLevel = muonConstants.getValue("m0_sector") / theLevelPart;
17  theRollLevel = muonConstants.getValue("m0_roll") / theLevelPart;
18  theNEtaPart = muonConstants.getValue("m0_nroll");
19 
20  // Debug using EDM_ML_DEBUG
21 #ifdef EDM_ML_DEBUG
22  edm::LogVerbatim("MuonGeom") << "Initialize ME0NumberingScheme"
23  << "\ntheRegionLevel " << theRegionLevel << "\ntheLayerLevel " << theLayerLevel
24  << "\ntheSectorLevel " << theSectorLevel << "\ntheRollLevel " << theRollLevel
25  << "\ntheNEtaPart " << theNEtaPart;
26 #endif
27  // -----------------------
28 }
29 
31  // Debug using EDM_ML_DEBUG
32 #ifdef EDM_ML_DEBUG
33  edm::LogVerbatim("MuonGeom") << "ME0NumberingScheme::baseNumberToUnitNumber BEGIN ";
34  edm::LogVerbatim("MuonGeom") << "ME0Numbering " << num.getLevels();
35  for (int level = 1; level <= num.getLevels(); level++) {
36  edm::LogVerbatim("MuonGeom") << "level " << level << " " << num.getSuperNo(level) << " " << num.getBaseNo(level);
37  }
38 #endif
39  // -----------------------
40 
41 #ifdef EDM_ML_DEBUG
42  if (num.getLevels() != theRollLevel)
43  edm::LogVerbatim("MuonGeom") << "MuonME0NS::BNToUN BaseNumber has " << num.getLevels()
44  << " levels which is less than " << theRollLevel;
45 #endif
46 
49 
50  //decode significant ME0 levels
51 
52  if (num.getBaseNo(theRegionLevel) == 0)
53  region = 1;
54  else
55  region = -1;
56  if (num.getLevels() >= theLayerLevel)
57  layer = num.getBaseNo(theLayerLevel) + 1;
58  if (num.getLevels() >= theSectorLevel)
59  chamber = num.getBaseNo(theSectorLevel) + 1;
60  if (num.getLevels() >= theRollLevel)
61  roll = num.getBaseNo(theRollLevel) + 1;
62 
63  // collect all info
64 
65  // Debug using EDM_ML_DEBUG
66 #ifdef EDM_ML_DEBUG
67  edm::LogVerbatim("MuonGeom") << "ME0NumberingScheme: Region " << region << " Layer " << layer << " Chamber "
68  << chamber << " Roll " << roll;
69 #endif
70  // -----------------------
71 
72  // Build the actual numbering
73  ME0DetId id(region, layer, chamber, roll);
74 
75  // Debug using EDM_ML_DEBUG
76 #ifdef EDM_ML_DEBUG
77  edm::LogVerbatim("MuonGeom") << " DetId " << id;
78 #endif
79  // ---------------------
80 
81  return id.rawId();
82 }
personalPlayback.level
level
Definition: personalPlayback.py:22
MuonGeometryConstants
Definition: MuonGeometryConstants.h:20
MessageLogger.h
ME0NumberingScheme::baseNumberToUnitNumber
int baseNumberToUnitNumber(const MuonBaseNumber &) const override
Definition: ME0NumberingScheme.cc:30
ME0DetId.h
MuonGeometryConstants.h
ME0NumberingScheme::ME0NumberingScheme
ME0NumberingScheme(const MuonGeometryConstants &muonConstants)
Definition: ME0NumberingScheme.cc:10
ME0DetId::minRollId
static constexpr int minRollId
Definition: ME0DetId.h:72
ME0NumberingScheme::theLayerLevel
int theLayerLevel
Definition: ME0NumberingScheme.h:22
ME0NumberingScheme.h
ME0DetId::minChamberId
static constexpr int minChamberId
Definition: ME0DetId.h:66
ME0NumberingScheme::theNEtaPart
int theNEtaPart
Definition: ME0NumberingScheme.h:24
phase1PixelTopology::layer
constexpr std::array< uint8_t, layerIndexSize > layer
Definition: phase1PixelTopology.h:99
ME0DetId::minLayerId
static constexpr int minLayerId
Definition: ME0DetId.h:69
MuonBaseNumber.h
HLT_FULL_cff.region
region
Definition: HLT_FULL_cff.py:88286
MuonGeometryConstants::getValue
int getValue(const std::string &name) const
Definition: MuonGeometryConstants.cc:8
ME0DetId
Definition: ME0DetId.h:16
ME0NumberingScheme::theRegionLevel
int theRegionLevel
Definition: ME0NumberingScheme.h:20
EgammaValidation_cff.num
num
Definition: EgammaValidation_cff.py:33
MuonBaseNumber
Definition: MuonBaseNumber.h:21
ME0NumberingScheme::theRollLevel
int theRollLevel
Definition: ME0NumberingScheme.h:23
edm::LogVerbatim
Log< level::Info, true > LogVerbatim
Definition: MessageLogger.h:128
triggerObjects_cff.id
id
Definition: triggerObjects_cff.py:29
ME0DetId::minRegionId
static constexpr int minRegionId
Definition: ME0DetId.h:63
relativeConstraints.chamber
chamber
Definition: relativeConstraints.py:53
Exception.h
ME0NumberingScheme::theSectorLevel
int theSectorLevel
Definition: ME0NumberingScheme.h:21
ME0NumberingScheme::initMe
void initMe(const MuonGeometryConstants &muonConstants)
Definition: ME0NumberingScheme.cc:12
edm::Log
Definition: MessageLogger.h:70