CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
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 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

double data_ [MAXSAMPLES]
 
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.

Date:
2013/04/15 12:19:45
Revision:
1.6

Definition at line 16 of file CaloSamples.h.

Constructor & Destructor Documentation

CaloSamples::CaloSamples ( )

Definition at line 6 of file CaloSamples.cc.

References setBlank().

int precisePresamples_
Definition: CaloSamples.h:82
void setBlank()
Definition: CaloSamples.cc:98
int presamples_
Definition: CaloSamples.h:79
int preciseSize_
Definition: CaloSamples.h:82
CaloSamples::CaloSamples ( const DetId id,
int  size 
)
explicit

Definition at line 8 of file CaloSamples.cc.

References setBlank().

8  :
9  id_ ( id ) ,
10  size_ ( size ) ,
11  presamples_ ( 0 ) ,
12  deltaTprecise_ (0.0f) ,
13  preciseSize_(0),
14  precisePresamples_(0) { setBlank() ; }
int precisePresamples_
Definition: CaloSamples.h:82
void setBlank()
Definition: CaloSamples.cc:98
double f[11][100]
int size() const
get the size
Definition: CaloSamples.h:26
float deltaTprecise_
Definition: CaloSamples.h:80
int presamples_
Definition: CaloSamples.h:79
int preciseSize_
Definition: CaloSamples.h:82
CaloSamples::CaloSamples ( const DetId id,
int  size,
int  preciseSize 
)
explicit

Definition at line 16 of file CaloSamples.cc.

References setBlank().

16  :
17  id_ ( id ) ,
18  size_ ( size ) ,
19  presamples_ ( 0 ) ,
20  deltaTprecise_ (0.0f) ,
21  preciseSize_(presize),
22  precisePresamples_(0) { setBlank() ; }
int precisePresamples_
Definition: CaloSamples.h:82
void setBlank()
Definition: CaloSamples.cc:98
double f[11][100]
int size() const
get the size
Definition: CaloSamples.h:26
float deltaTprecise_
Definition: CaloSamples.h:80
int presamples_
Definition: CaloSamples.h:79
int preciseSize_
Definition: CaloSamples.h:82

Member Function Documentation

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

Definition at line 88 of file CaloSamples.cc.

References data_, alignCSCRings::e, funct::false, i, MAXSAMPLES, and funct::true.

Referenced by CaloHitRespoNew::findSignal().

89 {
90  for( int i ( 0 ) ; i != MAXSAMPLES ; ++i )
91  {
92  if( 1.e-6 < fabs( data_[i] ) ) return false ;
93  }
94  return true ;
95 }
int i
Definition: DBlmapReader.cc:9
static const int MAXSAMPLES
Definition: CaloSamples.h:75
double data_[MAXSAMPLES]
Definition: CaloSamples.h:78
CaloSamples & CaloSamples::offsetTime ( double  offset)

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

Definition at line 67 of file CaloSamples.cc.

References data, data_, f, i, MAXSAMPLES, evf::evtn::offset(), and lumiQTWidget::t.

Referenced by HcalTimeSlewSim::delay().

68 {
69  double data[MAXSAMPLES];
70  for( int i ( 0 ) ; i != MAXSAMPLES ; ++i )
71  {
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 >= MAXSAMPLES) ? 0. : data_[firstbin];
77  double v2 = (nextbin < 0 || nextbin >= MAXSAMPLES) ? 0. : data_[nextbin];
78  data[i] = (v1*(1.-f)+v2*f);
79  }
80  for( int i ( 0 ) ; i != MAXSAMPLES ; ++i )
81  {
82  data_[i] = data[i];
83  }
84  return (*this);
85 }
int i
Definition: DBlmapReader.cc:9
static const int MAXSAMPLES
Definition: CaloSamples.h:75
double f[11][100]
unsigned int offset(bool)
char data[epos_bytes_allocation]
Definition: EPOS_Wrapper.h:82
double data_[MAXSAMPLES]
Definition: CaloSamples.h:78
CaloSamples& CaloSamples::operator*= ( double  value)
inline

scale all samples

Definition at line 45 of file CaloSamples.h.

References scale().

45 { return scale(value); }
CaloSamples & scale(double value)
multiply each item by this value
Definition: CaloSamples.cc:33
CaloSamples & CaloSamples::operator+= ( double  value)

add a value to all samples

Definition at line 40 of file CaloSamples.cc.

References data_, deltaTprecise_, i, j, MAXSAMPLES, and preciseData_.

40  {
41  for (int i=0; i<MAXSAMPLES; i++) data_[i]+=value;
42  for (std::vector<float>::iterator j=preciseData_.begin() ; j!=preciseData_.end(); j++)
43  (*j)+=value*deltaTprecise_/25.0; // note that the scale is conserved!
44  return (*this);
45 }
int i
Definition: DBlmapReader.cc:9
static const int MAXSAMPLES
Definition: CaloSamples.h:75
std::vector< float > preciseData_
Definition: CaloSamples.h:81
int j
Definition: DBlmapReader.cc:9
float deltaTprecise_
Definition: CaloSamples.h:80
double data_[MAXSAMPLES]
Definition: CaloSamples.h:78
CaloSamples & CaloSamples::operator+= ( const CaloSamples other)

Definition at line 47 of file CaloSamples.cc.

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

