Belle II Software  release-08-01-10
TOPRawDigit Class Reference

Class to store unpacked raw data (hits in feature-extraction format) It provides also calculation of 50% CFD leading and falling edge times and errors. More...

#include <TOPRawDigit.h>

Inheritance diagram for TOPRawDigit:
Collaboration diagram for TOPRawDigit:

Public Types

enum  ErrorFlags {
  c_HeadMagic = 0x0001 ,
  c_TailMagic = 0x0002 ,
  c_HitMagic = 0x0004 ,
  c_HitChecksum = 0x0008
}
 Enum for error flags; bits set if corresponding data not consistent. More...
 
enum  EDataTypes {
  c_Undefined = 0 ,
  c_MC = 1 ,
  c_Interim = 2 ,
  c_Production = 3 ,
  c_ProductionDebug = 4 ,
  c_Other = 99
}
 Enum for data types needed to steer time conversion in TOPRawDigitConverter. More...
 
enum  { c_WindowSize = 64 }
 Various constants. More...
 

Public Member Functions

 TOPRawDigit ()
 Default constructor.
 
 TOPRawDigit (unsigned short scrodID, EDataTypes dataType)
 Usefull constructor. More...
 
void setCarrierNumber (unsigned short carrier)
 Sets carrier board number. More...
 
void setASICNumber (unsigned short asic)
 Sets ASIC number. More...
 
void setASICChannel (unsigned short channel)
 Sets ASIC channel number. More...
 
void setASICWindow (unsigned short window)
 Sets first storage window number (logical window number) More...
 
void setStorageWindows (const std::vector< unsigned short > &windows)
 Sets storage windows of waveform segments. More...
 
void setLastWriteAddr (unsigned short window)
 Sets current (reference) window number. More...
 
void setTFine (unsigned short tfine)
 Sets fine timing for 50% CFD at rising edge (within two samples) More...
 
void setSampleRise (unsigned short sample)
 Sets sample number just before 50% CFD crossing at leading edge. More...
 
void setDeltaSamplePeak (unsigned short dsample)
 Sets peak position relative to m_sampleRise. More...
 
void setDeltaSampleFall (unsigned short dsample)
 Sets falling edge sample number just before 50% CFD crossing relative to m_sampleRise. More...
 
void setValueRise0 (short adc)
 Sets ADC value at m_sampleRise. More...
 
void setValueRise1 (short adc)
 Sets ADC value at m_sampleRise + 1. More...
 
