Class Reference for E1039 Core & Analysis Software
|
#include </dev/shm/kenichi/update-github-e1039-doc/e1039-core/packages/reco/kfitter/KalmanTrack.h>
Public Member Functions | |
KalmanTrack () | |
Constructor, default one is for list::resize() More... | |
KalmanTrack (SRecTrack &_trk, SRawEvent *_rawevt, SRecEvent *_recevt) | |
void | setTracklet (Tracklet &tracklet, bool wildseedcov=true) |
void | flipCharge () |
Flip the sign of this track. More... | |
bool | isValid () |
Self check to see if it is null. More... | |
bool | propagateTo (int detectorID) |
Propagate the track to a designated position. More... | |
int | getCurrentDetectorID () |
double | getExpPosition () |
Get the expected position. More... | |
double | getExpPosError () |
double | getExpPositionX () |
double | getExpPositionY () |
double | getExpPosErrorX () |
double | getExpPosErrorY () |
Node * | getNearestNodePtr (double z) |
void | getExpPositionFast (double z, double &x, double &y, Node *_node=nullptr) |
void | getExpPosErrorFast (double z, double &dx, double &dy, Node *_node=nullptr) |
double | getExpLocalSlop () |
Get the expected slope. More... | |
double | getExpLcSlopErr () |
double | getExpLocalIntersection () |
double | getExpLcIntersectionErr () |
bool | addHit (Hit _hit) |
void | update () |
Update the track status. More... | |
void | updateMomentum () |
Update the momentum. More... | |
void | setCurrTrkpar (TrkPar &_trkpar) |
set the current track parameter More... | |
double | getMomentumVertex (double z, double &px, double &py, double &pz) |
Get the rough vertex momentum. More... | |
std::list< int > & | getHitIndexList () |
Get the list of hits associated. More... | |
std::list< Node > & | getNodeList () |
std::vector< int > | getMissedDetectorIDs () |
int | getNHits () |
int | getCharge () |
int | getAssignedCharge () |
int | getKickCharge () |
double | getChisq () |
double | getQuality () |
double | getReducedChisq () |
double | getChisqVertex () |
double | getXZSlopeInStation (int stationID) |
double | getPositionInStation (int stationID, double &x, double &y, double &z) |
double | getMomentumInStation (int stationID) |
double | getMomentumUpstream () |
double | getMomentumUpstream (double &px, double &py, double &pz) |
int | getNHitsInStation (int stationID) |
void | getSagittaInSuperDetector (int detectorID, double &pos_exp, double &window) |
Node * | getNodeDownstream () |
Get Nodes in both upstream and downstream which are closest to KMag. More... | |
Node * | getNodeUpstream () |
bool | operator< (const KalmanTrack &elem) const |
Overriden operators. More... | |
bool | operator== (const KalmanTrack &elem) const |
bool | similarity (const KalmanTrack &elem) const |
void | print () |
Debugging print. More... | |
void | printNodes () |
int | getNodeChisq (double *chisqs) |
Quality monitoring methods. More... | |
int | getAlignment (int level, int *detectorID, double *res, double *R, double *T) |
int | getPositions (int level, double *x, double *y, double *z) |
int | getMomentums (int level, double *px, double *py, double *pz) |
int | getHitsIndex (int *index) |
TGraph | getXZProjection () |
SRecTrack | getSRecTrack () |
Output to SRecTrack. More... | |
Definition at line 27 of file KalmanTrack.h.
KalmanTrack::KalmanTrack | ( | ) |
Constructor, default one is for list::resize()
Default constructor for KalmanTrack, wiill only be used when resizing the track candidate list.
Definition at line 18 of file KalmanTrack.cxx.
References update().
Update the hit info. if needed
Definition at line 27 of file KalmanTrack.cxx.
References TrkPar::_covar_kf, TrkPar::_state_kf, TrkPar::_z, Hit::detectorID, Hit::driftDistance, Hit::elementID, SRecTrack::getChisq(), SRecTrack::getChisqAtNode(), SRecTrack::getCovariance(), GeomSvc::getDriftDistance(), Node::getFiltered(), SRawEvent::getHit(), SRecTrack::getHitIndex(), SRecEvent::getLocalID(), GeomSvc::getMeasurement(), SRecTrack::getNHits(), Node::getPredicted(), Hit::getSign(), Node::getSmoothed(), SRecTrack::getStateVector(), SRecTrack::getZ(), GeomSvc::instance(), Hit::pos, Node::setChisq(), Node::setFilterDone(), Node::setPredictionDone(), Node::setSmoothDone(), Node::setZ(), and Hit::tdcTime.
bool KalmanTrack::addHit | ( | Hit | _hit | ) |
Add a new hit to the hit list both in index list and node list
Definition at line 576 of file KalmanTrack.cxx.
References KalmanFilter::filter(), Node::getFiltered(), Node::getPredicted(), Hit::index, KalmanFilter::instance(), Node::setPredictionDone(), and update().
void KalmanTrack::flipCharge | ( | ) |
Flip the sign of this track.
Definition at line 160 of file KalmanTrack.cxx.
References TrkPar::_covar_kf, and TrkPar::flip_charge().
int KalmanTrack::getAlignment | ( | int | level, |
int * | detectorID, | ||
double * | res, | ||
double * | R, | ||
double * | T | ||
) |
Definition at line 600 of file KalmanTrack.cxx.
References GeomSvc::getCostheta(), GeomSvc::getSintheta(), and GeomSvc::instance().
|
inline |
Definition at line 89 of file KalmanTrack.h.
Referenced by print().
|
inline |
Definition at line 88 of file KalmanTrack.h.
Referenced by print().
|
inline |
Definition at line 91 of file KalmanTrack.h.
Referenced by KalmanDSTrk::processOneTracklet().
|
inline |
Definition at line 94 of file KalmanTrack.h.
|
inline |
Definition at line 46 of file KalmanTrack.h.
References Hit::detectorID, and Node::getHit().
double KalmanTrack::getExpLcIntersectionErr | ( | ) |
double KalmanTrack::getExpLcSlopErr | ( | ) |
Definition at line 360 of file KalmanTrack.cxx.
References TrkPar::_covar_kf, Node::getPredicted(), and Node::getProjector().
double KalmanTrack::getExpLocalIntersection | ( | ) |
double KalmanTrack::getExpLocalSlop | ( | ) |
Get the expected slope.
Definition at line 351 of file KalmanTrack.cxx.
References TrkPar::_state_kf, Node::getPredicted(), and Node::getProjector().
double KalmanTrack::getExpPosError | ( | ) |
Definition at line 252 of file KalmanTrack.cxx.
References TrkPar::_covar_kf, Hit::detectorID, SMatrix::getABCt(), Node::getHit(), GeomSvc::getPlaneSpacing(), Node::getPredicted(), Node::getProjector(), and GeomSvc::instance().
void KalmanTrack::getExpPosErrorFast | ( | double | z, |
double & | dx, | ||
double & | dy, | ||
Node * | _node = nullptr |
||
) |
Definition at line 320 of file KalmanTrack.cxx.
References TrkPar::_covar_kf, TrkPar::get_z(), Node::getFiltered(), getNearestNodePtr(), Node::getPredicted(), Node::getSmoothed(), Node::isFilterDone(), and Node::isSmoothDone().
|
inline |
Definition at line 53 of file KalmanTrack.h.
References TrkPar::_covar_kf, and Node::getPredicted().
|
inline |
Definition at line 54 of file KalmanTrack.h.
References TrkPar::_covar_kf, and Node::getPredicted().
double KalmanTrack::getExpPosition | ( | ) |
Get the expected position.
Definition at line 239 of file KalmanTrack.cxx.
References TrkPar::_state_kf, Node::getPredicted(), Node::getProjector(), and LogInfo.
void KalmanTrack::getExpPositionFast | ( | double | z, |
double & | x, | ||
double & | y, | ||
Node * | _node = nullptr |
||
) |
Definition at line 289 of file KalmanTrack.cxx.
References TrkPar::get_dxdz(), TrkPar::get_dydz(), TrkPar::get_x(), TrkPar::get_y(), TrkPar::get_z(), Node::getFiltered(), getNearestNodePtr(), Node::getPredicted(), Node::getSmoothed(), Node::isFilterDone(), and Node::isSmoothDone().
Referenced by getSagittaInSuperDetector().
|
inline |
Definition at line 51 of file KalmanTrack.h.
References TrkPar::_state_kf, and Node::getPredicted().
|
inline |
Definition at line 52 of file KalmanTrack.h.
References TrkPar::_state_kf, and Node::getPredicted().
|
inline |
Get the list of hits associated.
Definition at line 83 of file KalmanTrack.h.
Referenced by KalmanDSTrk::processOneTracklet(), KalmanFastTracking::resolveLeftRight(), and KalmanDSTrk::resolveLeftRight().
int KalmanTrack::getHitsIndex | ( | int * | index | ) |
Definition at line 712 of file KalmanTrack.cxx.
int KalmanTrack::getKickCharge | ( | ) |
Definition at line 478 of file KalmanTrack.cxx.
References getXZSlopeInStation().
Referenced by print().
std::vector< int > KalmanTrack::getMissedDetectorIDs | ( | ) |
Definition at line 724 of file KalmanTrack.cxx.
double KalmanTrack::getMomentumInStation | ( | int | stationID | ) |
Definition at line 409 of file KalmanTrack.cxx.
int KalmanTrack::getMomentums | ( | int | level, |
double * | px, | ||
double * | py, | ||
double * | pz | ||
) |
Definition at line 677 of file KalmanTrack.cxx.
|
inline |
Definition at line 99 of file KalmanTrack.h.
Referenced by isValid().
double KalmanTrack::getMomentumUpstream | ( | double & | px, |
double & | py, | ||
double & | pz | ||
) |
Definition at line 486 of file KalmanTrack.cxx.
double KalmanTrack::getMomentumVertex | ( | double | z, |
double & | px, | ||
double & | py, | ||
double & | pz | ||
) |
Get the rough vertex momentum.
Definition at line 204 of file KalmanTrack.cxx.
References KalmanFilter::fit_node(), TrkPar::get_mom(), Node::getChisq(), Node::getFiltered(), Node::getMeasurement(), Node::getMeasurementCov(), Node::getProjector(), KalmanFilter::instance(), KalmanFilter::setCurrTrkpar(), and Node::setZ().
Node * KalmanTrack::getNearestNodePtr | ( | double | z | ) |
Definition at line 269 of file KalmanTrack.cxx.
Referenced by getExpPosErrorFast(), and getExpPositionFast().
|
inline |
Definition at line 87 of file KalmanTrack.h.
Referenced by getXZProjection().
int KalmanTrack::getNHitsInStation | ( | int | stationID | ) |
Definition at line 502 of file KalmanTrack.cxx.
int KalmanTrack::getNodeChisq | ( | double * | chisqs | ) |
Quality monitoring methods.
Node * KalmanTrack::getNodeDownstream | ( | ) |
Get Nodes in both upstream and downstream which are closest to KMag.
Definition at line 390 of file KalmanTrack.cxx.
References Hit::detectorID, and Node::getHit().
|
inline |
Definition at line 84 of file KalmanTrack.h.
Referenced by VertexFit::addTrack(), KalmanFastTracking::fitTrack(), KalmanDSTrk::fitTrack(), SQReco::fitTrackCand(), KalmanFitter::initNodeList(), KalmanDSTrk::processOneTracklet(), KalmanFastTracking::resolveLeftRight(), KalmanDSTrk::resolveLeftRight(), KalmanFitter::setStartingParameter(), and KalmanFitter::updateTrack().
Node * KalmanTrack::getNodeUpstream | ( | ) |
Definition at line 371 of file KalmanTrack.cxx.
References Hit::detectorID, and Node::getHit().
double KalmanTrack::getPositionInStation | ( | int | stationID, |
double & | x, | ||
double & | y, | ||
double & | z | ||
) |
Definition at line 447 of file KalmanTrack.cxx.
int KalmanTrack::getPositions | ( | int | level, |
double * | x, | ||
double * | y, | ||
double * | z | ||
) |
Definition at line 643 of file KalmanTrack.cxx.
Referenced by getXZProjection().
|
inline |
Definition at line 92 of file KalmanTrack.h.
|
inline |
Definition at line 93 of file KalmanTrack.h.
void KalmanTrack::getSagittaInSuperDetector | ( | int | detectorID, |
double & | pos_exp, | ||
double & | window | ||
) |
DetectorID of the relevant view of D1U, D1X and D1V
Definition at line 752 of file KalmanTrack.cxx.
References GeomSvc::getCostheta(), getExpPositionFast(), GeomSvc::getPlanePosition(), GeomSvc::getSintheta(), and GeomSvc::instance().
SRecTrack KalmanTrack::getSRecTrack | ( | ) |
Output to SRecTrack.
Definition at line 801 of file KalmanTrack.cxx.
References SRecTrack::insertChisq(), SRecTrack::insertCovariance(), SRecTrack::insertHitIndex(), SRecTrack::insertStateVector(), SRecTrack::insertZ(), SRecTrack::setChisq(), SRecTrack::setKalmanStatus(), and SRecTrack::swimToVertex().
Referenced by SQReco::fitTrackCand(), KalmanFastTracking::processOneTracklet(), and KalmanDSTrk::processOneTracklet().
TGraph KalmanTrack::getXZProjection | ( | ) |
Definition at line 792 of file KalmanTrack.cxx.
References getNHits(), and getPositions().
double KalmanTrack::getXZSlopeInStation | ( | int | stationID | ) |
Definition at line 428 of file KalmanTrack.cxx.
Referenced by getKickCharge().
bool KalmanTrack::isValid | ( | ) |
Self check to see if it is null.
Definition at line 96 of file KalmanTrack.cxx.
References getMomentumUpstream().
Referenced by SQReco::fitTrackCand(), KalmanFastTracking::processOneTracklet(), and KalmanDSTrk::processOneTracklet().
bool KalmanTrack::operator< | ( | const KalmanTrack & | elem | ) | const |
Overriden operators.
Definition at line 533 of file KalmanTrack.cxx.
bool KalmanTrack::operator== | ( | const KalmanTrack & | elem | ) | const |
Definition at line 538 of file KalmanTrack.cxx.
void KalmanTrack::print | ( | ) |
Debugging print.
Definition at line 820 of file KalmanTrack.cxx.
References TrkPar::_state_kf, TrkPar::get_z(), getAssignedCharge(), getCharge(), and getKickCharge().
Referenced by KalmanDSTrk::processOneTracklet().
void KalmanTrack::printNodes | ( | ) |
Definition at line 851 of file KalmanTrack.cxx.
Referenced by KalmanDSTrk::processOneTracklet().
bool KalmanTrack::propagateTo | ( | int | detectorID | ) |
Propagate the track to a designated position.
Definition at line 185 of file KalmanTrack.cxx.
References Hit::detectorID, KalmanFilter::instance(), KalmanFilter::predict(), and KalmanFilter::setCurrTrkpar().
|
inline |
set the current track parameter
Definition at line 77 of file KalmanTrack.h.
Referenced by KalmanDSTrk::processOneTracklet(), and KalmanFitter::updateTrack().
void KalmanTrack::setTracklet | ( | Tracklet & | tracklet, |
bool | wildseedcov = true |
||
) |
Definition at line 62 of file KalmanTrack.cxx.
References TrkPar::_covar_kf, TrkPar::_state_kf, TrkPar::_z, Tracklet::getCharge(), Tracklet::getExpPositionX(), Tracklet::getExpPositionY(), GeomSvc::getPlanePosition(), Tracklet::hits, GeomSvc::instance(), Tracklet::invP, Tracklet::tx, and Tracklet::ty.
Referenced by SQReco::fitTrackCand(), and KalmanFastTracking::processOneTracklet().
bool KalmanTrack::similarity | ( | const KalmanTrack & | elem | ) | const |
Definition at line 546 of file KalmanTrack.cxx.
void KalmanTrack::update | ( | ) |
Update the track status.
Definition at line 520 of file KalmanTrack.cxx.
Referenced by addHit(), KalmanTrack(), and KalmanFitter::updateTrack().
void KalmanTrack::updateMomentum | ( | ) |