Class Reference for E1039 Core & Analysis Software
KalmanFastTracking.h
Go to the documentation of this file.
1 /*
2 KalmanFastTracking.h
3 
4 Fast tracking utility of Kalman filter track, used to improve the tracking speed and also for online monitoring
5 
6 Author: Kun Liu, liuk@fnal.gov
7 Created: 05-24-2013
8 */
9 
10 #ifndef _KALMANFASTTRACKING_H
11 #define _KALMANFASTTRACKING_H
12 
13 #include <GlobalConsts.h>
14 #include <geom_svc/GeomSvc.h>
15 
16 #include <list>
17 #include <vector>
18 #include <map>
19 
20 #include <Math/Factory.h>
21 #include <Math/Minimizer.h>
22 #include <Math/Functor.h>
23 
24 #include "SRawEvent.h"
25 #include "KalmanTrack.h"
26 #include "KalmanFitter.h"
27 #include "FastTracklet.h"
28 #include "SQTrackletFitter.h"
29 
30 class TGeoManager;
31 
32 class PHField;
33 class PHTimer;
34 
36 {
37 public:
38  explicit KalmanFastTracking(const PHField* field, const TGeoManager *geom, bool flag = true, const int verb=0);
39  virtual ~KalmanFastTracking();
40 
41  //set/get verbosity
42  void Verbosity(const int a) {verbosity = a;}
43  int Verbosity() const {return verbosity;}
44  void printTimers();
45 
46  //Set the input event
47  virtual int setRawEvent(SRawEvent* event_input);
48  void setRawEventDebug(SRawEvent* event_input);
49 
50  //Event quality cut
52 
54  //Build tracklets in a station
55  virtual void buildTrackletsInStation(int stationID, int listID, double* pos_exp = nullptr, double* window = nullptr);
56 
57  //Build back partial tracks using tracklets in station 2 & 3
58  virtual void buildBackPartialTracks();
59 
60  //Build global tracks by connecting station 23 tracklets and station 1 tracklets
61  virtual void buildGlobalTracks();
62 
63  //Fit tracklets
64  int fitTracklet(Tracklet& tracklet);
65 
66  //Check the quality of tracklet, number of hits
67  bool acceptTracklet(Tracklet& tracklet);
68  bool hodoMask(Tracklet& tracklet);
69  bool muonID_comp(Tracklet& tracklet);
70  bool muonID_search(Tracklet& tracklet);
71  bool muonID_hodoAid(Tracklet& tracklet);
72 
73  void buildPropSegments();
74 
75  //Resolve left-right when possible
76  void resolveLeftRight(SRawEvent::hit_pair hpair, int& LR1, int& LR2);
77  void resolveLeftRight(Tracklet& tracklet, double threshold);
78  void resolveSingleLeftRight(Tracklet& tracklet);
79 
80  //Remove bad hit if needed
81  void removeBadHits(Tracklet& tracklet);
82 
83  //Reduce the list of tracklets, returns the number of elements reduced
84  int reduceTrackletList(std::list<Tracklet>& tracklets);
85 
86  //Get exp postion and window using sagitta method in station 1
87  void getSagittaWindowsInSt1(Tracklet& tracklet, double* pos_exp, double* window, int st1ID);
88  void getExtrapoWindowsInSt1(Tracklet& tracklet, double* pos_exp, double* window, int st1ID);
89 
90  //Print the distribution of tracklets at detector back/front
91  void printAtDetectorBack(int stationID, std::string outputFileName);
92 
94  //Convert Tracklet to KalmanTrack and solve left-right problem, and eventually to a SRecTrack
96 
97  //Use Kalman fitter to fit a track
98  bool fitTrack(KalmanTrack& kmtrk);
99 
100  //Resolve left right by Kalman fitting results
101  void resolveLeftRight(KalmanTrack& kmtrk);
102 
104  std::list<Tracklet>& getFinalTracklets() { return trackletsInSt[outputListIdx]; }
105  std::list<Tracklet>& getBackPartials() { return trackletsInSt[3]; }
106  std::list<Tracklet>& getTrackletList(int i) { return trackletsInSt[i]; }
107  std::list<SRecTrack>& getSRecTracks() { return stracks; }
108  std::list<PropSegment>& getPropSegments(int i) { return propSegs[i]; }
109 
111 
115  void setOutputListIndex(unsigned int i) { outputListIdx = i; }
116 
118  void chi2fit(int n, double x[], double y[], double& a, double& b);
119 
120 protected:
121  //verbosity following Fun4All convention
123 
124  //Raw event input
126  std::vector<Hit> hitAll;
127 
128  //Tracklets in one event, id = 0, 1, 2 for station 0/1, 2, 3+/-, id = 3 for station 2&3 combined, id = 4 for global tracks
129  //Likewise for the next part
130  std::list<Tracklet> trackletsInSt[5];
131 
132  //Final SRecTrack list
133  std::list<SRecTrack> stracks;
134 
135  //Index of the trackletlist designated as output
136  unsigned int outputListIdx;
137 
138  //Prop. tube segments for muon id purposes
139  // 0 for X-Z, 1 for Y-Z
140  std::list<PropSegment> propSegs[2];
141 
143  //Hodo. IDs for masking, 4 means we have 4 hodo stations
144  std::vector<int> detectorIDs_mask[4];
145  std::vector<int> detectorIDs_maskX[4];
146  std::vector<int> detectorIDs_maskY[4];
147  std::list<int> hitIDs_mask[4]; //hits in T/B, L/R are combined
148  std::vector<int> detectorIDs_muidHodoAid[2]; //Aux-hodoscope masking for muon ID
149 
150  //register difference hodo masking stations for different chamber detectors
151  std::vector<int> stationIDs_mask[nStations];
152 
153  //prop. tube IDs for MUID -- 0 for x-z, 1 for y-z
154  int detectorIDs_muid[2][4];
155  double z_ref_muid[2][4];
156  std::list<int> hitIDs_muid[2][4];
157  std::list<int> hitIDs_muidHodoAid[2];
158 
159  //Masking window sizes, index is the uniqueID defined by nElement*detectorID + elementID
165 
167  //Super plane IDs for DCs
168  std::vector<int> superIDs[nChamberPlanes/6+2];
169 
170  //Window sizes for X-U combination
177 
178  //Plane angles for all planes
181 
182  //Z positions
184 
185  //Maximum slope and intersection in each view
188 
189  //Resolutions of all planes
191 
192  //Cell width of all planes
194 
195  //Sagitta ratio in station 1, index 0, 1, 2 are for X/U/V
196  int s_detectorID[3];
197 
198  //Simple tracklet fitter
200 
201  //Kalman fitter
203 
204  //Geometry service
206 
207  //Flag for enable Kalman fitting
208  const bool enable_KF;
209 
210  //Timer
211  std::map<std::string, PHTimer*> _timers;
212 
213  int setRawEventPrep(SRawEvent* event_input);
214 };
215 
216 #endif
#define nPropPlanes
Definition: GlobalConsts.h:8
#define nChamberPlanes
Definition: GlobalConsts.h:6
#define nHodoPlanes
Definition: GlobalConsts.h:7
#define nStations
Definition: GlobalConsts.h:5
User interface class about the geometry of detector planes.
Definition: GeomSvc.h:164
bool acceptEvent(SRawEvent *rawEvent)
std::list< SRecTrack > & getSRecTracks()
std::list< Tracklet > trackletsInSt[5]
void setRawEventDebug(SRawEvent *event_input)
std::vector< int > detectorIDs_maskY[4]
double costheta_plane[nChamberPlanes+1]
unsigned int outputListIdx
double u_sintheta[nChamberPlanes/6]
double u_costheta[nChamberPlanes/6]
double z_mask[nHodoPlanes+nPropPlanes]
std::list< SRecTrack > stracks
void removeBadHits(Tracklet &tracklet)
std::vector< int > stationIDs_mask[nStations]
bool hodoMask(Tracklet &tracklet)
std::vector< int > superIDs[nChamberPlanes/6+2]
For following part, id = 0, 1, 2, 3, 4, 5, 6 stand for station 0, 1, 2, 3+, 3-, and prop tubes X-Z an...
double z_plane[nChamberPlanes+1]
int setRawEventPrep(SRawEvent *event_input)
void getExtrapoWindowsInSt1(Tracklet &tracklet, double *pos_exp, double *window, int st1ID)
void setOutputListIndex(unsigned int i)
Set the index of the final output tracklet list.
void resolveLeftRight(SRawEvent::hit_pair hpair, int &LR1, int &LR2)
bool acceptTracklet(Tracklet &tracklet)
std::list< Tracklet > & getTrackletList(int i)
double intersection_max[nChamberPlanes+1]
void chi2fit(int n, double x[], double y[], double &a, double &b)
Tool, a simple-minded chi square fit.
virtual void buildTrackletsInStation(int stationID, int listID, double *pos_exp=nullptr, double *window=nullptr)
Tracklet finding stuff.
int fitTracklet(Tracklet &tracklet)
virtual void buildGlobalTracks()
virtual void buildBackPartialTracks()
KalmanFastTracking(const PHField *field, const TGeoManager *geom, bool flag=true, const int verb=0)
double slope_max[nChamberPlanes+1]
std::list< Tracklet > & getFinalTracklets()
Final output.
void Verbosity(const int a)
int reduceTrackletList(std::list< Tracklet > &tracklets)
std::list< PropSegment > & getPropSegments(int i)
bool muonID_comp(Tracklet &tracklet)
double spacing_plane[nChamberPlanes+1]
KalmanFitter * kmfitter
void getSagittaWindowsInSt1(Tracklet &tracklet, double *pos_exp, double *window, int st1ID)
std::vector< int > detectorIDs_mask[4]
Configurations of tracklet finding.
double resol_plane[nChamberPlanes+1]
std::vector< int > detectorIDs_muidHodoAid[2]
std::list< int > hitIDs_mask[4]
std::vector< Hit > hitAll
double z_plane_x[nChamberPlanes/6]
bool muonID_hodoAid(Tracklet &tracklet)
double z_plane_u[nChamberPlanes/6]
SRecTrack processOneTracklet(Tracklet &tracklet)
Track fitting stuff.
void resolveSingleLeftRight(Tracklet &tracklet)
std::vector< int > detectorIDs_maskX[4]
std::map< std::string, PHTimer * > _timers
double y_mask_max[nHodoPlanes+nPropPlanes][72]
double x_mask_min[nHodoPlanes+nPropPlanes][72]
void printAtDetectorBack(int stationID, std::string outputFileName)
virtual int setRawEvent(SRawEvent *event_input)
bool fitTrack(KalmanTrack &kmtrk)
double x_mask_max[nHodoPlanes+nPropPlanes][72]
double u_win[nChamberPlanes/6]
bool muonID_search(Tracklet &tracklet)
std::list< PropSegment > propSegs[2]
std::list< int > hitIDs_muidHodoAid[2]
double y_mask_min[nHodoPlanes+nPropPlanes][72]
std::list< int > hitIDs_muid[2][4]
std::list< Tracklet > & getBackPartials()
double sintheta_plane[nChamberPlanes+1]
SQTrackletFitter * trackletFitter
double z_plane_v[nChamberPlanes/6]
transient DST object for field storage and access
Definition: PHField.h:14
high precision timer
Definition: PHTimer.h:25
std::pair< Int_t, Int_t > hit_pair
Type of pair with two adjacent wires.
Definition: SRawEvent.h:169