-
Notifications
You must be signed in to change notification settings - Fork 43
/
Copy pathSBSElement.h
99 lines (80 loc) · 3.89 KB
/
SBSElement.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
#ifndef ROOT_SBSElement
#define ROOT_SBSElement
////////////////////////////////////////////////////////////////////////////
// //
// SBSElement //
// //
////////////////////////////////////////////////////////////////////////////
#include <TObject.h>
#include "SBSData.h"
///////////////////////////////////////////////////////////////////////////////
class SBSElement : public TObject {
public:
SBSElement() : fADC(nullptr), fTDC(nullptr), fWaveform(nullptr) {};
SBSElement(Double_t x, Double_t y, Double_t z,
Int_t row, Int_t col, Int_t layer, Int_t id = 0);
virtual ~SBSElement();
// Getters
Double_t GetX() const { return fX; }
Double_t GetY() const { return fY; }
Double_t GetZ() const { return fZ; }
Double_t GetE() const { return fE; }
Double_t GetAgain() const { return fAgain; }
Double_t GetAtime() const { return fAtime; }
Double_t GetTDCtime() const { return fTDCtime; }
Int_t GetRow() const { return fRow; }
Int_t GetCol() const { return fCol; }
Int_t GetLayer() const { return fLayer; }
Int_t GetStat() const { return fStat; }
Int_t GetID() const { return fID; }
Bool_t IsRFtime() const { return fIsRFtime; }
Bool_t IsTrigTime() const { return fIsTrigTime; }
virtual SBSData::ADC* ADC() { return fADC; }
virtual SBSData::TDC* TDC() { return fTDC; }
virtual SBSData::Waveform* Waveform() { return fWaveform; }
// Setters
void SetX(Double_t var) { fX = var; }
void SetY(Double_t var) { fY = var; }
void SetZ(Double_t var) { fZ = var; }
void SetE(Double_t var) { fE = var; }
void SetAgain(Double_t var) { fAgain = var; }
void SetAtime(Double_t var) { fAtime = var; }
void SetTDCtime(Double_t var) { fTDCtime = var; }
void SetRow(Int_t var) { fRow = var; }
void SetCol(Int_t var) { fCol = var; }
void SetLayer(Int_t var) { fLayer = var; }
void SetStat(Int_t var) { fStat = var; }
void SetID(Int_t var) { fID = var; }
void SetADC(Double_t ped, Double_t gain);
void SetTDC(Double_t offset, Double_t cal, Double_t GoodTimeCut);
void SetWaveform(Double_t ped, Double_t gain,Double_t ChanToMv,Double_t adc_timecut);
void SetRF( Bool_t isrf ){ fIsRFtime = isrf; }
void SetTrig( Bool_t istrig ){ fIsTrigTime = istrig; }
// Sub-classes may want a more comprehensive clear
virtual void Clear( Option_t* opt="" );
// Check if this block has any data
virtual Bool_t HasData();
virtual Bool_t HasADCData();
virtual Bool_t HasTDCData();
protected:
//Since the RF time and trigger time are usually stored in one of these "RefElements",
Bool_t fIsRFtime; //flag indicating that this element contains the RF time for this detector (assumed to be a TDC channel)
Bool_t fIsTrigTime; //flag indicating that this element contains the Trigger time for this detector (assumed to be a TDC channel);
Double_t fX; ///< relative x position of the center
Double_t fY; ///< relative y position of the center
Double_t fZ; ///< relative z position of the center
Double_t fE; ///< calibrated energy of event in this block
Double_t fAgain; ///< ADC gain coefficient (GeV/pC)
Double_t fAtime; ///< ADC time of event in this block
Double_t fTDCtime; ///< TDC time of event in this block
Int_t fRow; ///< Row of the block
Int_t fCol; ///< Column of the block
Int_t fLayer; ///< Layer of the block
Int_t fStat; ///< Status: 0: not seen, 1: seen, 2: local max
Int_t fID; ///< a logical number to this element
SBSData::ADC *fADC; //< All ADC hits
SBSData::TDC *fTDC; //< All TDC hits
SBSData::Waveform *fWaveform;
ClassDef(SBSElement,1) ///< Generic shower block class (no data)
};
#endif