47  {
48  if(size_ != other.size_ ||
49  presamples_ != other.presamples_ ||
50  preciseSize_ != other.preciseSize_) {
51  edm::LogError("CaloHitResponse") << "Mismatched calo signals ";
52  }
53  int i;
54  for(i = 0; i < size_; ++i) {
55  data_[i] += other.data_[i];
56  }
57  if ( preciseData_.size() == 0 && other.preciseData_.size() > 0 ) resetPrecise();
58  if ( other.preciseData_.size() > 0 ) {
59  for(i = 0; i < preciseSize_; ++i) {
60  preciseData_[i] += other.preciseData_[i];
61  }
62  }
63  return *this;
64 }
int i
Definition: DBlmapReader.cc:9
void resetPrecise()
Definition: CaloSamples.cc:25
std::vector< float > preciseData_
Definition: CaloSamples.h:81
int presamples_
Definition: CaloSamples.h:79
double data_[MAXSAMPLES]
Definition: CaloSamples.h:78
int preciseSize_
Definition: CaloSamples.h:82
double& CaloSamples::operator[] ( int  i)
inline

mutable operator to access samples

Definition at line 28 of file CaloSamples.h.

References data_, and i.

28 { return data_[i]; }
int i
Definition: DBlmapReader.cc:9
double data_[MAXSAMPLES]
Definition: CaloSamples.h:78
double CaloSamples::operator[] ( int  i) const
inline

const operator to access samples

Definition at line 30 of file CaloSamples.h.

References data_, and i.

30 { return data_[i]; }
int i
Definition: DBlmapReader.cc:9
double data_[MAXSAMPLES]
Definition: CaloSamples.h:78
float CaloSamples::preciseAt ( int  i) const
inline

const function to access precise samples

Definition at line 35 of file CaloSamples.h.

References i, and preciseData_.

Referenced by HcalTDC::timing().

35 { return preciseData_[i]; }
int i
Definition: DBlmapReader.cc:9
std::vector< float > preciseData_
Definition: CaloSamples.h:81
float& CaloSamples::preciseAtMod ( int  i)
inline

mutable function to access precise samples

Definition at line 33 of file CaloSamples.h.

References i, and preciseData_.

Referenced by HcalSiPMHitResponse::differentiatePreciseSamples(), and HcalSiPMHitResponse::makeSiPMSignal().

33 { return preciseData_[i]; }
int i
Definition: DBlmapReader.cc:9
std::vector< float > preciseData_
Definition: CaloSamples.h:81
float CaloSamples::preciseDeltaT ( ) const
inline

Definition at line 66 of file CaloSamples.h.

References deltaTprecise_.

Referenced by HcalSiPMHitResponse::differentiatePreciseSamples().

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

Definition at line 65 of file CaloSamples.h.

References precisePresamples_.

Referenced by setPrecise().

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

get the size

Definition at line 64 of file CaloSamples.h.

References preciseData_, and preciseSize_.

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

64 { if ( preciseData_.size() ==0 ) return 0; return preciseSize_; }
std::vector< float > preciseData_
Definition: CaloSamples.h:81
int preciseSize_
Definition: CaloSamples.h:82
int CaloSamples::presamples ( ) const
inline
void CaloSamples::resetPrecise ( )

Definition at line 25 of file CaloSamples.cc.

References preciseData_, and preciseSize_.

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

25  {
26  preciseData_.resize(preciseSize_,0);
27 }
std::vector< float > preciseData_
Definition: CaloSamples.h:81
int preciseSize_
Definition: CaloSamples.h:82
CaloSamples & CaloSamples::scale ( double  value)
void CaloSamples::setBlank ( )

Definition at line 98 of file CaloSamples.cc.

References data_, lumiContext::fill, MAXSAMPLES, and preciseData_.

Referenced by CaloSamples().

99 {
100  std::fill( data_ , data_ + MAXSAMPLES, (double)0.0 ) ;
101  std::fill( preciseData_.begin() , preciseData_.end(), (double)0.0 ) ;
102 }
string fill
Definition: lumiContext.py:319
static const int MAXSAMPLES
Definition: CaloSamples.h:75
std::vector< float > preciseData_
Definition: CaloSamples.h:81
double data_[MAXSAMPLES]
Definition: CaloSamples.h:78
void CaloSamples::setDetId ( DetId  detId)
inline

Definition at line 55 of file CaloSamples.h.

References id_.

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

Definition at line 68 of file CaloSamples.h.

References deltaTprecise_, precisePresamples(), and precisePresamples_.

68  {
70  deltaTprecise_=deltaT;
71  }
int precisePresamples_
Definition: CaloSamples.h:82
int precisePresamples() const
Definition: CaloSamples.h:65
float deltaTprecise_
Definition: CaloSamples.h:80
void CaloSamples::setPresamples ( int  pre)

set presample information

Definition at line 29 of file CaloSamples.cc.

References presamples_.

Referenced by CastorNominalCoder::adc2fC(), HcalNominalCoder::adc2fC(), CastorCoderDb::adc2fC_(), and HcalCoderDb::adc2fC_().

29  {
30  presamples_ = pre ;
31 }
int presamples_
Definition: CaloSamples.h:79
void CaloSamples::setSize ( unsigned int  size)
inline

Definition at line 57 of file CaloSamples.h.

References size(), and size_.

57 { size_ = size ; }
int size() const
get the size
Definition: CaloSamples.h:26
int CaloSamples::size ( void  ) const
inline

Member Data Documentation

double CaloSamples::data_[MAXSAMPLES]
private

Definition at line 78 of file CaloSamples.h.

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

float CaloSamples::deltaTprecise_
private

Definition at line 80 of file CaloSamples.h.

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

DetId CaloSamples::id_
private

Definition at line 77 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 82 of file CaloSamples.h.

Referenced by precisePresamples(), and setPrecise().

int CaloSamples::preciseSize_
private

Definition at line 82 of file CaloSamples.h.

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

int CaloSamples::presamples_
private

Definition at line 79 of file CaloSamples.h.

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

int CaloSamples::size_
private

Definition at line 79 of file CaloSamples.h.

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