13 #include <top/dbobjects/TOPASICPedestals.h>
40 c_TimeAxisSize = c_WindowSize * 4
79 void setTimeAxis(
const std::vector<double>& sampleTimes,
double syncTimeBase);
131 double getFullTime(
int window,
double sample)
const;
142 double getTime(
int window,
double sample)
const
169 double getTimeBin(
int window,
int sampleNumber)
const;
181 double getSample(
int window,
double time)
const;
@ c_WindowSize
number of samples
Calibration constants of a singe ASIC channel: time axis (sample times)
unsigned short m_scrodID
scrod ID
ClassDef(TOPSampleTimes, 2)
ClassDef.
TOPSampleTimes(unsigned scrodID, unsigned channel, double syncTimeBase)
Useful constructor, sets equidistant time base (uncalibrated)
double getTimeError() const
Returns uncertainty on time base calibration incl.
unsigned short m_channel
hardware channel number within SCROD
bool isDefault() const
Returns calibration status.
float m_timeAxis[c_TimeAxisSize+1]
time axis + right border point
~TOPSampleTimes()
Destructor.
void setUnusable()
Switches calibration status to unusable to flag badly calibrated constant.
void setTimeError(double error)
Sets uncertainty on time base calibration incl.
EStatus
Calibration status values.
@ c_Calibrated
good calibrated value
@ c_Unusable
bad calibrated value
@ c_Default
uncalibrated default value
double getTimeRange() const
Returns time axis range (time interval corresponding to 4 asic windows)
unsigned getChannel() const
Returns hardware channel number.
unsigned getScrodID() const
Returns scrod ID.
EStatus m_calibrated
calibration status
bool isCalibrated() const
Returns calibration status.
double getDeltaTime(int window, double sample2, double sample1) const
Returns time difference between sample2 and sample1.
float m_timeError
uncertainty of time axis points incl.
double getTime(int window, double sample) const
Returns time w.r.t SSTin that corresponds to the window number.
bool isUnusable() const
Returns calibration status.
TOPSampleTimes()
Default constructor.
double getFullTime(int window, double sample) const
Returns time with respect to sample 0 of window 0.
double getTimeBin(int window, int sampleNumber) const
Returns time bin of a given sample number and window (e.g.
double getSample(int window, double time) const
Returns sample with respect to sample 0 of the specified ASIC window (inverse of getTime).
void setTimeAxis(double syncTimeBase)
Sets equidistant time axis (uncalibrated).
std::vector< double > getTimeAxis() const
Returns time axis (sample times)
Abstract base class for different kinds of events.