void setValuePeak (short adc)
 Sets ADC value at m_sampleRise + m_dSamplePeak (e.g. More...
 
void setValueFall0 (short adc)
 Sets ADC value at m_sampleRise + m_dSampleFall. More...
 
void setValueFall1 (short adc)
 Sets ADC value at m_sampleRise + m_dSampleFall + 1. More...
 
void setIntegral (int integral)
 Sets integral of a pulse (e.g. More...
 
void setRevo9Counter (unsigned short revo9Counter)
 Sets number of global clock tics since last revo9 flag (production firmware only) More...
 
void setPhase (unsigned short phase)
 Sets beam orbit synchronisation phase (production firmware only) 9-state count: valid values are 0 - 8. More...
 
void setLookBackWindows (unsigned short lookBack)
 Sets number of look-back windows. More...
 
void setErrorFlags (unsigned short flags)
 Sets error flags. More...
 
void setOfflineFlag ()
 Sets offline flag: telling that this digit was extracted offline in basf2.
 
EDataTypes getDataType () const
 Returns data type. More...
 
unsigned getScrodID () const
 Returns SCROD ID. More...
 
unsigned getCarrierNumber () const
 Returns carrier board number. More...
 
unsigned getASICNumber () const
 Returns ASIC number. More...
 
unsigned getASICChannel () const
 Returns ASIC channel number. More...
 
unsigned getScrodChannel () const
 Returns channel number within SCROD (in the range 0 - 127) More...
 
unsigned getASICWindow () const
 Returns ASIC storage window number. More...
 
const std::vector< unsigned short > & getStorageWindows () const
 Returns storage window numbers of waveform segments (not always available!) More...
 
unsigned getLastWriteAddr () const
 Returns current (reference) ASIC window number. More...
 
unsigned getTFine () const
 Returns fine timing for 50% CFD (within two samples) More...
 
unsigned getSampleRise () const
 Returns sample number at leading edge just before 50% CFD crossing. More...
 
unsigned getDeltaSamplePeak () const
 Returns peak position relative to m_sampleRise. More...
 
unsigned getSamplePeak () const
 Returns peak position. More...
 
unsigned getDeltaSampleFall () const
 Returns sample number at falling edge just before 50% CFD relative to m_sampleRise. More...
 
unsigned getSampleFall () const
 Returns sample number at falling edge just before 50% CFD crossing. More...
 
int getValueRise0 () const
 Returns ADC value at leading edge (at m_sampleRise) More...
 
int getValueRise1 () const
 Returns ADC value at leading edge (at m_sampleRise + 1) More...
 
int getValuePeak () const
 Returns ADC value at peak (e.g. More...
 
int getValueFall0 () const
 Returns ADC value at falling edge (at m_sampleRise + m_dSampleFall) More...
 
int getValueFall1 () const
 Returns ADC value at falling edge (at m_sampleRise + m_dSampleFall + 1) More...
 
int getIntegral () const
 Returns integral of a pulse (e.g. More...
 
unsigned short getRevo9Counter () const
 Returns 127 MHz clock ticks since last revo9 marker. More...
 
unsigned short getLookBackWindows () const
 Returns number of look-back windows. More...
 
unsigned short getPhase () const
 Returns beam orbit synchronisation phase (9-state count: valid values are 0 - 8) More...
 
unsigned short getErrorFlags () const
 Returns error flags. More...
 
double getLeadingSlope () const
 Returns leading edge slope. More...
 
double getFallingSlope () const
 Returns falling edge slope. More...
 
double getCFDLeadingTime () const
 Returns leading edge CFD time. More...
 
double getCFDFallingTime () const
 Returns falling edge CFD time. More...
 
double getCFDLeadingTimeError (double rmsNoise) const
 Returns leading edge CFD time uncertainty (assuming uncorrelated noise) More...
 
double getCFDFallingTimeError (double rmsNoise) const
 Returns falling edge CFD time uncertainty (assuming uncorrelated noise) More...
 
double getFWHM () const
 Returns signal full width half maximum. More...
 
bool isLeadingEdgeValid () const
 Checks if leading edge is consistently defined. More...
 
bool isFallingEdgeValid () const
 Checks if falling edge is consistently defined. More...
 
bool isFEValid () const
 Checks if feature extraction points make sense. More...
 
bool isPedestalJump () const
 Checks if feature extraction finds a pedestal jump. More...
 
bool isAtWindowDiscontinuity (unsigned short storageDepth=508) const
 Checks if feature extraction points are at window discontinuity (e.g. More...
 
bool areWindowsInOrder (unsigned short storageDepth=508) const
 Checks if storage windows come in the consecutive order before the last sample (no gaps before the last sample) Note: returns true if m_windows is empty. More...
 
double correctTime (double time, unsigned short storageDepth=508) const
 Corrects time after window discontinuity by adding missing samples. More...
 
bool isWindowConsistent () const
 Checks if the first window number is the same as the first one in m_windows Note: returns true if m_windows is empty. More...
 
bool isMadeOffline () const
 Returns offline flag. More...
 
void addRelationTo (const RelationsInterface< BASE > *object, float weight=1.0, const std::string &namedRelation="") const
 Add a relation from this object to another object (with caching). More...
 
void addRelationTo (const TObject *object, float weight=1.0, const std::string &namedRelation="") const
 Add a relation from this object to another object (no caching, can be quite slow). More...
 
void copyRelations (const RelationsInterface< BASE > *sourceObj)
 Copies all relations of sourceObj (pointing from or to sourceObj) to this object (including weights). More...
 
template<class TO >
RelationVector< TO > getRelationsTo (const std::string &name="", const std::string &namedRelation="") const
 Get the relations that point from this object to another store array. More...
 
template<class FROM >
RelationVector< FROM > getRelationsFrom (const std::string &name="", const std::string &namedRelation="") const
 Get the relations that point from another store array to this object. More...
 
template<class T >
RelationVector< T > getRelationsWith (const std::string &name="", const std::string &namedRelation="") const
 Get the relations between this object and another store array. More...
 
template<class TO >
TO * getRelatedTo (const std::string &name="", const std::string &namedRelation="") const
 Get the object to which this object has a relation. More...
 
template<class FROM >
FROM * getRelatedFrom (const std::string &name="", const std::string &namedRelation="") const
 Get the object from which this object has a relation. More...
 
template<class T >
T * getRelated (const std::string &name="", const std::string &namedRelation="") const
 Get the object to or from which this object has a relation. More...
 
template<class TO >
std::pair< TO *, float > getRelatedToWithWeight (const std::string &name="", const std::string &namedRelation="") const
 Get first related object & weight of relation pointing to an array. More...
 
template<class FROM >
std::pair< FROM *, float > getRelatedFromWithWeight (const std::string &name="", const std::string &namedRelation="") const
 Get first related object & weight of relation pointing from an array. More...
 
template<class T >
std::pair< T *, float > getRelatedWithWeight (const std::string &name="", const std::string &namedRelation="") const
 Get first related object & weight of relation pointing from/to an array. More...
 
virtual std::string getName () const
 Return a short name that describes this object, e.g. More...
 
virtual std::string getInfoHTML () const
 Return a short summary of this object's contents in HTML format. More...
 
std::string getInfo () const
 Return a short summary of this object's contents in raw text format. More...
 
std::string getArrayName () const
 Get name of array this object is stored in, or "" if not found.
 
int getArrayIndex () const
 Returns this object's array index (in StoreArray), or -1 if not found.
 

Protected Member Functions

TClonesArray * getArrayPointer () const
 Returns the pointer to the raw DataStore array holding this object (protected since these arrays are easy to misuse).
 

Private Member Functions

double timeCFDCrossing (int sample, int value, double slope) const
 calculates time of 50% CFD crossing More...
 
double timeErrorCoefficient (double y1, double y2) const
 Calculate the coefficient of time error. More...
 
bool checkEdge (int v1, int v2, int vp) const
 Checks if values v1, v2 and vp are consistent.
 
 ClassDef (TOPRawDigit, 6)
 ClassDef.
 

Private Attributes

unsigned short m_scrodID = 0
 SCROD ID.
 
unsigned short m_carrier = 0
 carrier board number
 
unsigned short m_asic = 0
 ASIC number.
 
unsigned short m_channel = 0
 ASIC channel number.
 
unsigned short m_window = 0
 first ASIC storage window number
 
unsigned short m_TFine = 0
 fine timing for 50% CFD (within two samples)
 
unsigned short m_sampleRise = 0
 sample number just before 50% CFD crossing
 
unsigned short m_dSamplePeak = 0
 peak position relative to m_sampleRise
 
unsigned short m_dSampleFall = 0
 same for falling edge, rel. More...
 
short m_VRise0 = 0
 ADC value at m_sampleRise.
 
short m_VRise1 = 0
 ADC value at m_sampleRise + 1.
 
short m_VPeak = 0
 ADC value at m_sampleRise + m_dSamplePeak.
 
short m_VFall0 = 0
 ADC value at m_sampleRise + m_dSampleFall.
 
short m_VFall1 = 0
 ADC value at m_sampleRise + m_dSampleFall + 1.
 
int m_integral = 0
 integral of a pulse (proportional to charge)
 
unsigned short m_revo9Counter = 0
 number of clock ticks since last revo9 flag
 
unsigned short m_phase = 0
 carrier phase
 
unsigned short m_lookBackWindows = 0
 number of look-back windows
 
unsigned short m_errorFlags = 0
 feature extraction error flags (see enum)
 
unsigned short m_lastWriteAddr = 0
 current (reference) window number
 
std::vector< unsigned short > m_windows
 storage windows of waveform segments
 
bool m_offline = false
 feature extraction flag: by firmware or software
 
EDataTypes m_dataType = c_Undefined
 data type
 
DataStore::StoreEntrym_cacheDataStoreEntry
 Cache of the data store entry to which this object belongs.
 
int m_cacheArrayIndex
 Cache of the index in the TClonesArray to which this object belongs.
 

Detailed Description

Class to store unpacked raw data (hits in feature-extraction format) It provides also calculation of 50% CFD leading and falling edge times and errors.

Definition at line 24 of file TOPRawDigit.h.

Member Enumeration Documentation

◆ anonymous enum

anonymous enum

Various constants.

Enumerator
c_WindowSize 

number of samples per window

Definition at line 53 of file TOPRawDigit.h.

53  {
54  c_WindowSize = 64
55  };
@ c_WindowSize
number of samples per window
Definition: TOPRawDigit.h:54

◆ EDataTypes

enum EDataTypes

Enum for data types needed to steer time conversion in TOPRawDigitConverter.

Enumerator
c_Undefined 

undefined

c_MC 

from MC digitization

c_Interim 

from interim feature extraction

c_Production 

from the future production format

c_ProductionDebug 

from production debugging format

c_Other 

other

Definition at line 41 of file TOPRawDigit.h.

◆ ErrorFlags

enum ErrorFlags

Enum for error flags; bits set if corresponding data not consistent.

Enumerator
c_HeadMagic 

if magic number not 0xA

c_TailMagic 

if magic bits not '101' = 0x5

c_HitMagic 

if magic number not 0xB

c_HitChecksum 

if sum of 16-bit words not zero

Definition at line 30 of file TOPRawDigit.h.

Constructor & Destructor Documentation

◆ TOPRawDigit()

TOPRawDigit ( unsigned short  scrodID,
EDataTypes  dataType 
)
inline

Usefull constructor.

Parameters
scrodIDSCROD ID
dataTypedata type

Definition at line 68 of file TOPRawDigit.h.

Member Function Documentation

◆ addRelationTo() [1/2]

void addRelationTo ( const RelationsInterface< BASE > *  object,
float  weight = 1.0,
const std::string &  namedRelation = "" 
) const
inlineinherited

Add a relation from this object to another object (with caching).

Parameters
objectThe object to which the relation should point.
weightThe weight of the relation.
namedRelationAdditional name for the relation, or "" for the default naming

Definition at line 142 of file RelationsObject.h.

◆ addRelationTo() [2/2]

void addRelationTo ( const TObject *  object,
float  weight = 1.0,
const std::string &  namedRelation = "" 
) const
inlineinherited

Add a relation from this object to another object (no caching, can be quite slow).

Parameters
objectThe object to which the relation should point.
weightThe weight of the relation.
namedRelationAdditional name for the relation, or "" for the default naming

Definition at line 155 of file RelationsObject.h.

◆ copyRelations()

void copyRelations ( const RelationsInterface< BASE > *  sourceObj)
inlineinherited

Copies all relations of sourceObj (pointing from or to sourceObj) to this object (including weights).

Useful if you want to make a complete copy of a StoreArray object to make modifications to it, but retain all information on linked objects.

Note: this only works if sourceObj inherits from the same base (e.g. RelationsObject), and only for related objects that also inherit from the same base.

Definition at line 170 of file RelationsObject.h.

◆ getASICChannel()

unsigned getASICChannel ( ) const
inline

Returns ASIC channel number.

Returns
ASIC channel number

Definition at line 230 of file TOPRawDigit.h.

◆ getASICNumber()

unsigned getASICNumber ( ) const
inline

Returns ASIC number.

Returns
ASIC number

Definition at line 224 of file TOPRawDigit.h.

◆ getASICWindow()

unsigned getASICWindow ( ) const
inline

Returns ASIC storage window number.

Returns
window number

Definition at line 243 of file TOPRawDigit.h.

◆ getCarrierNumber()

unsigned getCarrierNumber ( ) const
inline

Returns carrier board number.

Returns
carrier board number

Definition at line 218 of file TOPRawDigit.h.

◆ getCFDFallingTime()

double getCFDFallingTime ( ) const
inline

Returns falling edge CFD time.

Returns
time [samples] (not in [ns]!)

Definition at line 378 of file TOPRawDigit.h.

◆ getCFDFallingTimeError()

double getCFDFallingTimeError ( double  rmsNoise) const
inline

Returns falling edge CFD time uncertainty (assuming uncorrelated noise)

Parameters
rmsNoiser.m.s of the pedestal fluctuations [ADC counts]
Returns
time uncertainty [samples] (not in [ns]!)

Definition at line 398 of file TOPRawDigit.h.

◆ getCFDLeadingTime()

double getCFDLeadingTime ( ) const
inline

Returns leading edge CFD time.

Returns
time [samples] (not in [ns]!)

Definition at line 369 of file TOPRawDigit.h.

◆ getCFDLeadingTimeError()

double getCFDLeadingTimeError ( double  rmsNoise) const
inline

Returns leading edge CFD time uncertainty (assuming uncorrelated noise)

Parameters
rmsNoiser.m.s of the pedestal fluctuations [ADC counts]
Returns
time uncertainty [samples] (not in [ns]!)

Definition at line 388 of file TOPRawDigit.h.

◆ getDataType()

EDataTypes getDataType ( ) const
inline

Returns data type.

Returns
data type

Definition at line 206 of file TOPRawDigit.h.

◆ getDeltaSampleFall()

unsigned getDeltaSampleFall ( ) const
inline

Returns sample number at falling edge just before 50% CFD relative to m_sampleRise.

Returns
sample number difference

Definition at line 285 of file TOPRawDigit.h.

◆ getDeltaSamplePeak()

unsigned getDeltaSamplePeak ( ) const
inline

Returns peak position relative to m_sampleRise.

Returns
sample number difference

Definition at line 273 of file TOPRawDigit.h.

◆ getErrorFlags()

unsigned short getErrorFlags ( ) const
inline

Returns error flags.

Returns
flags

Definition at line 351 of file TOPRawDigit.h.

◆ getFallingSlope()

double getFallingSlope ( ) const
inline

Returns falling edge slope.

Returns
slope [ADC counts per sample]

Definition at line 363 of file TOPRawDigit.h.

◆ getFWHM()

double getFWHM ( ) const
inline

Returns signal full width half maximum.

Returns
FWHM [samples] (not in [ns]!)

Definition at line 407 of file TOPRawDigit.h.

◆ getInfo()

std::string getInfo ( ) const
inlineinherited

Return a short summary of this object's contents in raw text format.

Returns the contents of getInfoHTML() while translating line-breaks etc.

Note
: You don't need to implement this function (it's not virtual), getInfoHTML() is enough.

Definition at line 370 of file RelationsObject.h.

◆ getInfoHTML()

virtual std::string getInfoHTML ( ) const
inlinevirtualinherited

Return a short summary of this object's contents in HTML format.

Reimplement this in your own class to provide useful output for display or debugging purposes. For example, you might do something like:

std::stringstream out;
out << "<b>PDG</b>: " << m_pdg << "<br>";
out << "<b>Covariance Matrix</b>: " << HTML::getString(getCovariance5()) << "<br>";
return out.str();
std::string getString(const TMatrixFBase &matrix, int precision=2, bool color=true)
get HTML table representing a matrix.
Definition: HTML.cc:24
See also
Particle::getInfoHTML() for a more complex example.
HTML for some utility functions.
Use getInfo() to get a raw text version of this output.

Reimplemented in RecoTrack, TRGSummary, TrackFitResult, Track, SoftwareTriggerResult, PIDLikelihood, MCParticle, Cluster, and Particle.

Definition at line 362 of file RelationsObject.h.

◆ getIntegral()

int getIntegral ( ) const
inline

Returns integral of a pulse (e.g.

a value proportional to charge)

Returns
integral

Definition at line 327 of file TOPRawDigit.h.

◆ getLastWriteAddr()

unsigned getLastWriteAddr ( ) const
inline

Returns current (reference) ASIC window number.

Returns
window number

Definition at line 255 of file TOPRawDigit.h.

◆ getLeadingSlope()

double getLeadingSlope ( ) const
inline

Returns leading edge slope.

Returns
slope [ADC counts per sample]

Definition at line 357 of file TOPRawDigit.h.

◆ getLookBackWindows()

unsigned short getLookBackWindows ( ) const
inline

Returns number of look-back windows.

Returns
number of look-back windows (0 means 'not available')

Definition at line 339 of file TOPRawDigit.h.

◆ getName()

virtual std::string getName ( ) const
inlinevirtualinherited

Return a short name that describes this object, e.g.

pi+ for an MCParticle.

Reimplemented in SpacePoint, MCParticle, and Particle.

Definition at line 344 of file RelationsObject.h.

◆ getPhase()

unsigned short getPhase ( ) const
inline

Returns beam orbit synchronisation phase (9-state count: valid values are 0 - 8)

Returns
phase

Definition at line 345 of file TOPRawDigit.h.

◆ getRelated()

T* getRelated ( const std::string &  name = "",
const std::string &  namedRelation = "" 
) const
inlineinherited

Get the object to or from which this object has a relation.

Template Parameters
TThe class of objects to or from which the relation points.
Parameters
nameThe name of the store array to or from which the relation points. If empty the default store array name for class T will be used. If the special name "ALL" is given all store arrays containing objects of type T are considered.
namedRelationAdditional name for the relation, or "" for the default naming
Returns
The first related object or a null pointer.

Definition at line 278 of file RelationsObject.h.

◆ getRelatedFrom()

FROM* getRelatedFrom ( const std::string &  name = "",
const std::string &  namedRelation = "" 
) const
inlineinherited

Get the object from which this object has a relation.

Template Parameters
FROMThe class of objects from which the relation points.
Parameters
nameThe name of the store array from which the relation points. If empty the default store array name for class FROM will be used. If the special name "ALL" is given all store arrays containing objects of type FROM are considered.
namedRelationAdditional name for the relation, or "" for the default naming
Returns
The first related object or a null pointer.

Definition at line 263 of file RelationsObject.h.

◆ getRelatedFromWithWeight()

std::pair<FROM*, float> getRelatedFromWithWeight ( const std::string &  name = "",
const std::string &  namedRelation = "" 
) const
inlineinherited

Get first related object & weight of relation pointing from an array.

Template Parameters
FROMThe class of objects from which the relation points.
Parameters
nameThe name of the store array from which the relation points. If empty the default store array name for class FROM will be used. If the special name "ALL" is given all store arrays containing objects of type FROM are considered.
namedRelationAdditional name for the relation, or "" for the default naming
Returns
Pair of first related object and the relation weight, or (NULL, 1.0) if none found.

Definition at line 314 of file RelationsObject.h.

◆ getRelatedTo()

TO* getRelatedTo ( const std::string &  name = "",
const std::string &  namedRelation = "" 
) const
inlineinherited

Get the object to which this object has a relation.

Template Parameters
TOThe class of objects to which the relation points.
Parameters
nameThe name of the store array to which the relation points. If empty the default store array name for class TO will be used. If the special name "ALL" is given all store arrays containing objects of type TO are considered.
namedRelationAdditional name for the relation, or "" for the default naming
Returns
The first related object or a null pointer.

Definition at line 248 of file RelationsObject.h.

◆ getRelatedToWithWeight()

std::pair<TO*, float> getRelatedToWithWeight ( const std::string &  name = "",
const std::string &  namedRelation = "" 
) const
inlineinherited

Get first related object & weight of relation pointing to an array.

Template Parameters
TOThe class of objects to which the relation points.
Parameters
nameThe name of the store array to which the relation points. If empty the default store array name for class TO will be used. If the special name "ALL" is given all store arrays containing objects of type TO are considered.
namedRelationAdditional name for the relation, or "" for the default naming
Returns
Pair of first related object and the relation weight, or (NULL, 1.0) if none found.

Definition at line 297 of file RelationsObject.h.

◆ getRelatedWithWeight()

std::pair<T*, float> getRelatedWithWeight ( const std::string &  name = "",
const std::string &  namedRelation = "" 
) const
inlineinherited

Get first related object & weight of relation pointing from/to an array.

Template Parameters
TThe class of objects to or from which the relation points.
Parameters
nameThe name of the store array to or from which the relation points. If empty the default store array name for class T will be used. If the special name "ALL" is given all store arrays containing objects of type T are considered.
namedRelationAdditional name for the relation, or "" for the default naming
Returns
Pair of first related object and the relation weight, or (NULL, 1.0) if none found.

Definition at line 331 of file RelationsObject.h.

◆ getRelationsFrom()

RelationVector<FROM> getRelationsFrom ( const std::string &  name = "",
const std::string &  namedRelation = "" 
) const
inlineinherited

Get the relations that point from another store array to this object.

Template Parameters
FROMThe class of objects from which the relations point.
Parameters
nameThe name of the store array from which the relations point. If empty the default store array name for class FROM will be used. If the special name "ALL" is given all store arrays containing objects of type FROM are considered.
namedRelationAdditional name for the relation, or "" for the default naming
Returns
A vector of relations.

Definition at line 212 of file RelationsObject.h.

◆ getRelationsTo()

RelationVector<TO> getRelationsTo ( const std::string &  name = "",
const std::string &  namedRelation = "" 
) const
inlineinherited

Get the relations that point from this object to another store array.

Template Parameters
TOThe class of objects to which the relations point.
Parameters
nameThe name of the store array to which the relations point. If empty the default store array name for class TO will be used. If the special name "ALL" is given all store arrays containing objects of type TO are considered.
namedRelationAdditional name for the relation, or "" for the default naming
Returns
A vector of relations.

Definition at line 197 of file RelationsObject.h.

◆ getRelationsWith()

RelationVector<T> getRelationsWith ( const std::string &  name = "",
const std::string &  namedRelation = "" 
) const
inlineinherited

Get the relations between this object and another store array.

Relations in both directions are returned.

Template Parameters
TThe class of objects to or from which the relations point.
Parameters
nameThe name of the store array to or from which the relations point. If empty the default store array name for class T will be used. If the special name "ALL" is given all store arrays containing objects of type T are considered.
namedRelationAdditional name for the relation, or "" for the default naming
Returns
A vector of relations.

Definition at line 230 of file RelationsObject.h.

◆ getRevo9Counter()

unsigned short getRevo9Counter ( ) const
inline

Returns 127 MHz clock ticks since last revo9 marker.

Returns
revo9counter

Definition at line 333 of file TOPRawDigit.h.

◆ getSampleFall()

unsigned getSampleFall ( ) const
inline

Returns sample number at falling edge just before 50% CFD crossing.

Returns
sample number

Definition at line 291 of file TOPRawDigit.h.

◆ getSamplePeak()

unsigned getSamplePeak ( ) const
inline

Returns peak position.

Returns
sample number

Definition at line 279 of file TOPRawDigit.h.

◆ getSampleRise()

unsigned getSampleRise ( ) const
inline

Returns sample number at leading edge just before 50% CFD crossing.

Returns
sample number

Definition at line 267 of file TOPRawDigit.h.

◆ getScrodChannel()

unsigned getScrodChannel ( ) const
inline

Returns channel number within SCROD (in the range 0 - 127)

Returns
SCROD channel number

Definition at line 237 of file TOPRawDigit.h.

◆ getScrodID()

unsigned getScrodID ( ) const
inline

Returns SCROD ID.

Returns
SCROD ID

Definition at line 212 of file TOPRawDigit.h.

◆ getStorageWindows()

const std::vector<unsigned short>& getStorageWindows ( ) const
inline

Returns storage window numbers of waveform segments (not always available!)

Returns
window numbers

Definition at line 249 of file TOPRawDigit.h.

◆ getTFine()

unsigned getTFine ( ) const
inline

Returns fine timing for 50% CFD (within two samples)

Returns
fine timing

Definition at line 261 of file TOPRawDigit.h.

◆ getValueFall0()

int getValueFall0 ( ) const
inline

Returns ADC value at falling edge (at m_sampleRise + m_dSampleFall)

Returns
ADC value

Definition at line 315 of file TOPRawDigit.h.

◆ getValueFall1()

int getValueFall1 ( ) const
inline

Returns ADC value at falling edge (at m_sampleRise + m_dSampleFall + 1)

Returns
ADC value

Definition at line 321 of file TOPRawDigit.h.

◆ getValuePeak()

int getValuePeak ( ) const
inline

Returns ADC value at peak (e.g.

pulse height)

Returns
ADC value

Definition at line 309 of file TOPRawDigit.h.

◆ getValueRise0()

int getValueRise0 ( ) const
inline

Returns ADC value at leading edge (at m_sampleRise)

Returns
ADC value

Definition at line 297 of file TOPRawDigit.h.

◆ getValueRise1()

int getValueRise1 ( ) const
inline

Returns ADC value at leading edge (at m_sampleRise + 1)

Returns
ADC value

Definition at line 303 of file TOPRawDigit.h.

◆ isFallingEdgeValid()

bool isFallingEdgeValid ( ) const
inline

Checks if falling edge is consistently defined.

Returns
true if consistent

Definition at line 419 of file TOPRawDigit.h.

◆ isFEValid()

bool isFEValid ( ) const
inline

Checks if feature extraction points make sense.

Returns
true if consistent

Definition at line 425 of file TOPRawDigit.h.

◆ isLeadingEdgeValid()

bool isLeadingEdgeValid ( ) const
inline

Checks if leading edge is consistently defined.

Returns
true if consistent

Definition at line 413 of file TOPRawDigit.h.

◆ isMadeOffline()

bool isMadeOffline ( ) const
inline

Returns offline flag.

Returns
true, if digit was extracted from waveform offline (in basf2)

Definition at line 477 of file TOPRawDigit.h.

◆ isWindowConsistent()

bool isWindowConsistent ( ) const
inline

Checks if the first window number is the same as the first one in m_windows Note: returns true if m_windows is empty.

Returns
true, if window numbers are the same or m_windows is empty

Definition at line 467 of file TOPRawDigit.h.

◆ setASICChannel()

void setASICChannel ( unsigned short  channel)
inline

Sets ASIC channel number.

Parameters
channelnumber

Definition at line 88 of file TOPRawDigit.h.

◆ setASICNumber()

void setASICNumber ( unsigned short  asic)
inline

Sets ASIC number.

Parameters
asicnumber

Definition at line 82 of file TOPRawDigit.h.

◆ setASICWindow()

void setASICWindow ( unsigned short  window)
inline

Sets first storage window number (logical window number)

Parameters
windownumber

Definition at line 94 of file TOPRawDigit.h.

◆ setCarrierNumber()

void setCarrierNumber ( unsigned short  carrier)
inline

Sets carrier board number.

Parameters
carriernumber

Definition at line 76 of file TOPRawDigit.h.

◆ setDeltaSampleFall()

void setDeltaSampleFall ( unsigned short  dsample)
inline

Sets falling edge sample number just before 50% CFD crossing relative to m_sampleRise.

Parameters
dsamplesample difference

Definition at line 134 of file TOPRawDigit.h.

◆ setDeltaSamplePeak()

void setDeltaSamplePeak ( unsigned short  dsample)
inline

Sets peak position relative to m_sampleRise.

Parameters
dsamplesample difference

Definition at line 127 of file TOPRawDigit.h.

◆ setErrorFlags()

void setErrorFlags ( unsigned short  flags)
inline

Sets error flags.

Parameters
flagserror flags

Definition at line 195 of file TOPRawDigit.h.

◆ setIntegral()

void setIntegral ( int  integral)
inline

Sets integral of a pulse (e.g.

a value proportional to charge)

Parameters
integral

Definition at line 170 of file TOPRawDigit.h.

◆ setLastWriteAddr()

void setLastWriteAddr ( unsigned short  window)
inline

Sets current (reference) window number.

Parameters
windownumber

Definition at line 109 of file TOPRawDigit.h.

◆ setLookBackWindows()

void setLookBackWindows ( unsigned short  lookBack)
inline

Sets number of look-back windows.

Parameters
lookBacknumber of look-back windows

Definition at line 189 of file TOPRawDigit.h.

◆ setPhase()

void setPhase ( unsigned short  phase)
inline

Sets beam orbit synchronisation phase (production firmware only) 9-state count: valid values are 0 - 8.

Parameters
phasebeam orbit sunchronisation phase

Definition at line 183 of file TOPRawDigit.h.

◆ setRevo9Counter()

void setRevo9Counter ( unsigned short  revo9Counter)
inline

Sets number of global clock tics since last revo9 flag (production firmware only)

Parameters
revo9Countercounter state

Definition at line 176 of file TOPRawDigit.h.

◆ setSampleRise()

void setSampleRise ( unsigned short  sample)
inline

Sets sample number just before 50% CFD crossing at leading edge.

Parameters
samplenumber

Definition at line 121 of file TOPRawDigit.h.

◆ setStorageWindows()

void setStorageWindows ( const std::vector< unsigned short > &  windows)
inline

Sets storage windows of waveform segments.

Parameters
windowswindow numbers

Definition at line 100 of file TOPRawDigit.h.

◆ setTFine()

void setTFine ( unsigned short  tfine)
inline

Sets fine timing for 50% CFD at rising edge (within two samples)

Parameters
tfinefine timing

Definition at line 115 of file TOPRawDigit.h.

◆ setValueFall0()

void setValueFall0 ( short  adc)
inline

Sets ADC value at m_sampleRise + m_dSampleFall.

Parameters
adcvalue

Definition at line 158 of file TOPRawDigit.h.

◆ setValueFall1()

void setValueFall1 ( short  adc)
inline

Sets ADC value at m_sampleRise + m_dSampleFall + 1.

Parameters
adcvalue

Definition at line 164 of file TOPRawDigit.h.

◆ setValuePeak()

void setValuePeak ( short  adc)
inline

Sets ADC value at m_sampleRise + m_dSamplePeak (e.g.

pulse height)

Parameters
adcvalue

Definition at line 152 of file TOPRawDigit.h.

◆ setValueRise0()

void setValueRise0 ( short  adc)
inline

Sets ADC value at m_sampleRise.

Parameters
adcvalue

Definition at line 140 of file TOPRawDigit.h.

◆ setValueRise1()

void setValueRise1 ( short  adc)
inline

Sets ADC value at m_sampleRise + 1.

Parameters
adcvalue

Definition at line 146 of file TOPRawDigit.h.

◆ timeCFDCrossing()

double timeCFDCrossing ( int  sample,
int  value,
double  slope 
) const
inlineprivate

calculates time of 50% CFD crossing

Parameters
samplesample number
valueADC value at sample number
slopeslope of a line
Returns
time [samples]

Definition at line 488 of file TOPRawDigit.h.

Member Data Documentation

◆ m_dSampleFall

unsigned short m_dSampleFall = 0
private

same for falling edge, rel.

to m_sampleRise

Definition at line 519 of file TOPRawDigit.h.


The documentation for this class was generated from the following files: