CMS 3D CMS Logo

List of all members | Public Member Functions | Static Public Attributes | Private Attributes
CaloSamples Class Reference

#include <CaloSamples.h>

Public Member Functions

 CaloSamples ()
 
 CaloSamples (const DetId &id, int size)
 
 CaloSamples (const DetId &id, int size, int preciseSize)
 
DetId id () const
 get the (generic) id More...
 
bool isBlank () const
 
CaloSamplesoffsetTime (double offset)
 shift all the samples by a time, in ns, interpolating More...
 
CaloSamplesoperator*= (double value)
 scale all samples More...
 
CaloSamplesoperator+= (double value)
 add a value to all samples More...
 
CaloSamplesoperator+= (const CaloSamples &other)
 
double & operator[] (int i)
 mutable operator to access samples More...
 
double operator[] (int i) const
 const operator to access samples More...
 
float preciseAt (int i) const
 const function to access precise samples More...
 
float & preciseAtMod (int i)
 mutable function to access precise samples More...
 
float preciseDeltaT () const
 
int precisePresamples () const
 
int preciseSize () const
 get the size More...
 
int presamples () const
 access presample information More...
 
void resetPrecise ()
 
CaloSamplesscale (double value)
 multiply each item by this value More...
 
void setBlank ()
 
void setDetId (DetId detId)
 
void setPrecise (int precisePresamples, float deltaT)
 
void setPreciseSize (unsigned int size)
 
void setPresamples (int pre)
 set presample information More...
 
void setSize (unsigned int size)
 
int size () const
 get the size More...
 

Static Public Attributes

static const int MAXSAMPLES = 10
 

Private Attributes

std::vector< double > data_
 
float deltaTprecise_
 
DetId id_
 
std::vector< float > preciseData_
 
int precisePresamples_
 
int preciseSize_
 
int presamples_
 
int size_
 

Detailed Description

Class which represents the charge/voltage measurements of an event/channel with the ADC decoding performed.

Definition at line 14 of file CaloSamples.h.

Constructor & Destructor Documentation

CaloSamples::CaloSamples ( )

Definition at line 6 of file CaloSamples.cc.

References setBlank().

int precisePresamples_
Definition: CaloSamples.h:94
void setBlank()
Definition: CaloSamples.cc:95
int presamples_
Definition: CaloSamples.h:90
int preciseSize_
Definition: CaloSamples.h:94
CaloSamples::CaloSamples ( const DetId id,
int  size 
)
explicit

Definition at line 8 of file CaloSamples.cc.

References setBlank().

9  : id_(id),
10  size_(size),
11  presamples_(0),
12  data_(size_, 0.0),
13  deltaTprecise_(0.0f),
14  preciseSize_(0),
16  setBlank();
17 }
int precisePresamples_
Definition: CaloSamples.h:94
void setBlank()
Definition: CaloSamples.cc:95
double f[11][100]
std::vector< double > data_
Definition: CaloSamples.h:91
int size() const
get the size
Definition: CaloSamples.h:24
float deltaTprecise_
Definition: CaloSamples.h:92
int presamples_
Definition: CaloSamples.h:90
int preciseSize_
Definition: CaloSamples.h:94
CaloSamples::CaloSamples ( const DetId id,
int  size,
int  preciseSize 
)
explicit

Definition at line 19 of file CaloSamples.cc.

References setBlank().

20  : id_(id),
21  size_(size),
22  presamples_(0),
23  data_(size_, 0.0),
24  deltaTprecise_(0.0f),
25  preciseSize_(presize),
27  setBlank();
28 }
int precisePresamples_
Definition: CaloSamples.h:94
void setBlank()
Definition: CaloSamples.cc:95
double f[11][100]
std::vector< double > data_
Definition: CaloSamples.h:91
int size() const
get the size
Definition: CaloSamples.h:24
float deltaTprecise_
Definition: CaloSamples.h:92
int presamples_
Definition: CaloSamples.h:90
int preciseSize_
Definition: CaloSamples.h:94

Member Function Documentation

DetId CaloSamples::id ( ) const
inline
bool CaloSamples::isBlank ( ) const

Definition at line 86 of file CaloSamples.cc.

References data_, MillePedeFileConverter_cfg::e, mps_fire::i, and size_.

Referenced by setPreciseSize().

87 {
88  for (int i(0); i != size_; ++i) {
89  if (1.e-6 < fabs(data_[i]))
90  return false;
91  }
92  return true;
93 }
std::vector< double > data_
Definition: CaloSamples.h:91
CaloSamples & CaloSamples::offsetTime ( double  offset)

shift all the samples by a time, in ns, interpolating

Definition at line 69 of file CaloSamples.cc.

References data, data_, f, mps_fire::i, PFRecoTauDiscriminationByIsolation_cfi::offset, size_, and protons_cff::t.

