10 #ifndef _KALMANTRACK_H
11 #define _KALMANTRACK_H
88 int getCharge() {
return _nodes.front().getFiltered().get_charge(); }
120 int getAlignment(
int level,
int *detectorID,
double* res,
double* R,
double* T);
121 int getPositions(
int level,
double* x,
double* y,
double* z);
122 int getMomentums(
int level,
double* px,
double* py,
double* pz);
130 std::list<int> _hit_index;
131 std::list<Node> _nodes;
135 double _chisq_vertex;
Definition of hit structure.
int getAlignment(int level, int *detectorID, double *res, double *R, double *T)
double getMomentumVertex(double z, double &px, double &py, double &pz)
Get the rough vertex momentum.
double getExpPosition()
Get the expected position.
int getHitsIndex(int *index)
void updateMomentum()
Update the momentum.
bool operator<(const KalmanTrack &elem) const
Overriden operators.
SRecTrack getSRecTrack()
Output to SRecTrack.
bool similarity(const KalmanTrack &elem) const
int getCurrentDetectorID()
std::vector< int > getMissedDetectorIDs()
std::list< Node > & getNodeList()
int getPositions(int level, double *x, double *y, double *z)
void setTracklet(Tracklet &tracklet, bool wildseedcov=true)
int getNHitsInStation(int stationID)
double getExpLocalIntersection()
bool isValid()
Self check to see if it is null.
void print()
Debugging print.
void setCurrTrkpar(TrkPar &_trkpar)
set the current track parameter
std::list< int > & getHitIndexList()
Get the list of hits associated.
int getNodeChisq(double *chisqs)
Quality monitoring methods.
double getExpLocalSlop()
Get the expected slope.
bool propagateTo(int detectorID)
Propagate the track to a designated position.
Node * getNodeDownstream()
Get Nodes in both upstream and downstream which are closest to KMag.
int getMomentums(int level, double *px, double *py, double *pz)
void update()
Update the track status.
double getMomentumUpstream()
double getXZSlopeInStation(int stationID)
double getExpLcIntersectionErr()
void getSagittaInSuperDetector(int detectorID, double &pos_exp, double &window)
void getExpPositionFast(double z, double &x, double &y, Node *_node=nullptr)
void getExpPosErrorFast(double z, double &dx, double &dy, Node *_node=nullptr)
double getMomentumInStation(int stationID)
Node * getNearestNodePtr(double z)
double getPositionInStation(int stationID, double &x, double &y, double &z)
bool operator==(const KalmanTrack &elem) const
void flipCharge()
Flip the sign of this track.
KalmanTrack()
Constructor, default one is for list::resize()
TrkPar & getPredicted()
Gets.
TMatrixD _state_kf
State vectors and its covariance.