CMS 3D CMS Logo

HGCGeometryValidation.cc
Go to the documentation of this file.
1 #include <memory>
2 #include <iostream>
3 
6 
11 
23 
29 
31 
32 #include "CLHEP/Geometry/Point3D.h"
33 #include "CLHEP/Geometry/Vector3D.h"
34 #include "CLHEP/Units/GlobalSystemOfUnits.h"
35 #include "CLHEP/Units/GlobalPhysicalConstants.h"
36 
37 const double mmtocm = 0.1;
38 
40 public:
41  explicit HGCGeometryValidation(const edm::ParameterSet &);
42  ~HGCGeometryValidation() override;
43  static void fillDescriptions(edm::ConfigurationDescriptions &descriptions);
44 
45 protected:
46  void dqmBeginRun(edm::Run const &, edm::EventSetup const &) override;
47  void bookHistograms(DQMStore::IBooker &, edm::Run const &, edm::EventSetup const &) override;
48  void analyze(const edm::Event &, const edm::EventSetup &) override;
49 
50 private:
52  std::vector<std::string> geometrySource_;
54  std::vector<edm::ESGetToken<HGCalDDDConstants, IdealGeometryRecord>> geomToken_;
55 
56  //HGCal geometry scheme
57  std::vector<const HGCalDDDConstants *> hgcGeometry_;
58 
59  //histogram related stuff
70 
75 };
76 
78  g4Token_ = consumes<PHGCalValidInfo>(cfg.getParameter<edm::InputTag>("g4Source"));
79  geometrySource_ = cfg.getUntrackedParameter<std::vector<std::string>>("geometrySource");
80  verbosity_ = cfg.getUntrackedParameter<int>("verbosity", 0);
81  for (const auto &name : geometrySource_)
82  geomToken_.emplace_back(
83  esConsumes<HGCalDDDConstants, IdealGeometryRecord, edm::Transition::BeginRun>(edm::ESInputTag{"", name}));
84 }
85 
87 
90  desc.setUnknown();
91  descriptions.addDefault(desc);
92 }
93 
95  //initiating hgcnumbering
96  for (size_t i = 0; i < geometrySource_.size(); i++) {
97  hgcGeometry_.emplace_back(&iSetup.getData(geomToken_[i]));
98  }
99 }
100 
102  iB.setCurrentFolder("HGCAL/HGCalSimHitsV/Geometry");
103 
104  //initiating histograms
105  heeTotEdepStep = iB.book1D("heeTotEdepStep", "", 100, 0, 100);
106  hefTotEdepStep = iB.book1D("hefTotEdepStep", "", 100, 0, 100);
107  hebTotEdepStep = iB.book1D("hebTotEdepStep", "", 100, 0, 100);
108 
109  hebLayerVsEnStep = iB.book2D("hebLayerVsEnStep", "", 25, 0, 25, 100, 0, 0.01);
110  hefLayerVsEnStep = iB.book2D("hefLayerVsEnStep", "", 36, 0, 36, 100, 0, 0.01);
111  heeLayerVsEnStep = iB.book2D("heeLayerVsEnStep", "", 84, 0, 84, 100, 0, 0.01);
112 
113  heeXG4VsId = iB.book2D("heeXG4VsId", "", 600, -300, 300, 600, -300, 300);
114  heeYG4VsId = iB.book2D("heeYG4VsId", "", 600, -300, 300, 600, -300, 300);
115  heeZG4VsId = iB.book2D("heeZG4VsId", "", 3000, 320, 350, 3000, 320, 350);
116 
117  hefXG4VsId = iB.book2D("hefXG4VsId", "", 600, -300, 300, 600, -300, 300);
118  hefYG4VsId = iB.book2D("hefYG4VsId", "", 600, -300, 300, 600, -300, 300);
119  hefZG4VsId = iB.book2D("hefZG4VsId", "", 6000, 350, 410, 6000, 350, 410);
120 
121  hebXG4VsId = iB.book2D("hebXG4VsId", "", 600, -300, 300, 600, -300, 300);
122  hebYG4VsId = iB.book2D("hebYG4VsId", "", 600, -300, 300, 600, -300, 300);
123  hebZG4VsId = iB.book2D("hebZG4VsId", "", 220, 400, 620, 220, 400, 620);
124 
125  heedzVsZ = iB.book2D("heedzVsZ", "", 600, 320, 350, 100, -1, 1);
126  heedyVsY = iB.book2D("heedyVsY", "", 400, -200, 200, 100, -1, 1);
127  heedxVsX = iB.book2D("heedxVsX", "", 400, -200, 200, 100, -1, 1);
128 
129  hefdzVsZ = iB.book2D("hefdzVsZ", "", 1200, 350, 410, 100, -1, 1);
130  hefdyVsY = iB.book2D("hefdyVsY", "", 400, -200, 200, 100, -1, 1);
131  hefdxVsX = iB.book2D("hefdxVsX", "", 400, -200, 200, 100, -1, 1);
132 
133  hebdzVsZ = iB.book2D("hebdzVsZ", "", 220, 400, 620, 100, -5, 5);
134  hebdyVsY = iB.book2D("hebdyVsY", "", 400, -200, 200, 100, -5, 5);
135  hebdxVsX = iB.book2D("hebdxVsX", "", 400, -200, 200, 100, -5, 5);
136 
137  heedzVsLayer = iB.book2D("heedzVsLayer", "", 100, 0, 100, 100, -1, 1);
138  hefdzVsLayer = iB.book2D("hefdzVsLayer", "", 40, 0, 40, 100, -1, 1);
139  hebdzVsLayer = iB.book2D("hebdzVsLayer", "", 50, 0, 25, 100, -5, 5);
140 
141  heedyVsLayer = iB.book2D("heedyVsLayer", "", 100, 0, 100, 100, -1, 1);
142  hefdyVsLayer = iB.book2D("hefdyVsLayer", "", 40, 0, 40, 100, -1, 1);
143  hebdyVsLayer = iB.book2D("hebdyVsLayer", "", 50, 0, 25, 100, -5, 5);
144 
145  heedxVsLayer = iB.book2D("heedxVsLayer", "", 100, 0, 100, 100, -1, 1);
146  hefdxVsLayer = iB.book2D("hefdxVsLayer", "", 40, 0, 40, 500, -1, 1);
147  hebdxVsLayer = iB.book2D("hebdxVsLayer", "", 50, 0, 25, 500, -5, 5.0);
148 
149  heedX = iB.book1D("heedX", "", 100, -1, 1);
150  heedY = iB.book1D("heedY", "", 100, -1, 1);
151  heedZ = iB.book1D("heedZ", "", 100, -1, 1);
152 
153  hefdX = iB.book1D("hefdX", "", 100, -1, 1);
154  hefdY = iB.book1D("hefdY", "", 100, -1, 1);
155  hefdZ = iB.book1D("hefdZ", "", 100, -1, 1);
156 
157  hebdX = iB.book1D("hebdX", "", 100, -1, 1);
158  hebdY = iB.book1D("hebdY", "", 100, -1, 1);
159  hebdZ = iB.book1D("hebdZ", "", 100, -1, 1);
160 }
161 
163  //Accessing G4 information
165  iEvent.getByToken(g4Token_, infoLayer);
166 
167  if (infoLayer.isValid()) {
168  //step vertex information
169  std::vector<float> hitVtxX = infoLayer->hitvtxX();
170  std::vector<float> hitVtxY = infoLayer->hitvtxY();
171  std::vector<float> hitVtxZ = infoLayer->hitvtxZ();
172  std::vector<unsigned int> hitDet = infoLayer->hitDets();
173  std::vector<unsigned int> hitIdx = infoLayer->hitIndex();
174 
175  //energy information
176  std::vector<float> edepLayerEE = infoLayer->eehgcEdep();
177  std::vector<float> edepLayerHE = infoLayer->hefhgcEdep();
178  std::vector<float> edepLayerHB = infoLayer->hebhgcEdep();
179 
180  unsigned int i;
181  for (i = 0; i < edepLayerEE.size(); i++) {
182  heeLayerVsEnStep->Fill(i, edepLayerEE.at(i));
183  }
184 
185  for (i = 0; i < edepLayerHE.size(); i++) {
186  hefLayerVsEnStep->Fill(i, edepLayerHE.at(i));
187  }
188 
189  for (i = 0; i < edepLayerHB.size(); i++) {
190  hebLayerVsEnStep->Fill(i, edepLayerHB.at(i));
191  }
192 
193  //fill total energy deposited
194  heeTotEdepStep->Fill((double)infoLayer->eeTotEdep());
195  hefTotEdepStep->Fill((double)infoLayer->hefTotEdep());
196  hebTotEdepStep->Fill((double)infoLayer->hebTotEdep());
197 
198  //loop over all hits
199  for (unsigned int i = 0; i < hitVtxX.size(); i++) {
200  hitVtxX.at(i) = mmtocm * hitVtxX.at(i);
201  hitVtxY.at(i) = mmtocm * hitVtxY.at(i);
202  hitVtxZ.at(i) = mmtocm * hitVtxZ.at(i);
203 
204  if ((hitDet.at(i) == (unsigned int)(DetId::Forward)) || (hitDet.at(i) == (unsigned int)(DetId::HGCalEE)) ||
205  (hitDet.at(i) == (unsigned int)(DetId::HGCalHSi)) || (hitDet.at(i) == (unsigned int)(DetId::HGCalHSc))) {
206  double xx, yy;
207  int dtype(0), layer(0), zside(1);
208  std::pair<float, float> xy;
209  if (hitDet.at(i) == (unsigned int)(DetId::Forward)) {
210  int subdet, wafer, celltype, cell;
211  HGCalTestNumbering::unpackHexagonIndex(hitIdx.at(i), subdet, zside, layer, wafer, celltype, cell);
212  dtype = (subdet == (int)(HGCEE)) ? 0 : 1;
213  xy = hgcGeometry_[dtype]->locateCell(cell, layer, wafer, true); //cm
214  } else if ((hitDet.at(i) == (unsigned int)(DetId::HGCalEE)) ||
215  (hitDet.at(i) == (unsigned int)(DetId::HGCalHSi))) {
216  HGCSiliconDetId id(hitIdx.at(i));
217  dtype = (id.det() == DetId::HGCalEE) ? 0 : 1;
218  layer = id.layer();
219  zside = id.zside();
220  xy = hgcGeometry_[dtype]->locateCell(layer, id.waferU(), id.waferV(), id.cellU(), id.cellV(), true, true);
221  } else {
222  HGCScintillatorDetId id(hitIdx.at(i));
223  dtype = 2;
224  layer = id.layer();
225  zside = id.zside();
226  xy = hgcGeometry_[dtype]->locateCellTrap(layer, id.ietaAbs(), id.iphi(), true);
227  }
228  double zz = hgcGeometry_[dtype]->waferZ(layer, true); //cm
229  if (zside < 0)
230  zz = -zz;
231  xx = (zside < 0) ? -xy.first : xy.first;
232  yy = xy.second;
233 
234  if (dtype == 0) {
235  heedzVsZ->Fill(zz, (hitVtxZ.at(i) - zz));
236  heedyVsY->Fill(yy, (hitVtxY.at(i) - yy));
237  heedxVsX->Fill(xx, (hitVtxX.at(i) - xx));
238 
239  heeXG4VsId->Fill(hitVtxX.at(i), xx);
240  heeYG4VsId->Fill(hitVtxY.at(i), yy);
241  heeZG4VsId->Fill(hitVtxZ.at(i), zz);
242 
243  heedzVsLayer->Fill(layer, (hitVtxZ.at(i) - zz));
244  heedyVsLayer->Fill(layer, (hitVtxY.at(i) - yy));
245  heedxVsLayer->Fill(layer, (hitVtxX.at(i) - xx));
246 
247  heedX->Fill((hitVtxX.at(i) - xx));
248  heedZ->Fill((hitVtxZ.at(i) - zz));
249  heedY->Fill((hitVtxY.at(i) - yy));
250 
251  } else if (dtype == 1) {
252  hefdzVsZ->Fill(zz, (hitVtxZ.at(i) - zz));
253  hefdyVsY->Fill(yy, (hitVtxY.at(i) - yy));
254  hefdxVsX->Fill(xx, (hitVtxX.at(i) - xx));
255 
256  hefXG4VsId->Fill(hitVtxX.at(i), xx);
257  hefYG4VsId->Fill(hitVtxY.at(i), yy);
258  hefZG4VsId->Fill(hitVtxZ.at(i), zz);
259 
260  hefdzVsLayer->Fill(layer, (hitVtxZ.at(i) - zz));
261  hefdyVsLayer->Fill(layer, (hitVtxY.at(i) - yy));
262  hefdxVsLayer->Fill(layer, (hitVtxX.at(i) - xx));
263 
264  hefdX->Fill((hitVtxX.at(i) - xx));
265  hefdZ->Fill((hitVtxZ.at(i) - zz));
266  hefdY->Fill((hitVtxY.at(i) - yy));
267 
268  } else {
269  hebdzVsZ->Fill(zz, (hitVtxZ.at(i) - zz));
270  hebdyVsY->Fill(yy, (hitVtxY.at(i) - yy));
271  hebdxVsX->Fill(xx, (hitVtxX.at(i) - xx));
272 
273  hebXG4VsId->Fill(hitVtxX.at(i), xx);
274  hebYG4VsId->Fill(hitVtxY.at(i), yy);
275  hebZG4VsId->Fill(hitVtxZ.at(i), zz);
276 
277  hebdzVsLayer->Fill(layer, (hitVtxZ.at(i) - zz));
278  hebdyVsLayer->Fill(layer, (hitVtxY.at(i) - yy));
279  hebdxVsLayer->Fill(layer, (hitVtxX.at(i) - xx));
280 
281  hebdX->Fill((hitVtxX.at(i) - xx));
282  hebdZ->Fill((hitVtxZ.at(i) - zz));
283  hebdY->Fill((hitVtxY.at(i) - yy));
284  }
285  }
286  } //end G4 hits
287 
288  } else {
289  if (verbosity_ > 0)
290  edm::LogVerbatim("HGCalValid") << "HGCGeometryValidation::No PHGCalInfo";
291  }
292 }
293 
294 //define this as a plug-in
HGCGeometryValidation::hefdzVsZ
MonitorElement * hefdzVsZ
Definition: HGCGeometryValidation.cc:61
ConfigurationDescriptions.h
GenParticlesHelper.h
HGCGeometryValidation::heedzVsLayer
MonitorElement * heedzVsLayer
Definition: HGCGeometryValidation.cc:63
dqm::impl::MonitorElement
Definition: MonitorElement.h:99
Handle.h
HGCGeometryValidation::hebdzVsZ
MonitorElement * hebdzVsZ
Definition: HGCGeometryValidation.cc:62
mps_fire.i
i
Definition: mps_fire.py:428
edm::ESInputTag
Definition: ESInputTag.h:87
geometryCSVtoXML.zz
zz
Definition: geometryCSVtoXML.py:19
mmtocm
const double mmtocm
Definition: HGCGeometryValidation.cc:37
MessageLogger.h
HGCScintillatorDetId.h
HGCGeometryValidation::hebdyVsLayer
MonitorElement * hebdyVsLayer
Definition: HGCGeometryValidation.cc:64
HGCNumberingScheme.h
HGCGeometryValidation::g4Token_
edm::EDGetTokenT< PHGCalValidInfo > g4Token_
Definition: HGCGeometryValidation.cc:51
HGCGeometryValidation::hebdZ
MonitorElement * hebdZ
Definition: HGCGeometryValidation.cc:74
edm::Run
Definition: Run.h:45
HGCGeometryValidation::geometrySource_
std::vector< std::string > geometrySource_
Definition: HGCGeometryValidation.cc:52
HGCGeometryValidation::heedzVsZ
MonitorElement * heedzVsZ
Definition: HGCGeometryValidation.cc:60
HGCGeometryValidation::heeTotEdepStep
MonitorElement * heeTotEdepStep
Definition: HGCGeometryValidation.cc:71
ecaldqm::zside
int zside(DetId const &)
Definition: EcalDQMCommonUtils.cc:189
HGCGeometryValidation::bookHistograms
void bookHistograms(DQMStore::IBooker &, edm::Run const &, edm::EventSetup const &) override
Definition: HGCGeometryValidation.cc:101
edm::EDGetTokenT< PHGCalValidInfo >
PHGCalValidInfo::hefTotEdep
float hefTotEdep() const
Definition: PHGCalValidInfo.h:18
HGCalTestNumbering::unpackHexagonIndex
static void unpackHexagonIndex(const uint32_t &idx, int &subdet, int &z, int &lay, int &wafer, int &celltyp, int &cell)
Definition: HGCalTestNumbering.cc:46
HGCSiliconDetId.h
edm::ParameterSetDescription
Definition: ParameterSetDescription.h:52
HGCGeometryValidation::hefdxVsX
MonitorElement * hefdxVsX
Definition: HGCGeometryValidation.cc:61
HGCalWaferIndex::waferU
int32_t waferU(const int32_t index)
Definition: HGCalWaferIndex.cc:27
HGCGeometryValidation::HGCGeometryValidation
HGCGeometryValidation(const edm::ParameterSet &)
Definition: HGCGeometryValidation.cc:77
dqm::implementation::NavigatorBase::setCurrentFolder
virtual void setCurrentFolder(std::string const &fullpath)
Definition: DQMStore.cc:32
HGCGeometryValidation::hefdX
MonitorElement * hefdX
Definition: HGCGeometryValidation.cc:73
if
if(0==first)
Definition: CAHitNtupletGeneratorKernelsImpl.h:58
PHGCalValidInfo::hitIndex
std::vector< unsigned int > hitIndex() const
Definition: PHGCalValidInfo.h:25
DQMStore.h
PHGCalValidInfo::hefhgcEdep
std::vector< float > hefhgcEdep() const
Definition: PHGCalValidInfo.h:22
HGCGeometryValidation::hebdxVsX
MonitorElement * hebdxVsX
Definition: HGCGeometryValidation.cc:62
HGCGeometryValidation::heeXG4VsId
MonitorElement * heeXG4VsId
Definition: HGCGeometryValidation.cc:66
edm::Handle
Definition: AssociativeIterator.h:50
HGCGeometryValidation::hefdxVsLayer
MonitorElement * hefdxVsLayer
Definition: HGCGeometryValidation.cc:65
HGCGeometryValidation::heedY
MonitorElement * heedY
Definition: HGCGeometryValidation.cc:72
HGCSiliconDetId
Definition: HGCSiliconDetId.h:22
ForwardSubdetector.h
LEDCalibrationChannels.iphi
iphi
Definition: LEDCalibrationChannels.py:64
HGCGeometryValidation::hebYG4VsId
MonitorElement * hebYG4VsId
Definition: HGCGeometryValidation.cc:67
HGCGeometryValidation::hebdyVsY
MonitorElement * hebdyVsY
Definition: HGCGeometryValidation.cc:62
HGCGeometryValidation::hefdyVsY
MonitorElement * hefdyVsY
Definition: HGCGeometryValidation.cc:61
HGCGeometryValidation::heedxVsX
MonitorElement * heedxVsX
Definition: HGCGeometryValidation.cc:60
DetId::HGCalHSi
Definition: DetId.h:33
DetId::HGCalEE
Definition: DetId.h:32
MakerMacros.h
HGCGeometryValidation::heedZ
MonitorElement * heedZ
Definition: HGCGeometryValidation.cc:72
DEFINE_FWK_MODULE
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
Service.h
HGCGeometryValidation::hgcGeometry_
std::vector< const HGCalDDDConstants * > hgcGeometry_
Definition: HGCGeometryValidation.cc:57
dqm::impl::MonitorElement::Fill
void Fill(long long x)
Definition: MonitorElement.h:290
HGCGeometryValidation::hebTotEdepStep
MonitorElement * hebTotEdepStep
Definition: HGCGeometryValidation.cc:71
HGCGeometryValidation::heeYG4VsId
MonitorElement * heeYG4VsId
Definition: HGCGeometryValidation.cc:67
HGCalWaferIndex::waferV
int32_t waferV(const int32_t index)
Definition: HGCalWaferIndex.cc:32
HGCGeometryValidation::hefdyVsLayer
MonitorElement * hefdyVsLayer
Definition: HGCGeometryValidation.cc:64
EDGetToken.h
HGCGeometryValidation::hebXG4VsId
MonitorElement * hebXG4VsId
Definition: HGCGeometryValidation.cc:66
HGCGeometryValidation::analyze
void analyze(const edm::Event &, const edm::EventSetup &) override
Definition: HGCGeometryValidation.cc:162
geometryCSVtoXML.xy
xy
Definition: geometryCSVtoXML.py:19
DQMEDAnalyzer.h
edm::ConfigurationDescriptions
Definition: ConfigurationDescriptions.h:28
phase1PixelTopology::layer
constexpr std::array< uint8_t, layerIndexSize > layer
Definition: phase1PixelTopology.h:99
HGCGeometryValidation::fillDescriptions
static void fillDescriptions(edm::ConfigurationDescriptions &descriptions)
Definition: HGCGeometryValidation.cc:88
HGCEE
Definition: ForwardSubdetector.h:8
DQMEDAnalyzer
Definition: DQMEDAnalyzer.py:1
HGCGeometryValidation::hebdY
MonitorElement * hebdY
Definition: HGCGeometryValidation.cc:74
HGCGeometryValidation::geomToken_
std::vector< edm::ESGetToken< HGCalDDDConstants, IdealGeometryRecord > > geomToken_
Definition: HGCGeometryValidation.cc:54
edm::ParameterSet
Definition: ParameterSet.h:47
HGCGeometryValidation::hefdZ
MonitorElement * hefdZ
Definition: HGCGeometryValidation.cc:73
Event.h
geometryCSVtoXML.yy
yy
Definition: geometryCSVtoXML.py:19
PHGCalValidInfo::eehgcEdep
std::vector< float > eehgcEdep() const
Definition: PHGCalValidInfo.h:21
HGCGeometryValidation::heedyVsLayer
MonitorElement * heedyVsLayer
Definition: HGCGeometryValidation.cc:64
runTauDisplay.dtype
dtype
Definition: runTauDisplay.py:121
PCaloHit.h
HGCGeometryValidation::hebdX
MonitorElement * hebdX
Definition: HGCGeometryValidation.cc:74
createfilelist.int
int
Definition: createfilelist.py:10
iEvent
int iEvent
Definition: GenABIO.cc:224
HGCGeometryValidation::heedX
MonitorElement * heedX
Definition: HGCGeometryValidation.cc:72
HGCGeometryValidation::heedyVsY
MonitorElement * heedyVsY
Definition: HGCGeometryValidation.cc:60
IdealGeometryRecord.h
HGCGeometryValidation::hebdxVsLayer
MonitorElement * hebdxVsLayer
Definition: HGCGeometryValidation.cc:65
edm::EventSetup
Definition: EventSetup.h:58
HGCGeometryValidation::~HGCGeometryValidation
~HGCGeometryValidation() override
Definition: HGCGeometryValidation.cc:86
PHGCalValidInfo::hitDets
std::vector< unsigned int > hitDets() const
Definition: PHGCalValidInfo.h:24
PHGCalValidInfo::eeTotEdep
float eeTotEdep() const
Definition: PHGCalValidInfo.h:17
edm::EventSetup::getData
bool getData(T &iHolder) const
Definition: EventSetup.h:127
looper.cfg
cfg
Definition: looper.py:296
submitPVResolutionJobs.desc
string desc
Definition: submitPVResolutionJobs.py:251
HGCGeometryValidation::hefdY
MonitorElement * hefdY
Definition: HGCGeometryValidation.cc:73
Frameworkfwd.h
HGCScintillatorDetId
Definition: HGCScintillatorDetId.h:23
edm::LogVerbatim
Log< level::Info, true > LogVerbatim
Definition: MessageLogger.h:128
triggerObjects_cff.id
id
Definition: triggerObjects_cff.py:29
DetId::HGCalHSc
Definition: DetId.h:34
PHGCalValidInfo::hebTotEdep
float hebTotEdep() const
Definition: PHGCalValidInfo.h:19
dqm::implementation::IBooker::book2D
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:177
PHGCalValidInfo::hitvtxY
std::vector< float > hitvtxY() const
Definition: PHGCalValidInfo.h:27
HGCGeometryValidation::hefLayerVsEnStep
MonitorElement * hefLayerVsEnStep
Definition: HGCGeometryValidation.cc:69
HGCGeometryValidation::hebdzVsLayer
MonitorElement * hebdzVsLayer
Definition: HGCGeometryValidation.cc:63
HGCGeometryValidation::hebZG4VsId
MonitorElement * hebZG4VsId
Definition: HGCGeometryValidation.cc:68
HGCGeometryValidation::hefYG4VsId
MonitorElement * hefYG4VsId
Definition: HGCGeometryValidation.cc:67
PHGCalValidInfo::hitvtxX
std::vector< float > hitvtxX() const
Definition: PHGCalValidInfo.h:26
PHGCalValidInfo::hitvtxZ
std::vector< float > hitvtxZ() const
Definition: PHGCalValidInfo.h:28
Skims_PA_cff.name
name
Definition: Skims_PA_cff.py:17
HGCGeometryValidation::hefTotEdepStep
MonitorElement * hefTotEdepStep
Definition: HGCGeometryValidation.cc:71
HGCGeometryValidation::hefdzVsLayer
MonitorElement * hefdzVsLayer
Definition: HGCGeometryValidation.cc:63
Exception.h
PCaloHitContainer.h
HGCGeometryValidation
Definition: HGCGeometryValidation.cc:39
dqm::implementation::IBooker
Definition: DQMStore.h:43
HGCGeometryValidation::hebLayerVsEnStep
MonitorElement * hebLayerVsEnStep
Definition: HGCGeometryValidation.cc:69
HGCGeometryValidation::heeZG4VsId
MonitorElement * heeZG4VsId
Definition: HGCGeometryValidation.cc:68
HGCGeometryValidation::verbosity_
int verbosity_
Definition: HGCGeometryValidation.cc:53
HGCalDDDConstants.h
ParameterSet.h
DetId::Forward
Definition: DetId.h:30
HGCGeometryValidation::hefZG4VsId
MonitorElement * hefZG4VsId
Definition: HGCGeometryValidation.cc:68
edm::HandleBase::isValid
bool isValid() const
Definition: HandleBase.h:70
PHGCalValidInfo::hebhgcEdep
std::vector< float > hebhgcEdep() const
Definition: PHGCalValidInfo.h:23
edm::Event
Definition: Event.h:73
PHGCalValidInfo.h
edm::ConfigurationDescriptions::addDefault
void addDefault(ParameterSetDescription const &psetDescription)
Definition: ConfigurationDescriptions.cc:99
HGCGeometryValidation::heedxVsLayer
MonitorElement * heedxVsLayer
Definition: HGCGeometryValidation.cc:65
HGCGeometryValidation::hefXG4VsId
MonitorElement * hefXG4VsId
Definition: HGCGeometryValidation.cc:66
HGCGeometryValidation::dqmBeginRun
void dqmBeginRun(edm::Run const &, edm::EventSetup const &) override
Definition: HGCGeometryValidation.cc:94
edm::InputTag
Definition: InputTag.h:15
HGCGeometryValidation::heeLayerVsEnStep
MonitorElement * heeLayerVsEnStep
Definition: HGCGeometryValidation.cc:69
geometryCSVtoXML.xx
xx
Definition: geometryCSVtoXML.py:19
dqm::implementation::IBooker::book1D
MonitorElement * book1D(TString const &name, TString const &title, int const nchX, double const lowX, double const highX, FUNC onbooking=NOOP())
Definition: DQMStore.h:98
HGCalTestNumbering.h