Referenced by operator*=().

69  {
70  std::vector<double> data(size_, 0.0);
71  for (int i(0); i != size_; ++i) {
72  double t = i * 25. - offset;
73  int firstbin = floor(t / 25.);
74  double f = t / 25. - firstbin;
75  int nextbin = firstbin + 1;
76  double v1 = (firstbin < 0 || firstbin >= size_) ? 0. : data_[firstbin];
77  double v2 = (nextbin < 0 || nextbin >= size_) ? 0. : data_[nextbin];
78  data[i] = (v1 * (1. - f) + v2 * f);
79  }
80  for (int i(0); i != size_; ++i) {
81  data_[i] = data[i];
82  }
83  return (*this);
84 }
double f[11][100]
std::vector< double > data_
Definition: CaloSamples.h:91
char data[epos_bytes_allocation]
Definition: EPOS_Wrapper.h:82
CaloSamples& CaloSamples::operator*= ( double  value)
inline

scale all samples

Definition at line 43 of file CaloSamples.h.

References PFRecoTauDiscriminationByIsolation_cfi::offset, offsetTime(), operator+=(), trackingPlots::other, and scale().

43 { return scale(value); }
CaloSamples & scale(double value)
multiply each item by this value
Definition: CaloSamples.cc:35
Definition: value.py:1
CaloSamples & CaloSamples::operator+= ( double  value)

add a value to all samples

Definition at line 43 of file CaloSamples.cc.

References data_, deltaTprecise_, mps_fire::i, preciseData_, and size_.

Referenced by operator*=().

43  {
44  for (int i = 0; i < size_; i++)
45  data_[i] += value;
46  for (std::vector<float>::iterator j = preciseData_.begin(); j != preciseData_.end(); ++j)
47  (*j) += value * deltaTprecise_ / 25.0; // note that the scale is conserved!
48  return (*this);
49 }
std::vector< float > preciseData_
Definition: CaloSamples.h:93
Definition: value.py:1
std::vector< double > data_
Definition: CaloSamples.h:91
float deltaTprecise_
Definition: CaloSamples.h:92
CaloSamples & CaloSamples::operator+= ( const CaloSamples other)

Definition at line 51 of file CaloSamples.cc.

References data_, mps_fire::i, preciseData_, preciseSize_, presamples_, resetPrecise(), and size_.

51  {
52  if (size_ != other.size_ || presamples_ != other.presamples_ || preciseSize_ != other.preciseSize_) {
53  edm::LogError("CaloHitResponse") << "Mismatched calo signals ";
54  }
55  int i;
56  for (i = 0; i < size_; ++i) {
57  data_[i] += other.data_[i];
58  }
59  if (preciseData_.empty() && !other.preciseData_.empty())
60  resetPrecise();
61  if (!other.preciseData_.empty()) {
62  for (i = 0; i < preciseSize_; ++i) {
63  preciseData_[i] += other.preciseData_[i];
64  }
65  }
66  return *this;
67 }
void resetPrecise()
Definition: CaloSamples.cc:31
std::vector< float > preciseData_
Definition: CaloSamples.h:93
std::vector< double > data_
Definition: CaloSamples.h:91
int presamples_
Definition: CaloSamples.h:90
int preciseSize_
Definition: CaloSamples.h:94
double& CaloSamples::operator[] ( int  i)
inline

mutable operator to access samples

Definition at line 26 of file CaloSamples.h.

References data_, and mps_fire::i.

26 { return data_[i]; }
std::vector< double > data_
Definition: CaloSamples.h:91
double CaloSamples::operator[] ( int  i) const
inline

const operator to access samples

Definition at line 28 of file CaloSamples.h.

References data_, and mps_fire::i.

28 { return data_[i]; }
std::vector< double > data_
Definition: CaloSamples.h:91
float CaloSamples::preciseAt ( int  i) const
inline

const function to access precise samples

Definition at line 33 of file CaloSamples.h.

References mps_fire::i, and preciseData_.

Referenced by HcalTDC::timing().

33 { return preciseData_[i]; }
std::vector< float > preciseData_
Definition: CaloSamples.h:93
float& CaloSamples::preciseAtMod ( int  i)
inline

mutable function to access precise samples

Definition at line 31 of file CaloSamples.h.

References mps_fire::i, and preciseData_.

Referenced by CaloHitResponse::makeAnalogSignal(), and HcalSiPMHitResponse::makeSiPMSignal().

31 { return preciseData_[i]; }
std::vector< float > preciseData_
Definition: CaloSamples.h:93
float CaloSamples::preciseDeltaT ( ) const
inline

Definition at line 76 of file CaloSamples.h.

References deltaTprecise_.

76 { return deltaTprecise_; }
float deltaTprecise_
Definition: CaloSamples.h:92
int CaloSamples::precisePresamples ( ) const
inline

