CMS 3D CMS Logo

HcalPulseContainmentManager.cc
Go to the documentation of this file.
5 #include <iostream>
6 
8  : entries_(), shapes_(), max_fracerror_(max_fracerror) {
9  hcalTimeSlew_delay_ = nullptr;
10 }
11 
14  es.get<HcalTimeSlewRecord>().get("HBHE", delay);
16 
17  shapes_.beginRun(es);
18 }
19 
22 
23  shapes_.beginRun(conditions);
24 }
25 
26 double HcalPulseContainmentManager::correction(const HcalDetId& detId, int toAdd, float fixedphase_ns, double fc_ampl) {
27  /*
28  int sub = detId.subdet();
29  int depth = detId.depth();
30  int inteta = detId.ieta();
31  int intphi = detId.iphi();
32 
33  std::cout << "* HcalPulseContainmentManager::correction, cell:"
34  << " sub, ieta, iphi, depth = "
35  << sub << " " << inteta << " " << intphi
36  << " " << depth << " toAaa= " << toAdd
37  <<" phase = " << fixedphase_ns << " ampl = "
38  << fc_ampl
39  << std::endl;
40  */
41 
42  return get(detId, toAdd, fixedphase_ns)->getCorrection(fc_ampl);
43 }
44 
46  int toAdd,
47  float fixedphase_ns) {
48  // const HcalPulseShape * shape = &(shapes_.shape(detId));
49  const HcalPulseShape* shape = &(shapes_.shapeForReco(detId));
50  for (std::vector<HcalPulseContainmentEntry>::const_iterator entryItr = entries_.begin(); entryItr != entries_.end();
51  ++entryItr) {
52  if (entryItr->shape_ == shape && entryItr->toAdd_ == toAdd && entryItr->fixedphase_ns_ == fixedphase_ns) {
53  return &entryItr->correction_;
54  }
55  }
56 
57  /*
58  int sub = detId.subdet();
59  int depth = detId.depth();
60  int inteta = detId.ieta();
61  int intphi = detId.iphi();
62 
63  std::cout << "* HcalPulseContainmentManager::get new entry, cell:"
64  << " sub, ieta, iphi, depth = "
65  << sub << " " << inteta << " " << intphi
66  << " " << depth
67  << std::endl;
68  */
69 
70  // didn't find it. Make one.
72  toAdd,
73  fixedphase_ns,
74  shape,
76  entries_.push_back(entry);
77  return &(entries_.back().correction_);
78 }
HcalPulseContainmentManager::shapes_
HcalPulseShapes shapes_
Definition: HcalPulseContainmentManager.h:35
HcalPulseContainmentManager::entries_
std::vector< HcalPulseContainmentEntry > entries_
Definition: HcalPulseContainmentManager.h:34
ESHandle.h
HcalPulseContainmentManager.h
HcalPulseContainmentManager::max_fracerror_
float max_fracerror_
Definition: HcalPulseContainmentManager.h:37
mps_splice.entry
entry
Definition: mps_splice.py:68
HcalPulseShapes::shapeForReco
const Shape & shapeForReco(const HcalDetId &detId) const
Definition: HcalPulseShapes.cc:525
HcalPulseContainmentCorrection
Definition: HcalPulseContainmentCorrection.h:15
HcalPulseContainmentManager::get
const HcalPulseContainmentCorrection * get(const HcalDetId &detId, int toAdd, float fixedphase_ns)
Definition: HcalPulseContainmentManager.cc:45
HcalTimeSlew
Definition: HcalTimeSlew.h:19
edm::EventSetup::get
T get() const
Definition: EventSetup.h:73
edm::ESHandle
Definition: DTSurvey.h:22
HcalPulseContainmentManager::HcalPulseContainmentEntry
Definition: HcalPulseContainmentManager.h:22
HcalTimeSlewRecord
Definition: HcalTimeSlewRecord.h:4
HcalPulseContainmentManager::HcalPulseContainmentManager
HcalPulseContainmentManager(float max_fracerror)
Definition: HcalPulseContainmentManager.cc:7
HcalDetId
Definition: HcalDetId.h:12
HcalPulseShapes::beginRun
void beginRun(edm::EventSetup const &es)
Definition: HcalPulseShapes.cc:143
HcalPulseContainmentManager::hcalTimeSlew_delay_
const HcalTimeSlew * hcalTimeSlew_delay_
Definition: HcalPulseContainmentManager.h:39
edm::EventSetup
Definition: EventSetup.h:57
HcalPulseContainmentCorrection::getCorrection
double getCorrection(double fc_ampl) const
Definition: HcalPulseContainmentCorrection.cc:51
HcalPulseShape
Definition: HcalPulseShape.h:6
HcalDbService
Definition: HcalDbService.h:26
EventSetup.h
phase2TrackerDigitizer_cfi.delay
delay
Definition: phase2TrackerDigitizer_cfi.py:67
HLT_2018_cff.toAdd
toAdd
Definition: HLT_2018_cff.py:50595
HcalTimeSlewRecord.h
HcalPulseContainmentManager::correction
double correction(const HcalDetId &detId, int toAdd, float fixedphase_ns, double fc_ampl)
Definition: HcalPulseContainmentManager.cc:26
HcalPulseContainmentManager::beginRun
void beginRun(edm::EventSetup const &es)
Definition: HcalPulseContainmentManager.cc:12