Class Reference for E1039 Core & Analysis Software
SRecEvent.h
Go to the documentation of this file.
1 /*
2 SRecEvent.h
3 
4 Definition of the class SRecEvent and SRecTrack. SRecTrack is the final track structure of recontructed tracks.
5 Contains nothing but ROOT classes, light-weighted and can be used as input for physics analysis. SRecEvent serves
6 as a container of SRecTrack
7 
8 Added SRecDimuon, containing the dimuon info
9 
10 Author: Kun Liu, liuk@fnal.gov
11 Created: 01-21-2013
12 */
13 
14 #ifndef _SRECTRACK_H
15 #define _SRECTRACK_H
16 
17 #include <GlobalConsts.h>
18 
19 #include <phool/PHObject.h>
20 #include <interface_main/SQTrack.h>
22 
23 #include <iostream>
24 #include <vector>
25 #include <list>
26 #include <string>
27 #include <algorithm>
28 #include <map>
29 #include <cmath>
30 #include <stdexcept>
31 
32 #include <TObject.h>
33 #include <TROOT.h>
34 #include <TMatrixD.h>
35 #include <TVector3.h>
36 #include <TLorentzVector.h>
37 
38 #include <GenFit/MeasuredStateOnPlane.h>
39 
40 #include "SRawEvent.h"
41 
42 class SRecTrack: public SQTrack
43 {
44 public:
45  SRecTrack();
46 
48  void identify(std::ostream& os = std::cout) const { print(os); }
49  void Reset() { *this = SRecTrack(); }
50  int isValid() const;
51  SRecTrack* Clone() const {return (new SRecTrack(*this)); }
52 
54  virtual int get_track_id() const { return 0; }
55  virtual void set_track_id(const int a) { throw std::logic_error(__PRETTY_FUNCTION__); }
56 
57  virtual int get_rec_track_id() const { return 0; }
58  virtual void set_rec_track_id(const int a) { throw std::logic_error(__PRETTY_FUNCTION__); }
59 
60  virtual int get_charge() const { return getCharge(); }
61  virtual void set_charge(const int a) { throw std::logic_error(__PRETTY_FUNCTION__); }
62 
63  virtual int get_num_hits() const { return getNHits(); }
64  virtual void set_num_hits(const int a) { throw std::logic_error(__PRETTY_FUNCTION__); }
65 
66  virtual TVector3 get_pos_vtx() const { return fVertexPos; }
67  virtual void set_pos_vtx(const TVector3 a) { fVertexPos = a; }
68 
69  virtual TVector3 get_pos_st1() const { return getPositionVecSt1(); }
70  virtual void set_pos_st1(const TVector3 a) { throw std::logic_error(__PRETTY_FUNCTION__); }
71 
72  virtual TVector3 get_pos_st3() const { return getPositionVecSt3(); }
73  virtual void set_pos_st3(const TVector3 a) { throw std::logic_error(__PRETTY_FUNCTION__); }
74 
75  virtual TLorentzVector get_mom_vtx() const { return getlvec(fVertexMom); }
76  virtual void set_mom_vtx(const TLorentzVector a) { fVertexMom = a.Vect(); }
77 
78  virtual TLorentzVector get_mom_st1() const { return getlvec(getMomentumVecSt1()); }
79  virtual void set_mom_st1(const TLorentzVector a) { throw std::logic_error(__PRETTY_FUNCTION__); }
80 
81  virtual TLorentzVector get_mom_st3() const { return getlvec(getMomentumVecSt3()); }
82  virtual void set_mom_st3(const TLorentzVector a) { throw std::logic_error(__PRETTY_FUNCTION__); }
83 
84  virtual double get_chisq() const { return fChisq; }
85  virtual double get_chisq_target() const { return fChisqTarget; }
86  virtual double get_chisq_dump() const { return fChisqDump; }
87  virtual double get_chsiq_upstream() const { return fChisqUpstream; }
88  virtual double get_chisq_upstream() const { return fChisqUpstream; }
89 
90  virtual TVector3 get_pos_target() const { return fTargetPos; }
91  virtual TVector3 get_pos_dump() const { return fDumpPos; }
92 
93  virtual TLorentzVector get_mom_target() const { return getlvec(fTargetMom); }
94  virtual TLorentzVector get_mom_dump() const { return getlvec(fDumpMom); }
95 
96  virtual int get_hit_id(const int i) const { return fHitIndex[i]; }
97 
98  inline TLorentzVector getlvec(const TVector3& vec) const { TLorentzVector lvec; lvec.SetVectM(vec, M_MU); return lvec; }
99 
101  Int_t getCharge() const { return (fState[0])[0][0] > 0 ? 1 : -1; }
102  Int_t getNHits() const { return fHitIndex.size(); }
103  Int_t getNHitsInStation(Int_t stationID);
104  Double_t getChisq() const { return fChisq; }
105  Double_t getProb() const;
106  Double_t getQuality() const { return (Double_t)getNHits() - 0.4*getChisq(); }
107 
108  Int_t getHitIndex(Int_t i) { return fHitIndex[i]; }
109  TMatrixD getStateVector(Int_t i) { return fState[i]; }
110  TMatrixD getCovariance(Int_t i) { return fCovar[i]; }
111  Double_t getZ(Int_t i) { return fZ[i]; }
112  Double_t getChisqAtNode(Int_t i) { return fChisqAtNode[i]; }
113 
114  TVector3 getGFPlaneO(Int_t i) { return fGFDetPlaneVec[0][i]; }
115  TVector3 getGFPlaneU(Int_t i) { return fGFDetPlaneVec[1][i]; }
116  TVector3 getGFPlaneV(Int_t i) { return fGFDetPlaneVec[2][i]; }
117  TVectorD getGFAuxInfo(Int_t i) { return fGFAuxInfo[i]; }
118  TVectorD getGFState(Int_t i) { return fGFStateVec[i]; }
119  TMatrixDSym getGFCov(Int_t i) { return fGFCov[i]; }
120 
121  Int_t getNearestNode(Double_t z);
122  void getExpPositionFast(Double_t z, Double_t& x, Double_t& y, Int_t iNode = -1);
123  void getExpPosErrorFast(Double_t z, Double_t& dx, Double_t& dy, Int_t iNode = -1);
124  Double_t getExpMomentumFast(Double_t z, Double_t& px, Double_t& py, Double_t& pz, Int_t iNode = -1);
125  Double_t getExpMomentumFast(Double_t z, Int_t iNode = -1);
126 
127  Double_t getMomentumSt1(Double_t& px, Double_t& py, Double_t& pz) const { return getMomentum(fState.front(), px, py, pz); }
128  Double_t getMomentumSt1() const { Double_t px, py, pz; return getMomentumSt1(px, py, pz); }
129  TVector3 getMomentumVecSt1() const { Double_t px, py, pz; getMomentumSt1(px, py, pz); return TVector3(px, py, pz); }
130 
131  Double_t getMomentumSt3(Double_t& px, Double_t& py, Double_t& pz) const { return getMomentum(fState.back(), px, py, pz); }
132  Double_t getMomentumSt3() const { Double_t px, py, pz; return getMomentumSt3(px, py, pz); }
133  TVector3 getMomentumVecSt3() const { Double_t px, py, pz; getMomentumSt3(px, py, pz); return TVector3(px, py, pz); }
134 
135  Double_t getPositionSt1(Double_t& x, Double_t& y) const { return getPosition(fState.front(), x, y); }
136  Double_t getPositionSt1() const { Double_t x, y; return getPositionSt1(x, y); }
137  TVector3 getPositionVecSt1() const { Double_t x, y; getPositionSt1(x, y); return TVector3(x, y, fZ.front()); }
138 
139  Double_t getPositionSt3(Double_t& x, Double_t& y) const { return getPosition(fState.back(), x, y); }
140  Double_t getPositionSt3() const { Double_t x, y; return getPositionSt3(x, y); }
141  TVector3 getPositionVecSt3() const { Double_t x, y; getPositionSt3(x, y); return TVector3(x, y, fZ.back()); }
142 
143  Double_t getMomentum(const TMatrixD& state, Double_t& px, Double_t& py, Double_t& pz) const;
144  Double_t getPosition(const TMatrixD& state, Double_t& x, Double_t& y) const;
145 
147  Bool_t isKalmanFitted() { return fKalmanStatus > 0; }
148  void setKalmanStatus(Int_t status) { fKalmanStatus = status; }
149 
151  bool operator<(const SRecTrack& elem) const;
152 
154  void setChisq(Double_t chisq) { fChisq = chisq; }
155  void insertHitIndex(Int_t index) { fHitIndex.push_back(index); }
156  void insertStateVector(TMatrixD state) { fState.push_back(state); }
157  void insertCovariance(TMatrixD covar) { fCovar.push_back(covar); }
158  void insertZ(Double_t z) { fZ.push_back(z); }
159  void insertChisq(Double_t chisq) { fChisqAtNode.push_back(chisq); }
160  void insertGFState(const genfit::MeasuredStateOnPlane& msop);
161 
163  void adjustKMag(double kmagStr);
164 
166  bool isVertexValid() const;
167  void setZVertex(Double_t z, bool update = true);
168  void updateVtxHypothesis();
169 
171  void setVertexFast(TVector3 mom, TVector3 pos);
172 
174  void swimToVertex(TVector3* pos = nullptr, TVector3* mom = nullptr, bool hyptest = true);
175 
177  TLorentzVector getMomentumVertex();
178  Double_t getMomentumVertex(Double_t& px, Double_t& py, Double_t& pz) { return getMomentum(fStateVertex, px, py, pz); }
179  Double_t getZVertex() { return fVertexPos[2]; }
180  Double_t getRVertex() { return fVertexPos.Perp(); }
181  TVector3 getVertex() { return fVertexPos; }
182  Double_t getVtxPar(Int_t i) { return fVertexPos[i]; }
183  Double_t getChisqVertex() { return fChisqVertex; }
184 
186  TVector3 getDumpPos() { return fDumpPos; }
187  TVector3 getDumpFacePos() { return fDumpFacePos; }
188  TVector3 getTargetPos() { return fTargetPos; }
189  TVector3 getXVertexPos() { return fXVertexPos; }
190  TVector3 getYVertexPos() { return fYVertexPos; }
191  TVector3 getDumpMom() { return fDumpMom; }
192  TVector3 getDumpFaceMom() { return fDumpFaceMom; }
193  TVector3 getTargetMom() { return fTargetMom; }
194  TVector3 getXVertexMom() { return fXVertexMom; }
195  TVector3 getYVertexMom() { return fYVertexMom; }
196  TVector3 getVertexPos() { return fVertexPos; }
197  TVector3 getVertexMom() { return fVertexMom; }
198  Double_t getChisqDump() { return fChisqDump; }
199  Double_t getChisqTarget() { return fChisqTarget; }
200  Double_t getChisqUpstream() { return fChisqUpstream; }
201 
203  void setDumpPos(TVector3 pos) { fDumpPos = pos; }
204  void setDumpFacePos(TVector3 pos) { fDumpFacePos = pos; }
205  void setTargetPos(TVector3 pos) { fTargetPos = pos; }
206  void setXVertexPos(TVector3 pos) { fXVertexPos = pos; }
207  void setYVertexPos(TVector3 pos) { fYVertexPos = pos; }
208  void setVertexPos(TVector3 pos) { fVertexPos = pos; }
209  void setDumpMom(TVector3 mom) { fDumpMom = mom; }
210  void setDumpFaceMom(TVector3 mom) { fDumpFaceMom = mom; }
211  void setTargetMom(TVector3 mom) { fTargetMom = mom; }
212  void setXVertexMom(TVector3 mom) { fXVertexMom = mom; }
213  void setYVertexMom(TVector3 mom) { fYVertexMom = mom; }
214  void setVertexMom(TVector3 mom) { fVertexMom = mom; }
215  void setChisqDump(Double_t chisq) { fChisqDump = chisq; }
216  void setChisqTarget(Double_t chisq) { fChisqTarget = chisq; }
217  void setChisqUpstream(Double_t chisq) { fChisqUpstream = chisq; }
218  void setChisqVertex(Double_t chisq) { fChisqVertex = chisq; }
219 
221  void setTriggerRoad(Int_t roadID) { fTriggerID = roadID; }
222  Int_t getTriggerRoad() { return fTriggerID; }
223 
225  void setPTSlope(Double_t slopeX, Double_t slopeY) { fPropSlopeX = slopeX; fPropSlopeY = slopeY; }
226  void setNHitsInPT(Int_t nHitsX, Int_t nHitsY) { fNPropHitsX = nHitsX; fNPropHitsY = nHitsY; }
227  Double_t getPTSlopeX() { return fPropSlopeX; }
228  Double_t getPTSlopeY() { return fPropSlopeY; }
229  Double_t getDeflectionX() { return fState.back()[1][0] - fPropSlopeX; }
230  Double_t getDeflectionY() { return fState.back()[2][0] - fPropSlopeY; }
231  Int_t getNHitsInPTX() { return fNPropHitsX; }
232  Int_t getNHitsInPTY() { return fNPropHitsY; }
233 
235  //bool isValid();
236  bool isTarget();
237  bool isDump();
238 
240  void print(std::ostream& os = std::cout) const;
241  void printGF(std::ostream& os = std::cout) const;
242 
243 private:
245  Double_t fChisq;
246 
248  std::vector<Int_t> fHitIndex;
249  std::vector<TMatrixD> fState;
250  std::vector<TMatrixD> fCovar;
251  std::vector<Double_t> fZ;
252  std::vector<Double_t> fChisqAtNode;
253 
255  TVector3 fDumpFacePos;
256  TVector3 fDumpPos;
257  TVector3 fTargetPos;
258  TVector3 fXVertexPos;
259  TVector3 fYVertexPos;
260 
261  TVector3 fDumpFaceMom;
262  TVector3 fDumpMom;
263  TVector3 fTargetMom;
264  TVector3 fXVertexMom;
265  TVector3 fYVertexMom;
266 
268  TVector3 fVertexMom; //duplicate information as fStateVertex already contains all the info., just keep it for now
269  TVector3 fVertexPos;
270  Double_t fChisqVertex;
271  TMatrixD fStateVertex;
272  TMatrixD fCovarVertex;
273 
275  Int_t fKalmanStatus;
276 
278  Int_t fTriggerID;
279 
281  Int_t fNPropHitsX;
282  Int_t fNPropHitsY;
283  Double_t fPropSlopeX;
284  Double_t fPropSlopeY;
285 
287  Double_t fChisqTarget;
288  Double_t fChisqDump;
289  Double_t fChisqUpstream;
290 
292  std::vector<TVector3> fGFDetPlaneVec[3];
293  std::vector<TVectorD> fGFAuxInfo;
294  std::vector<TVectorD> fGFStateVec;
295  std::vector<TMatrixDSym> fGFCov;
296 
297  ClassDef(SRecTrack, 11)
298 };
299 
300 class SRecDimuon: public SQDimuon
301 {
302 public:
303 
305  void identify(std::ostream& os = std::cout) const { os << "SRecDimuon: TODO: NOT IMPLEMENTED!" << std::endl; }
306  void Reset() { *this = SRecDimuon(); }
307  int isValid() const;
308  SRecDimuon* Clone() const { return (new SRecDimuon(*this)); }
309 
311  virtual int get_dimuon_id() const { return 0; }
312  virtual void set_dimuon_id(const int a) { throw std::logic_error(__PRETTY_FUNCTION__); }
313 
314  virtual int get_rec_dimuon_id() const { return 0; }
315  virtual void set_rec_dimuon_id(const int a) { throw std::logic_error(__PRETTY_FUNCTION__); }
316 
317  virtual int get_pdg_id() const { return 0; }
318  virtual void set_pdg_id(const int a) { throw std::logic_error(__PRETTY_FUNCTION__); }
319 
320  virtual int get_track_id_pos() const { return trackID_pos; }
321  virtual void set_track_id_pos(const int a) { trackID_pos = a; }
322 
323  virtual int get_track_id_neg() const { return trackID_neg; }
324  virtual void set_track_id_neg(const int a) { trackID_neg = a; }
325 
326  virtual TVector3 get_pos() const { return vtx; }
327  virtual void set_pos(const TVector3 a) { vtx = a; }
328 
329  virtual TLorentzVector get_mom() const { return p_pos + p_neg; }
330  virtual void set_mom(const TLorentzVector a) { throw std::logic_error(__PRETTY_FUNCTION__); }
331 
332  virtual TLorentzVector get_mom_pos() const { return p_pos; }
333  virtual void set_mom_pos(const TLorentzVector a) { p_pos = a; }
334 
335  virtual TLorentzVector get_mom_neg() const { return p_neg; }
336  virtual void set_mom_neg(const TLorentzVector a) { p_neg = a; }
337 
338  virtual double get_mass() const { return mass; }
339  virtual double get_x1() const { return x1; }
340  virtual double get_x2() const { return x2; }
341  virtual double get_xf() const { return xF; }
342 
343  virtual double get_chisq() const { return chisq_kf; }
344 
346  TLorentzVector getVPhoton() { return p_pos + p_neg; }
347 
349  void calcVariables(int choice = 0);
350 
351  //Dimuon quality cut
352  //bool isValid();
353 
355  bool isTarget();
356 
358  bool isDump();
359 
361  Int_t trackID_pos;
362  Int_t trackID_neg;
363 
365  TLorentzVector p_pos;
366  TLorentzVector p_neg;
367 
369  TLorentzVector p_pos_target;
370  TLorentzVector p_neg_target;
371  TLorentzVector p_pos_dump;
372  TLorentzVector p_neg_dump;
373 
375  TLorentzVector p_pos_single;
376  TLorentzVector p_neg_single;
377 
379  TVector3 vtx;
380  TVector3 vtx_pos;
381  TVector3 vtx_neg;
382 
384  TVector3 proj_target_pos;
385  TVector3 proj_dump_pos;
386  TVector3 proj_target_neg;
387  TVector3 proj_dump_neg;
388 
390  Double_t mass;
391  Double_t pT;
392  Double_t xF;
393  Double_t x1;
394  Double_t x2;
395  Double_t costh;
396  Double_t phi;
397  Double_t mass_single;
398  Double_t chisq_single;
399 
401  Double_t chisq_kf;
402  Double_t chisq_vx;
403 
405  Double_t chisq_target;
406  Double_t chisq_dump;
407  Double_t chisq_upstream;
408 
409  ClassDef(SRecDimuon, 7)
410 };
411 
412 class SRecEvent: public PHObject
413 {
414 public:
415  SRecEvent();
416 
418  void identify(std::ostream& os = std::cout) const {
419  os
420  << " SRecEvent: { " << fRunID << ", " << fSpillID << ", " << fEventID << " } "
421  << " NTracks: " << fAllTracks.size()
422  << std::endl;
423  }
424  void Reset() {*this = SRecEvent();}
425  int isValid() const {return true;}
426  SRecEvent* Clone() const {return (new SRecEvent(*this));}
427 
429  void setEventInfo(SRawEvent* rawEvent);
430  void setEventInfo(int runID, int spillID, int eventID) { fRunID = runID; fSpillID = spillID; fEventID = eventID; }
431  void setTargetPos(int targetPos) { fTargetPos = targetPos; }
432  void setRecStatus(int status) { fRecStatus += status; }
433 
435  void setRawEvent(SRawEvent* rawEvent);
436 
438  bool isTriggeredBy(Int_t trigger) { return (fTriggerBits & trigger) != 0; }
439 
440  Int_t getRunID() { return fRunID; }
441  Int_t getSpillID() { return fSpillID; }
442  Int_t getEventID() { return fEventID; }
443  Int_t getTargetPos() { return fTargetPos; }
444  Int_t getTriggerBits() { return fTriggerBits; }
445  Int_t getRecStatus() { return fRecStatus; }
446 
447  Int_t getLocalID(Int_t hitID) { return fLocalID[hitID]; }
448 
450  void setEventSource(Int_t id1, Int_t id2) { fSource1 = id1; fSource2 = id2; }
451  Int_t getSourceID1() { return fSource1; }
452  Int_t getSourceID2() { return fSource2; }
453 
455  Int_t getNTracks() { return fAllTracks.size(); }
456  SRecTrack& getTrack(Int_t i) { return fAllTracks[i]; }
457 
459  std::vector<Int_t> getChargedTrackIDs(Int_t charge);
460 
462  Int_t getNDimuons() { return fDimuons.size(); }
463  SRecDimuon& getDimuon(Int_t i) { return fDimuons[i]; }
464 
466  void insertTrack(SRecTrack trk) { fAllTracks.push_back(trk); }
467  void reIndex() { sort(fAllTracks.begin(), fAllTracks.end()); }
468 
470  void insertDimuon(SRecDimuon dimuon) { fDimuons.push_back(dimuon); }
471 
473  void clear();
474  void clearTracks();
475  void clearDimuons();
476 
477 private:
479  Short_t fRecStatus;
480 
482  Int_t fRunID;
483  Int_t fSpillID;
484  Int_t fEventID;
485 
487  Int_t fTargetPos;
488 
490  Int_t fTriggerBits;
491 
493  std::vector<SRecTrack> fAllTracks;
494 
496  std::vector<SRecDimuon> fDimuons;
497 
499  std::map<Int_t, Int_t> fLocalID;
500 
501  //Event source
502  Int_t fSource1;
503  Int_t fSource2;
504 
505  ClassDef(SRecEvent, 5)
506 };
507 
508 #endif
#define M_MU
Definition: GlobalConsts.h:12
An SQ interface class to hold one true or reconstructed dimuon.
Definition: SQDimuon.h:8
ClassDef(SQDimuon, 1)
An SQ interface class to hold one true or reconstructed track.
Definition: SQTrack.h:8
ClassDef(SQTrack, 1)
Double_t costh
Definition: SRecEvent.h:395
virtual int get_rec_dimuon_id() const
Return the dimuon ID of associated reconstructed dimuon. Valid only if this object holds truth dimuon...
Definition: SRecEvent.h:314
Double_t mass_single
Definition: SRecEvent.h:397
Double_t chisq_single
Definition: SRecEvent.h:398
TVector3 vtx
3-vector vertex position
Definition: SRecEvent.h:379
virtual int get_dimuon_id() const
SQDimuon virtual functions.
Definition: SRecEvent.h:311
void calcVariables(int choice=0)
Calculate the kinematic vairables, 0 = vertex, 1 = target, 2 = dump.
Definition: SRecEvent.cxx:633
virtual double get_xf() const
Definition: SRecEvent.h:341
TLorentzVector p_neg_target
Definition: SRecEvent.h:370
virtual void set_dimuon_id(const int a)
Definition: SRecEvent.h:312
virtual void set_mom_neg(const TLorentzVector a)
Definition: SRecEvent.h:336
Double_t chisq_dump
Definition: SRecEvent.h:406
Double_t chisq_upstream
Definition: SRecEvent.h:407
TVector3 proj_target_neg
Definition: SRecEvent.h:386
bool isDump()
Dump dimuon.
Definition: SRecEvent.cxx:735
int isValid() const
isValid returns non zero if object contains vailid data
Definition: SRecEvent.cxx:694
Double_t chisq_vx
Definition: SRecEvent.h:402
virtual void set_track_id_pos(const int a)
Definition: SRecEvent.h:321
virtual int get_pdg_id() const
Return the GPD ID of parent particle. It is valid only for true dimuon.
Definition: SRecEvent.h:317
Int_t trackID_pos
Index of muon track used in host SRecEvent.
Definition: SRecEvent.h:361
virtual TVector3 get_pos() const
Return the dimuon position at vertex.
Definition: SRecEvent.h:326
Double_t xF
Definition: SRecEvent.h:392
Double_t chisq_target
Chisq of three test position.
Definition: SRecEvent.h:405
TVector3 proj_dump_pos
Definition: SRecEvent.h:385
TLorentzVector p_neg_single
Definition: SRecEvent.h:376
virtual void set_pdg_id(const int a)
Definition: SRecEvent.h:318
TVector3 proj_dump_neg
Definition: SRecEvent.h:387
Int_t trackID_neg
Definition: SRecEvent.h:362
TLorentzVector p_pos_target
Track momentum projections at different location.
Definition: SRecEvent.h:369
TLorentzVector p_neg
Definition: SRecEvent.h:366
virtual double get_mass() const
Definition: SRecEvent.h:338
TLorentzVector p_pos_single
4-momentum of the muon tracks before vertex fit
Definition: SRecEvent.h:375
virtual void set_pos(const TVector3 a)
Definition: SRecEvent.h:327
Double_t chisq_kf
Vertex fit chisqs.
Definition: SRecEvent.h:401
Double_t x2
Definition: SRecEvent.h:394
TLorentzVector p_pos
4-momentum of the muon tracks after vertex fit
Definition: SRecEvent.h:365
virtual double get_x2() const
Definition: SRecEvent.h:340
virtual TLorentzVector get_mom() const
Return the dimuon momentum at vertex.
Definition: SRecEvent.h:329
virtual double get_chisq() const
Definition: SRecEvent.h:343
Double_t x1
Definition: SRecEvent.h:393
virtual void set_track_id_neg(const int a)
Definition: SRecEvent.h:324
virtual int get_track_id_neg() const
Return the track ID of the negative track.
Definition: SRecEvent.h:323
virtual int get_track_id_pos() const
Return the track ID of the positive track.
Definition: SRecEvent.h:320
Double_t mass
Kinematic variables.
Definition: SRecEvent.h:390
TVector3 vtx_neg
Definition: SRecEvent.h:381
bool isTarget()
Target dimuon.
Definition: SRecEvent.cxx:719
virtual void set_mom_pos(const TLorentzVector a)
Definition: SRecEvent.h:333
virtual void set_rec_dimuon_id(const int a)
Definition: SRecEvent.h:315
Double_t pT
Definition: SRecEvent.h:391
TVector3 vtx_pos
Definition: SRecEvent.h:380
TVector3 proj_target_pos
Track projections at different location.
Definition: SRecEvent.h:384
TLorentzVector p_pos_dump
Definition: SRecEvent.h:371
virtual void set_mom(const TLorentzVector a)
Definition: SRecEvent.h:330
virtual TLorentzVector get_mom_neg() const
Return the momentum of the negative track at vertex.
Definition: SRecEvent.h:335
void Reset()
Clear Event.
Definition: SRecEvent.h:306
TLorentzVector p_neg_dump
Definition: SRecEvent.h:372
virtual double get_x1() const
Definition: SRecEvent.h:339
SRecDimuon * Clone() const
Definition: SRecEvent.h:308
virtual TLorentzVector get_mom_pos() const
Return the momentum of the positive track at vertex.
Definition: SRecEvent.h:332
Double_t phi
Definition: SRecEvent.h:396
TLorentzVector getVPhoton()
Get the total momentum of the virtual photon.
Definition: SRecEvent.h:346
void identify(std::ostream &os=std::cout) const
PHObject virtual overloads.
Definition: SRecEvent.h:305
void setRecStatus(int status)
Definition: SRecEvent.h:432
Int_t getSourceID2()
Definition: SRecEvent.h:452
SRecEvent * Clone() const
Definition: SRecEvent.h:426
Int_t getEventID()
Definition: SRecEvent.h:442
void setEventSource(Int_t id1, Int_t id2)
Event source set/get.
Definition: SRecEvent.h:450
void setTargetPos(int targetPos)
Definition: SRecEvent.h:431
void setEventInfo(int runID, int spillID, int eventID)
Definition: SRecEvent.h:430
Int_t getRecStatus()
Definition: SRecEvent.h:445
bool isTriggeredBy(Int_t trigger)
Trigger util.
Definition: SRecEvent.h:438
void reIndex()
Definition: SRecEvent.h:467
std::vector< Int_t > getChargedTrackIDs(Int_t charge)
Get track IDs.
Definition: SRecEvent.cxx:785
void insertTrack(SRecTrack trk)
Insert tracks.
Definition: SRecEvent.h:466
void identify(std::ostream &os=std::cout) const
PHObject virtual overloads.
Definition: SRecEvent.h:418
void setRawEvent(SRawEvent *rawEvent)
directly setup everything by raw event
Definition: SRecEvent.cxx:764
Int_t getLocalID(Int_t hitID)
Definition: SRecEvent.h:447
void Reset()
Clear Event.
Definition: SRecEvent.h:424
void clearTracks()
Definition: SRecEvent.cxx:811
SRecDimuon & getDimuon(Int_t i)
Definition: SRecEvent.h:463
Int_t getRunID()
Definition: SRecEvent.h:440
int isValid() const
isValid returns non zero if object contains vailid data
Definition: SRecEvent.h:425
Int_t getTargetPos()
Definition: SRecEvent.h:443
void insertDimuon(SRecDimuon dimuon)
Insert dimuon.
Definition: SRecEvent.h:470
void setEventInfo(SRawEvent *rawEvent)
Set/Get event info.
Definition: SRecEvent.cxx:775
Int_t getSourceID1()
Definition: SRecEvent.h:451
void clear()
Clear everything.
Definition: SRecEvent.cxx:802
Int_t getSpillID()
Definition: SRecEvent.h:441
Int_t getTriggerBits()
Definition: SRecEvent.h:444
Int_t getNTracks()
Get tracks.
Definition: SRecEvent.h:455
void clearDimuons()
Clear the dimuon list.
Definition: SRecEvent.cxx:824
SRecTrack & getTrack(Int_t i)
Definition: SRecEvent.h:456
Int_t getNDimuons()
Get dimuons.
Definition: SRecEvent.h:462
virtual TVector3 get_pos_st3() const
Return the track position at Station 3.
Definition: SRecEvent.h:72
void getExpPosErrorFast(Double_t z, Double_t &dx, Double_t &dy, Int_t iNode=-1)
Definition: SRecEvent.cxx:288
TMatrixD getCovariance(Int_t i)
Definition: SRecEvent.h:110
Double_t getChisq() const
Definition: SRecEvent.h:104
void setNHitsInPT(Int_t nHitsX, Int_t nHitsY)
Definition: SRecEvent.h:226
Int_t getNHits() const
Definition: SRecEvent.h:102
virtual void set_mom_st3(const TLorentzVector a)
Definition: SRecEvent.h:82
TVector3 getTargetPos()
Definition: SRecEvent.h:188
Int_t getCharge() const
Gets.
Definition: SRecEvent.h:101
SRecTrack * Clone() const
Definition: SRecEvent.h:51
Double_t getVtxPar(Int_t i)
Definition: SRecEvent.h:182
Double_t getChisqTarget()
Definition: SRecEvent.h:199
TLorentzVector getlvec(const TVector3 &vec) const
Definition: SRecEvent.h:98
TVector3 getMomentumVecSt3() const
Definition: SRecEvent.h:133
virtual TLorentzVector get_mom_st3() const
Return the track momentum at Station 3.
Definition: SRecEvent.h:81
Double_t getMomentum(const TMatrixD &state, Double_t &px, Double_t &py, Double_t &pz) const
Definition: SRecEvent.cxx:322
bool isDump()
Definition: SRecEvent.cxx:397
Double_t getRVertex()
Definition: SRecEvent.h:180
TVector3 getVertexPos()
Definition: SRecEvent.h:196
Double_t getPosition(const TMatrixD &state, Double_t &x, Double_t &y) const
Definition: SRecEvent.cxx:332
virtual int get_charge() const
Return the charge, i.e. +1 or -1.
Definition: SRecEvent.h:60
Double_t getMomentumSt1(Double_t &px, Double_t &py, Double_t &pz) const
Definition: SRecEvent.h:127
Double_t getChisqAtNode(Int_t i)
Definition: SRecEvent.h:112
virtual TLorentzVector get_mom_target() const
Definition: SRecEvent.h:93
Double_t getPositionSt3(Double_t &x, Double_t &y) const
Definition: SRecEvent.h:139
bool isVertexValid() const
Vertex stuff.
Definition: SRecEvent.cxx:241
void setVertexPos(TVector3 pos)
Definition: SRecEvent.h:208
void setChisqDump(Double_t chisq)
Definition: SRecEvent.h:215
Double_t getChisqDump()
Definition: SRecEvent.h:198
TVector3 getVertex()
Definition: SRecEvent.h:181
TVectorD getGFAuxInfo(Int_t i)
Definition: SRecEvent.h:117
void Reset()
Clear Event.
Definition: SRecEvent.h:49
TLorentzVector getMomentumVertex()
Get the vertex info.
Definition: SRecEvent.cxx:340
Int_t getTriggerRoad()
Definition: SRecEvent.h:222
void setDumpPos(TVector3 pos)
Set mom/pos at a given location.
Definition: SRecEvent.h:203
void getExpPositionFast(Double_t z, Double_t &x, Double_t &y, Int_t iNode=-1)
Definition: SRecEvent.cxx:267
virtual double get_chsiq_upstream() const
Definition: SRecEvent.h:87
bool operator<(const SRecTrack &elem) const
Comparitor.
Definition: SRecEvent.cxx:144
virtual double get_chisq_target() const
Definition: SRecEvent.h:85
void setTargetPos(TVector3 pos)
Definition: SRecEvent.h:205
Double_t getMomentumSt3() const
Definition: SRecEvent.h:132
void insertChisq(Double_t chisq)
Definition: SRecEvent.h:159
void setZVertex(Double_t z, bool update=true)
Definition: SRecEvent.cxx:168
void setChisq(Double_t chisq)
Sets.
Definition: SRecEvent.h:154
Double_t getPositionSt3() const
Definition: SRecEvent.h:140
void insertCovariance(TMatrixD covar)
Definition: SRecEvent.h:157
void print(std::ostream &os=std::cout) const
Debugging output.
Definition: SRecEvent.cxx:578
void insertGFState(const genfit::MeasuredStateOnPlane &msop)
Definition: SRecEvent.cxx:351
TVector3 getYVertexPos()
Definition: SRecEvent.h:190
virtual int get_track_id() const
SQTrack virtual overloads.
Definition: SRecEvent.h:54
TMatrixD getStateVector(Int_t i)
Definition: SRecEvent.h:109
Double_t getProb() const
Definition: SRecEvent.cxx:163
Double_t getZ(Int_t i)
Definition: SRecEvent.h:111
Double_t getPositionSt1(Double_t &x, Double_t &y) const
Definition: SRecEvent.h:135
void setYVertexPos(TVector3 pos)
Definition: SRecEvent.h:207
void adjustKMag(double kmagStr)
Fast-adjust of kmag.
Definition: SRecEvent.cxx:363
virtual void set_mom_vtx(const TLorentzVector a)
Definition: SRecEvent.h:76
TVector3 getMomentumVecSt1() const
Definition: SRecEvent.h:129
void setChisqTarget(Double_t chisq)
Definition: SRecEvent.h:216
virtual void set_pos_st1(const TVector3 a)
Definition: SRecEvent.h:70
TVector3 getDumpFacePos()
Definition: SRecEvent.h:187
Double_t getChisqUpstream()
Definition: SRecEvent.h:200
void setXVertexPos(TVector3 pos)
Definition: SRecEvent.h:206
TVector3 getPositionVecSt1() const
Definition: SRecEvent.h:137
virtual TVector3 get_pos_st1() const
Return the track position at Station 1.
Definition: SRecEvent.h:69
Double_t getQuality() const
Definition: SRecEvent.h:106
Double_t getMomentumSt1() const
Definition: SRecEvent.h:128
void setYVertexMom(TVector3 mom)
Definition: SRecEvent.h:213
Int_t getHitIndex(Int_t i)
Definition: SRecEvent.h:108
TVectorD getGFState(Int_t i)
Definition: SRecEvent.h:118
TVector3 getPositionVecSt3() const
Definition: SRecEvent.h:141
virtual int get_hit_id(const int i) const
Definition: SRecEvent.h:96
virtual double get_chisq_upstream() const
Definition: SRecEvent.h:88
virtual TLorentzVector get_mom_st1() const
Return the track momentum at Station 1.
Definition: SRecEvent.h:78
void printGF(std::ostream &os=std::cout) const
Definition: SRecEvent.cxx:593
TVector3 getGFPlaneU(Int_t i)
Definition: SRecEvent.h:115
TVector3 getXVertexMom()
Definition: SRecEvent.h:194
void setVertexMom(TVector3 mom)
Definition: SRecEvent.h:214
Double_t getDeflectionY()
Definition: SRecEvent.h:230
Int_t getNHitsInStation(Int_t stationID)
Definition: SRecEvent.cxx:149
int isValid() const
isValid returns non zero if object contains vailid data
Definition: SRecEvent.cxx:371
bool isTarget()
Overall track quality cut.
Definition: SRecEvent.cxx:392
TVector3 getGFPlaneO(Int_t i)
Definition: SRecEvent.h:114
void setDumpFaceMom(TVector3 mom)
Definition: SRecEvent.h:210
Int_t getNearestNode(Double_t z)
Definition: SRecEvent.cxx:249
void setPTSlope(Double_t slopeX, Double_t slopeY)
Prop. tube muon ID info.
Definition: SRecEvent.h:225
void setTriggerRoad(Int_t roadID)
Trigger road info.
Definition: SRecEvent.h:221
virtual void set_track_id(const int a)
Definition: SRecEvent.h:55
Double_t getMomentumVertex(Double_t &px, Double_t &py, Double_t &pz)
Definition: SRecEvent.h:178
void insertZ(Double_t z)
Definition: SRecEvent.h:158
virtual void set_num_hits(const int a)
Definition: SRecEvent.h:64
virtual void set_mom_st1(const TLorentzVector a)
Definition: SRecEvent.h:79
virtual TVector3 get_pos_dump() const
Definition: SRecEvent.h:91
void setXVertexMom(TVector3 mom)
Definition: SRecEvent.h:212
TVector3 getVertexMom()
Definition: SRecEvent.h:197
Double_t getZVertex()
Definition: SRecEvent.h:179
virtual void set_charge(const int a)
Definition: SRecEvent.h:61
virtual void set_pos_vtx(const TVector3 a)
Definition: SRecEvent.h:67
void setTargetMom(TVector3 mom)
Definition: SRecEvent.h:211
void setChisqUpstream(Double_t chisq)
Definition: SRecEvent.h:217
Double_t getDeflectionX()
Definition: SRecEvent.h:229
virtual void set_pos_st3(const TVector3 a)
Definition: SRecEvent.h:73
TVector3 getDumpFaceMom()
Definition: SRecEvent.h:192
virtual void set_rec_track_id(const int a)
Definition: SRecEvent.h:58
Double_t getExpMomentumFast(Double_t z, Double_t &px, Double_t &py, Double_t &pz, Int_t iNode=-1)
Definition: SRecEvent.cxx:311
TMatrixDSym getGFCov(Int_t i)
Definition: SRecEvent.h:119
Bool_t isKalmanFitted()
Fit status.
Definition: SRecEvent.h:147
void setDumpMom(TVector3 mom)
Definition: SRecEvent.h:209
void swimToVertex(TVector3 *pos=nullptr, TVector3 *mom=nullptr, bool hyptest=true)
Simple swim to vertex.
Definition: SRecEvent.cxx:402
virtual TLorentzVector get_mom_dump() const
Definition: SRecEvent.h:94
virtual int get_num_hits() const
Return the number of hits associated to this track.
Definition: SRecEvent.h:63
Double_t getPTSlopeX()
Definition: SRecEvent.h:227
Int_t getNHitsInPTX()
Definition: SRecEvent.h:231
void insertHitIndex(Int_t index)
Definition: SRecEvent.h:155
TVector3 getXVertexPos()
Definition: SRecEvent.h:189
virtual TVector3 get_pos_target() const
Definition: SRecEvent.h:90
Double_t getMomentumSt3(Double_t &px, Double_t &py, Double_t &pz) const
Definition: SRecEvent.h:131
void updateVtxHypothesis()
Definition: SRecEvent.cxx:213
TVector3 getYVertexMom()
Definition: SRecEvent.h:195
TVector3 getDumpPos()
Get mom/pos at a given location.
Definition: SRecEvent.h:186
virtual double get_chisq_dump() const
Definition: SRecEvent.h:86
void setDumpFacePos(TVector3 pos)
Definition: SRecEvent.h:204
virtual int get_rec_track_id() const
Return the track ID of associated reconstructed track. Valid only if this object holds truth track in...
Definition: SRecEvent.h:57
TVector3 getTargetMom()
Definition: SRecEvent.h:193
Double_t getPTSlopeY()
Definition: SRecEvent.h:228
virtual TLorentzVector get_mom_vtx() const
Return the track momentum at vertex.
Definition: SRecEvent.h:75
void identify(std::ostream &os=std::cout) const
PHObject virtual overloads.
Definition: SRecEvent.h:48
virtual double get_chisq() const
Definition: SRecEvent.h:84
Double_t getPositionSt1() const
Definition: SRecEvent.h:136
Int_t getNHitsInPTY()
Definition: SRecEvent.h:232
TVector3 getDumpMom()
Definition: SRecEvent.h:191
void setKalmanStatus(Int_t status)
Definition: SRecEvent.h:148
void setVertexFast(TVector3 mom, TVector3 pos)
Plain setting, no KF-related stuff.
Definition: SRecEvent.cxx:227
TVector3 getGFPlaneV(Int_t i)
Definition: SRecEvent.h:116
void insertStateVector(TMatrixD state)
Definition: SRecEvent.h:156
Double_t getChisqVertex()
Definition: SRecEvent.h:183
void setChisqVertex(Double_t chisq)
Definition: SRecEvent.h:218
virtual TVector3 get_pos_vtx() const
Return the track position at vertex.
Definition: SRecEvent.h:66