CGEM BOSS 6.6.5.f
BESIII Offline Software System
Loading...
Searching...
No Matches
Mdc/MdcRecEvent/MdcRecEvent-00-06-04/MdcRecEvent/RecMdcKalTrack.h
Go to the documentation of this file.
1/*
2 * @class : RecMdcKalTrack
3 *
4 * this class models "Kalman Track" used in Mdc Reconstruction
5 *
6 * by wangjk 2006.9
7 *
8 * ********************************************************/
9
10#ifndef RECMDCKALTRACK_H
11#define RECMDCKALTRACK_H
12#include "GaudiKernel/ContainedObject.h"
13#include "GaudiKernel/SmartRef.h"
14#include "GaudiKernel/SmartRefVector.h"
15#include "GaudiKernel/ObjectVector.h"
16#include "EventModel/EventModel.h"
17#include "DstEvent/DstMdcKalTrack.h"
18#include "CLHEP/Matrix/Vector.h"
19#include "CLHEP/Matrix/SymMatrix.h"
20#include "CLHEP/Vector/ThreeVector.h"
21#include "CLHEP/Geometry/Point3D.h"
22#include "RecMdcKalHelixSeg.h"
23
24
25extern const CLID& CLID_RecMdcKalTrack;
26
27typedef SmartRefVector<RecMdcKalHelixSeg> HelixSegRefVec;
28
29
30class RecMdcKalTrack : public DstMdcKalTrack {
31
32 public:
33 virtual const CLID& clID() const {
35 }
36
37 static const CLID& classID() {
39 }
40 //constructor and destructor
47
48 //extractors
49 HelixSegRefVec getVecHelixSegs(int pid=-1) const;//2011-05-06
50
51 int getTrackId( void ) const { return m_trackId; }
52 double getMass( int pid ) const { return m_mass[pid]; }
53 double getLength( int pid ) const { return m_length[pid]; }
54 double getTof( int pid ) const { return m_tof[pid]; }
55 int getNhits( int pid ) const { return m_nhits[pid]; }
56 int getStat( int i, int pid ) const { return m_stat[i][pid]; }
57 int getNster(const int i, const int pid) const { return m_nster[i][pid]; }
58 int getFirstLayer(const int i, const int pid) const { return m_firstLayer[i][pid]; }
59 int getLastLayer(const int i, const int pid) const { return m_lastLayer[i][pid]; }
60 double getChisq( int i, int pid ) const { return m_chisq[i][pid]; }
61 int getNdf( int i, int pid ) const { return m_ndf[i][pid]; }
62 double getPathl( int i ) const { return m_pathl[i]; }
63 double getPathSM( int pid) const { return m_pathSM[pid]; }
64
65
66 const HepVector& getZHelix() const { return m_zhelixs[2]; }
67 const HepSymMatrix& getZError() const { return m_zerrors[2]; }
68 const HepVector& getFHelix() const { return m_fhelixs[2]; }
69 const HepSymMatrix& getFError() const { return m_ferrors[2]; }
70 const HepVector& getLHelix() const { return m_lhelixs[2]; }
71 const HepSymMatrix& getLError() const { return m_lerrors[2]; }
72 const double getTHelix(const int i) const { return m_thelix[i]; }
73 const double getTError(const int i) const { return m_terror[i]; }
74 const HepVector getTHelix() const { return m_ta; }
75 const HepSymMatrix getTError() const { return m_tEa; }
76
77 HepVector& getZHelixE() { return m_zhelixs[0]; }
78 HepSymMatrix& getZErrorE() { return m_zerrors[0]; }
79 HepVector& getFHelixE() { return m_fhelixs[0]; }
80 HepSymMatrix& getFErrorE() { return m_ferrors[0]; }
81 HepVector& getLHelixE() { return m_lhelixs[0]; }
82 HepSymMatrix& getLErrorE() { return m_lerrors[0]; }
83
84 HepVector& getZHelixMu() { return m_zhelixs[1]; }
85 HepSymMatrix& getZErrorMu() { return m_zerrors[1]; }
86 HepVector& getFHelixMu() { return m_fhelixs[1]; }
87 HepSymMatrix& getFErrorMu() { return m_ferrors[1]; }
88 HepVector& getLHelixMu() { return m_lhelixs[1]; }
89 HepSymMatrix& getLErrorMu() { return m_lerrors[1]; }
90
91 HepVector& getZHelixK() { return m_zhelixs[3]; }
92 HepSymMatrix& getZErrorK() { return m_zerrors[3]; }
93 HepVector& getFHelixK() { return m_fhelixs[3]; }
94 HepSymMatrix& getFErrorK() { return m_ferrors[3]; }
95 HepVector& getLHelixK() { return m_lhelixs[3]; }
96 HepSymMatrix& getLErrorK() { return m_lerrors[3]; }
97
98 HepVector& getZHelixP() { return m_zhelixs[4]; }
99 HepSymMatrix& getZErrorP() { return m_zerrors[4]; }
100 HepVector& getFHelixP() { return m_fhelixs[4]; }
101 HepSymMatrix& getFErrorP() { return m_ferrors[4]; }
102 HepVector& getLHelixP() { return m_lhelixs[4]; }
103 HepSymMatrix& getLErrorP() { return m_lerrors[4]; }
104
105 const HepPoint3D getPocaE() const { return m_pocas[0]; }
106 const HepPoint3D getPocaMu() const { return m_pocas[1]; }
107 const HepPoint3D getPoca() const { return m_pocas[2]; }
108 const HepPoint3D getPocaK() const { return m_pocas[3]; }
109 const HepPoint3D getPocaP() const { return m_pocas[4]; }
110
111 const HepPoint3D& getLPointE() const { return m_lpoints[0]; }
112 const HepPoint3D& getLPointMu() const { return m_lpoints[1]; }
113 const HepPoint3D& getLPoint() const { return m_lpoints[2]; }
114 const HepPoint3D& getLPointK() const { return m_lpoints[3]; }
115 const HepPoint3D& getLPointP() const { return m_lpoints[4]; }
116
117 const HepPoint3D& getLPivotE() const { return m_lpivots[0]; }
118 const HepPoint3D& getLPivotMu() const { return m_lpivots[1]; }
119 const HepPoint3D& getLPivot() const { return m_lpivots[2]; }
120 const HepPoint3D& getLPivotK() const { return m_lpivots[3]; }
121 const HepPoint3D& getLPivotP() const { return m_lpivots[4]; }
122
123 // const HepVector& getZHelix(const int pid) const { return m_zhelixs[pid];}
124 // const HepSymMatrix& getZError(const int pid) const { return m_zerrors[pid];}
125 const HepVector& getLHelix(const int pid) const { return m_lhelixs[pid];}
126 const HepSymMatrix& getLError(const int pid) const { return m_lerrors[pid];}
127 //const HepVector& getFHelix(const int pid) const { return m_fhelixs[pid];}
128 //const HepSymMatrix& getFError(const int pid) const { return m_ferrors[pid];}
129 const HepPoint3D& getPoca(const int pid) const { return m_pocas[pid];}
130 const HepPoint3D& getLPoint(const int pid) const { return m_lpoints[pid];}
131 const double getFiTerm(const int pid) const { return m_fiTerm[pid]; }
132 const HepPoint3D& getLPivot(const int pid) const { return m_lpivots[pid];}
133
134
135 const double getZDr(void) const { return m_zhelixs[2][0]; }
136 const double getZFi0(void) const { return m_zhelixs[2][1]; }
137 const double getZCpa(void) const { return m_zhelixs[2][2]; }
138 const double getZDz(void) const { return m_zhelixs[2][3]; }
139 const double getZTanl(void) const { return m_zhelixs[2][4]; }
140
141 const double getLDr(void) const { return m_lhelixs[2][0]; }
142 const double getLFi0(void) const { return m_lhelixs[2][1]; }
143 const double getLCpa(void) const { return m_lhelixs[2][2]; }
144 const double getLDz(void) const { return m_lhelixs[2][3]; }
145 const double getLTanl(void) const { return m_lhelixs[2][4]; }
146
147 const double getFDr(void) const { return m_fhelixs[2][0]; }
148 const double getFFi0(void) const { return m_fhelixs[2][1]; }
149 const double getFCpa(void) const { return m_fhelixs[2][2]; }
150 const double getFDz(void) const { return m_fhelixs[2][3]; }
151 const double getFTanl(void) const { return m_fhelixs[2][4]; }
152
153
154 // modifiers
155 void setVecHelixSegs(const HelixSegRefVec& vechelixsegs, int pid=-1);// 2011-05-06
156
157
158 //void setTrackId(int id) { m_trackId = id; }
159 void setMass(double mass, int pid) { m_mass[pid] = mass; }
160 void setLength(double length, int pid) { m_length[pid] = length; }
161 void setTof(double tof, int pid) { m_tof[pid] = tof; }
162 void setNhits(int nhits, int pid) { m_nhits[pid] = nhits; }
163 //void setStat(int stat, int i, int pid) { m_stat[i][pid] = stat; }
164 //void setChisq(double chisq, int i, int pid) { m_chisq[i][pid] = chisq; }
165 //void setNdf(int ndf, int i, int pid) { m_ndf[i][pid] = ndf; }
166 //void setNster(int nster, int i, int pid) { m_nster[i][pid] = nster; }
167 //void setFirstLayer(int fL, int i, int pid) { m_firstLayer[i][pid] = fL;}
168 //void setLastLayer(int lL, int i, int pid) { m_lastLayer[i][pid] = lL; }
169 void setPathl(double pathl, int i) { m_pathl[i] = pathl; }
170 void setPathSM(double length, int pid) { m_pathSM[pid] = length; }
171
172
173 /*
174 void setZHelix(const HepVector& helix, const int pid) {
175 m_zhelixs[pid] = helix;
176 }
177 void setZError(const HepSymMatrix& error, const int pid) {
178 m_zerrors[pid] = error;
179 }
180 void setZHelix(float* helix, const int pid) {
181 for(int i=0; i<3; i++) {
182 m_zhelixs[pid][i] = helix[i];
183 }
184 }
185 void setZError(float* error, const int pid) {
186 int k=0;
187 HepSymMatrix mat(5);
188 for(int i=0; i<5 ; i++) {
189 for(int j=0; j<=i; j++,k++) {
190 mat[i][j] = error[k];
191 mat[j][i] = error[k];
192 }
193 }
194 m_zerrors[pid] = mat;
195 }
196 */
197
198 // void setFHelix(const HepVector& helix, const int pid) {
199 // m_fhelixs[pid] = helix;
200 // }
201 // void setFError(const HepSymMatrix& error, const int pid) {
202 // m_ferrors[pid] = error;
203 // }
204 // void setFHelix(double* helix, const int pid) {
205 // for(int i=0; i<5; i++) {
206 // m_fhelixs[pid][i] = helix[i];
207 // }
208 // }
209 // void setFError(double* error, const int pid) {
210 // int k=0;
211 // HepSymMatrix mat(5);
212 // for(int i=0; i<5 ; i++) {
213 // for(int j=0; j<=i; j++,k++) {
214 // mat[i][j] = error[k];
215 // mat[j][i] = error[k];
216 // }
217 // }
218 // m_ferrors[pid] = mat;
219 // }
220
221 void setLHelix(const HepVector& helix, const int pid) {
222 m_lhelixs[pid] = helix;
223 }
224 void setLError(const HepSymMatrix& error, const int pid) {
225 m_lerrors[pid] = error;
226 }
227 void setLHelix(double* helix, const int pid) {
228 for(int i=0; i<5; i++) {
229 m_lhelixs[pid][i] = helix[i];
230 }
231 }
232 void setLError(double* error, const int pid) {
233 int k=0;
234 HepSymMatrix mat(5);
235 for(int i=0; i<5 ; i++) {
236 for(int j=0; j<=i; j++,k++) {
237 mat[i][j] = error[k];
238 mat[j][i] = error[k];
239 }
240 }
241 m_lerrors[pid] = mat;
242 }
243
244 void setTHelix(const HepVector& helix) {
245 for(int i=0; i<5; i++){
246 m_thelix[i] = helix[i];
247 }
248 m_ta = helix;
249 }
250 void setTError(const HepSymMatrix& error) {
251 int k=0;
252 for(int i=0; i<5; i++){
253 for(int j=i; j<5; j++){
254 m_terror[k] = error[i][j];
255 k++;
256 }
257 }
258 m_tEa = error;
259 }
260 void setTHelix(double helix[5]) {
261 HepVector atemp(5);
262 for(int i=0; i<5; i++) {
263 m_thelix[i] = helix[i];
264 atemp[i] = helix[i];
265 }
266 m_ta = atemp;
267 }
268 void setTError(double error[15] ) {
269 int k=0;
270 HepSymMatrix mat(5);
271 for(int i=0; i<5 ; i++) {
272 for(int j=0; j<=i; j++,k++) {
273 mat[i][j] = error[k];
274 mat[j][i] = mat[i][j];
275 }
276 }
277 m_tEa = mat;
278
279 for(int i=0; i<15 ; i++) {
280 m_terror[i] = error[i];
281 }
282 }
283
284 void setLPoint(const HepPoint3D& point, const int pid) {
285 m_lpoints[pid] = point;
286 }
287
288
289 void setFiTerm(double fi, const int pid){
290 m_fiTerm[pid] = fi;
291 }
292
293
294 void setLPivot(const HepPoint3D& pivot, const int pid) {
295 m_lpivots[pid] = pivot;
296 }
297
298
299 /*
300 void setPoca(const HepPoint3D& poca, const int pid) {
301 m_pocas[pid] = poca;
302 }
303 void setPoca(float* poca, const int pid) {
304 for(int i=0; i<3; i++) {
305 m_pocas[pid][i] = poca[i];
306 }
307 }
308 */
309
310 private:
311 HelixSegRefVec m_vechelixsegs[5];// add 5 hypotheses by wangll 2011-05-06
312 int pidSeg;// added by wangll 2011-05-06
313 //int m_trackId;
314 double m_mass[5]; // mass assumption during the fit
315 //track path length from closest point to coord. origin to the last hit
316 double m_length[5];
317 double m_tof[5]; // time of flight correspond to length;
318 int m_nhits[5]; // number of total hits contained
319 // status flag 0:filter 1: smoother, convention: -1:as default; 0:kalfit OK; 1: kalfit abandoned
320 // int m_stat[2][5];
321 // int m_nster[2][5];
322 // int m_firstLayer[2][5];
323 // int m_lastLayer[2][5];
324 // double m_chisq[2][5]; // chi square of fit 0:filter 1:smoother
325 // int m_ndf[2][5]; // degree of freedom for the fit 0:filter 1:smoother
326 double m_pathl[43]; // path length in each layer
327 double m_pathSM[5];
328 double m_fiTerm[5];
329
330 // std::vector<HepPoint3D> m_pocas;
331 // std::vector<HepVector> m_zhelixs;
332 // std::vector<HepSymMatrix> m_zerrors;
333
334 std::vector<HepPoint3D> m_lpivots;
335 std::vector<HepPoint3D> m_lpoints;
336
337 //std::vector<HepVector> m_fhelixs;
338 //std::vector<HepSymMatrix> m_ferrors;
339 std::vector<HepVector> m_lhelixs;
340 std::vector<HepSymMatrix> m_lerrors;
341 double m_thelix[5];
342 double m_terror[15];
343 HepVector m_ta;
344 HepSymMatrix m_tEa;
345
346};
347
348typedef ObjectVector<RecMdcKalTrack> RecMdcKalTrackCol;
349
350#endif
351
SmartRefVector< RecMdcKalHelixSeg > HelixSegRefVec
SmartRefVector< RecMdcKalHelixSeg > HelixSegRefVec
const CLID & CLID_RecMdcKalTrack
Definition: EventModel.cxx:355
ObjectVector< RecMdcKalTrack > RecMdcKalTrackCol
void setLHelix(const HepVector &helix, const int pid)
RecMdcKalTrack(const RecMdcKalTrack &track)
RecMdcKalTrack & operator=(const RecMdcKalTrack &)
HelixSegRefVec getVecHelixSegs(int pid=-1) const
RecMdcKalTrack & operator=(const DstMdcKalTrack &)
void setVecHelixSegs(const HelixSegRefVec &vechelixsegs, int pid=-1)
void setLError(const HepSymMatrix &error, const int pid)
void setLPoint(const HepPoint3D &point, const int pid)
void setLPivot(const HepPoint3D &pivot, const int pid)
const HepSymMatrix & getLError(const int pid) const
RecMdcKalTrack(const DstMdcKalTrack &track)