forked from xweizhi/SoLIDTracking
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSoLIDSpectrometer.h
executable file
·111 lines (94 loc) · 3.8 KB
/
SoLIDSpectrometer.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
100
101
102
103
104
105
106
107
108
109
110
#ifndef ROOT_SoLID_Spectrometer
#define ROOT_SoLID_Spectrometer
//////////////////////////////////////////////////////////////////////////
//
// SoLID::SoLIDSpectrometer
//
// SoLID spectrometer class containing GEM trackers
// Used for testing.
//
//////////////////////////////////////////////////////////////////////////
//c++
#include <vector>
//root
#include "TVector2.h"
//Hall A analyzer
#include "THaSpectrometer.h"
//SoLIDTracking
#include "SoLIDTrackerSystem.h"
#ifndef KBIG
#define KBIG 1e38
#endif
class SoLIDTrackerSystem;
// Helper class for holding additional track data not in THaTrack
class SolTrackInfo : public TObject {
public:
SolTrackInfo()
: fSector(-1), fRtransv(KBIG), fTheta(KBIG), fPhi(KBIG),
fPhiRot(KBIG), fThetaDir(KBIG), fPhiDir(KBIG), fPhiDirRot(KBIG)
#ifdef MCDATA
, fMCHitBits(0), fNMCHits(0)
#endif
{}
SolTrackInfo( Int_t sector, const TVector3& point,
const TVector3& direction, Double_t phi0 )
: TObject(), fSector(sector), fRtransv(point.Perp()),
fTheta(point.Theta()), fPhi(point.Phi()),
fPhiRot(TVector2::Phi_mpi_pi(fPhi-phi0)),
fThetaDir(direction.Theta()), fPhiDir(direction.Phi()),
fPhiDirRot(TVector2::Phi_mpi_pi(fPhiDir-phi0))
#ifdef MCDATA
, fMCHitBits(0), fNMCHits(0)
#endif
{}
#ifdef MCDATA
Int_t GetMCHitBits() const { return fMCHitBits; }
Int_t GetNMCHits() const { return fNMCHits; }
void SetMCHitBits( Int_t bits ) { fMCHitBits = bits; }
void SetNMCHits( Int_t nhits ) { fNMCHits = nhits; }
#endif
protected:
// Track coordinates in the cylindrical system SoLID uses.
// Aziumthal angles are measured wrt to the x-axis, which is the centerline
// of sector 0. Positive angles mean clockwise rotation when looking
// downstream along the beam.
Int_t fSector; // Sector where this track was reconstructed
Double_t fRtransv; // Transverse distance of track point from beam [m]
Double_t fTheta; // Polar angle of track point wrt target center [rad]
Double_t fPhi; // Azimuth of track point [rad]
Double_t fPhiRot; // Azimuth of track point wrt to sector center [rad]
Double_t fThetaDir; // Polar angle of track direction [rad]
Double_t fPhiDir; // Azimuth of track direction [rad]
Double_t fPhiDirRot; // Azimuth of track dir wrt to sector center [rad]
#ifdef MCDATA
// Diagnostic info derived from Monte Carlo truth data
Int_t fMCHitBits; // Bitpattern of plane #s w/MC hit used by this track
Int_t fNMCHits; // Number of MC hits in this track (# bits set in fMCHitBits)
#endif
ClassDef(SolTrackInfo,0) // SoLID track coordinates
};
class SoLIDSpectrometer : public THaSpectrometer {
public:
SoLIDSpectrometer( const char* name, const char* description, UInt_t nsystem = 1,
UInt_t ntracker = 6 , UInt_t nsector = 30, UInt_t nreadout = 2);
virtual ~SoLIDSpectrometer();
virtual void Clear( Option_t* opt="" );
virtual EStatus Init( const TDatime& run_time );
virtual Int_t FindVertices( TClonesArray& tracks );
virtual Int_t TrackCalc();
virtual void PrintDataBase(Int_t level) const;
Bool_t IsSetup() const { return fIsSetup; }
TClonesArray* GetTrackInfo() { return fSolTrackInfo; }
protected:
TClonesArray* fSolTrackInfo; // SoLID-specific per-track info
virtual Int_t DefineVariables( EMode mode = kDefine );
virtual Int_t ReadRunDatabase( const TDatime& date );
Int_t fNSystem;
Int_t fNTracker;
Int_t fNSector;
Int_t fNReadOut;
//SoLIDTrackerSystem **fTrackerSystem;
std::vector<SoLIDTrackerSystem*> fTrackerSystem;
ClassDef(SoLIDSpectrometer,0) // SoLID spectrometer
};
#endif