Definition at line 75 of file CaloSamples.h.

References precisePresamples_.

Referenced by setPrecise().

75 { return precisePresamples_; }
int precisePresamples_
Definition: CaloSamples.h:94
int CaloSamples::preciseSize ( ) const
inline

get the size

Definition at line 70 of file CaloSamples.h.

References preciseData_, and preciseSize_.

Referenced by HcalSiPMHitResponse::makeSiPMSignal(), operator<<(), and HcalTDC::timing().

70  {
71  if (preciseData_.empty())
72  return 0;
73  return preciseSize_;
74  }
std::vector< float > preciseData_
Definition: CaloSamples.h:93
int preciseSize_
Definition: CaloSamples.h:94
int CaloSamples::presamples ( ) const
inline
void CaloSamples::resetPrecise ( )

Definition at line 31 of file CaloSamples.cc.

References preciseData_, and preciseSize_.

Referenced by CaloHitResponse::makeAnalogSignal(), HcalSiPMHitResponse::makeSiPMSignal(), operator+=(), and setPrecise().

31 { preciseData_.resize(preciseSize_, 0); }
std::vector< float > preciseData_
Definition: CaloSamples.h:93
int preciseSize_
Definition: CaloSamples.h:94
CaloSamples & CaloSamples::scale ( double  value)
void CaloSamples::setBlank ( )

Definition at line 95 of file CaloSamples.cc.

References data_, lumiContext::fill, and preciseData_.

Referenced by CaloSamples(), and setPreciseSize().

96 {
97  std::fill(data_.begin(), data_.end(), (double)0.0);
98  std::fill(preciseData_.begin(), preciseData_.end(), (double)0.0);
99 }
std::vector< float > preciseData_
Definition: CaloSamples.h:93
std::vector< double > data_
Definition: CaloSamples.h:91
void CaloSamples::setDetId ( DetId  detId)
inline

Definition at line 53 of file CaloSamples.h.

References id_.

53 { id_ = detId; }
void CaloSamples::setPrecise ( int  precisePresamples,
float  deltaT 
)
inline

Definition at line 78 of file CaloSamples.h.

References deltaTprecise_, precisePresamples(), precisePresamples_, and resetPrecise().

Referenced by HcalSiPMHitResponse::makeBlankSignal().

78  {
80  deltaTprecise_ = deltaT;
81  }
int precisePresamples_
Definition: CaloSamples.h:94
int precisePresamples() const
Definition: CaloSamples.h:75
float deltaTprecise_
Definition: CaloSamples.h:92
void CaloSamples::setPreciseSize ( unsigned int  size)
inline

Definition at line 60 of file CaloSamples.h.

References isBlank(), preciseData_, preciseSize_, setBlank(), and size().

Referenced by HcalSiPMHitResponse::finalizeHits().

60  {
62  preciseData_.resize(preciseSize_, 0.);
63  }
std::vector< float > preciseData_
Definition: CaloSamples.h:93
int size() const
get the size
Definition: CaloSamples.h:24
int preciseSize_
Definition: CaloSamples.h:94
void CaloSamples::setPresamples ( int  pre)
void CaloSamples::setSize ( unsigned int  size)
inline

Definition at line 55 of file CaloSamples.h.

References data_, size(), and size_.

55  {
56  size_ = size;
57  data_.resize(size, 0.);
58  }
std::vector< double > data_
Definition: CaloSamples.h:91
int size() const
get the size
Definition: CaloSamples.h:24
int CaloSamples::size ( void  ) const
inline

Member Data Documentation

std::vector<double> CaloSamples::data_
private

Definition at line 91 of file CaloSamples.h.

Referenced by isBlank(), offsetTime(), operator+=(), operator[](), scale(), setBlank(), and setSize().

float CaloSamples::deltaTprecise_
private

Definition at line 92 of file CaloSamples.h.

Referenced by operator+=(), preciseDeltaT(), and setPrecise().

DetId CaloSamples::id_
private

Definition at line 89 of file CaloSamples.h.

Referenced by id(), and setDetId().

const int CaloSamples::MAXSAMPLES = 10
static
std::vector<float> CaloSamples::preciseData_
private
int CaloSamples::precisePresamples_
private

Definition at line 94 of file CaloSamples.h.

Referenced by precisePresamples(), and setPrecise().

int CaloSamples::preciseSize_
private

Definition at line 94 of file CaloSamples.h.

Referenced by operator+=(), preciseSize(), resetPrecise(), and setPreciseSize().

int CaloSamples::presamples_
private

Definition at line 90 of file CaloSamples.h.

Referenced by operator+=(), presamples(), and setPresamples().

int CaloSamples::size_
private

Definition at line 90 of file CaloSamples.h.

Referenced by isBlank(), offsetTime(), operator+=(), scale(), setSize(), and size().