Class Reference for E1039 Core & Analysis Software
Tracklet Class Reference

#include </dev/shm/kenichi/update-github-e1039-doc/e1039-core/packages/reco/interface/FastTracklet.h>

+ Inheritance diagram for Tracklet:
+ Collaboration diagram for Tracklet:

Public Member Functions

 Tracklet ()
 
void identify (std::ostream &os=std::cout) const
 
void Reset ()
 Clear Event. More...
 
int isValid () const
 isValid returns non zero if object contains vailid data More...
 
TrackletClone () const
 
void print (std::ostream &os=std::cout)
 
void sortHits ()
 
int getNHits () const
 
int getNAllHits ()
 
double getProb () const
 
double getMomProb () const
 
double getChisq () const
 
double getExpPositionX (double z) const
 
double getExpPosErrorX (double z) const
 
double getExpPositionY (double z) const
 
double getExpPosErrorY (double z) const
 
double getExpPositionW (int detectorID) const
 
int getExpElementID (int detectorID) const
 
TVector3 getMomentumSt1 () const
 
TVector3 getMomentumSt3 () const
 
TVector3 getExpMomentum (double z) const
 
SignedHit getSignedHit (int index)
 
double Eval (const double *par)
 
double Eval4 (const double *par)
 
double calcChisq ()
 
void addDummyHits ()
 
double getMomentum () const
 
int getCharge () const
 Return the charge (+1 or -1) of this tracklet. More...
 
void getXZInfoInSt1 (double &tx_st1, double &x0_st1) const
 
void getXZErrorInSt1 (double &err_tx_st1, double &err_x0_st1) const
 
bool operator< (const Tracklet &elem) const
 
bool similarity (const Tracklet &elem) const
 
Tracklet merge (Tracklet &elem)
 
Tracklet operator+ (const Tracklet &elem) const
 
Tracklet operator* (const Tracklet &elem) const
 
SRecTrack getSRecTrack (bool hyptest=true)
 
- Public Member Functions inherited from PHObject
 PHObject ()
 ctor More...
 
virtual ~PHObject ()
 dtor More...
 
virtual PHObjectclone () const
 Virtual copy constructor. More...
 
virtual int isValid (const float) const
 
virtual int isValid (const double) const
 
virtual int isValid (const int) const
 
virtual int isValid (const unsigned int) const
 
virtual int isImplemented (const float f) const
 
virtual int isImplemented (const double f) const
 
virtual int isImplemented (const int i) const
 
virtual int isImplemented (const unsigned int i) const
 
void SplitLevel (const int i)
 
int SplitLevel () const
 
void BufferSize (const int i)
 
int BufferSize () const
 

Public Attributes

int stationID
 
int nXHits
 
int nUHits
 
int nVHits
 
double chisq
 
double chisq_vtx
 
std::list< SignedHithits
 
PropSegment seg_x
 
PropSegment seg_y
 
double tx
 
double ty
 
double x0
 
double y0
 
double invP
 
double err_tx
 
double err_ty
 
double err_x0
 
double err_y0
 
double err_invP
 
double residual [nChamberPlanes]
 

Detailed Description

Definition at line 123 of file FastTracklet.h.

Constructor & Destructor Documentation

◆ Tracklet()

Tracklet::Tracklet ( )

Definition at line 500 of file FastTracklet.cxx.

References nChamberPlanes, and residual.

Referenced by Clone(), and Reset().

+ Here is the caller graph for this function:

Member Function Documentation

◆ addDummyHits()

void Tracklet::addDummyHits ( )

Definition at line 900 of file FastTracklet.cxx.

References Hit::detectorID, SignedHit::hit, hits, sortHits(), and stationID.

+ Here is the call graph for this function:

◆ calcChisq()

double Tracklet::calcChisq ( )

The drift distance of a hit is ignored if the drift sign of the hit is not fixed.

Definition at line 929 of file FastTracklet.cxx.

References chisq, getXZInfoInSt1(), hits, nStations, residual, stationID, tx, ty, x0, and y0.

Referenced by Eval(), Eval4(), merge(), operator*(), operator+(), print(), KalmanFastTracking::removeBadHits(), and KalmanDSTrk::removeBadHits().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ Clone()

Tracklet* Tracklet::Clone ( ) const
inline

Definition at line 132 of file FastTracklet.h.

References Tracklet().

Referenced by TrackletVector::push_back().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ Eval()

double Tracklet::Eval ( const double *  par)

Definition at line 986 of file FastTracklet.cxx.

References calcChisq(), invP, tx, ty, x0, and y0.

Referenced by KalmanDSTrk::KalmanDSTrk(), and SQTrackletFitter::SQTrackletFitter().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ Eval4()

double Tracklet::Eval4 ( const double *  par)

Definition at line 998 of file FastTracklet.cxx.

References calcChisq(), tx, ty, x0, and y0.

+ Here is the call graph for this function:

◆ getCharge()

int Tracklet::getCharge ( ) const

Return the charge (+1 or -1) of this tracklet.

This function should be as simple as possible, in order to reduce the computation time. Therefore the condition of the charge determination uses only "x0" and "tx" (at St. 2+3). The formula was obtained practically by the study in DocDB 9505. This function is valid for both the parallel and anti-parallel FMag+KMag polarity combination. But it is not guaranteed to be valid when the FMag and/or KMag field strength is changed largely.

Definition at line 745 of file FastTracklet.cxx.

References FMAGSTR, tx, and x0.

Referenced by SQGenFit::GFTrack::getCharge(), getExpPositionX(), getMomentum(), getSRecTrack(), getXZInfoInSt1(), print(), SimpleTree::process_event(), KalmanDSTrk::processOneTracklet(), KalmanTrack::setTracklet(), and SQGenFit::GFTrack::setTracklet().

+ Here is the caller graph for this function:

◆ getChisq()

double Tracklet::getChisq ( ) const
inline

Definition at line 157 of file FastTracklet.h.

References chisq.

Referenced by AnaModule::process_event(), and SimpleTree::process_event().

+ Here is the caller graph for this function:

◆ getExpElementID()

int Tracklet::getExpElementID ( int  detectorID) const

Definition at line 657 of file FastTracklet.cxx.

References getExpPositionW().

+ Here is the call graph for this function:

◆ getExpMomentum()

TVector3 Tracklet::getExpMomentum ( double  z) const

Definition at line 593 of file FastTracklet.cxx.

References getMomentumSt1(), getMomentumSt3(), nStations, and stationID.

Referenced by SQGenFit::GFTrack::setTracklet().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getExpPosErrorX()

double Tracklet::getExpPosErrorX ( double  z) const

Definition at line 613 of file FastTracklet.cxx.

References err_invP, err_tx, err_x0, nStations, and stationID.

Referenced by KalmanFastTracking::getExtrapoWindowsInSt1(), KalmanDSTrk::getExtrapoWindowsInSt1(), getSRecTrack(), KalmanFastTracking::hodoMask(), KalmanDSTrk::hodoMask(), KalmanFastTracking::muonID_hodoAid(), KalmanDSTrk::muonID_hodoAid(), and print().

+ Here is the caller graph for this function:

◆ getExpPosErrorY()

double Tracklet::getExpPosErrorY ( double  z) const

Definition at line 638 of file FastTracklet.cxx.

References err_ty, and err_y0.

Referenced by KalmanFastTracking::getExtrapoWindowsInSt1(), KalmanDSTrk::getExtrapoWindowsInSt1(), getSRecTrack(), KalmanFastTracking::hodoMask(), KalmanDSTrk::hodoMask(), KalmanFastTracking::muonID_hodoAid(), KalmanDSTrk::muonID_hodoAid(), and print().

+ Here is the caller graph for this function:

◆ getExpPositionW()

double Tracklet::getExpPositionW ( int  detectorID) const

Definition at line 646 of file FastTracklet.cxx.

References getExpPositionX(), and getExpPositionY().

Referenced by MakeRTCurve::AnalyzeFile(), CalibData::FillTrackletHits(), getExpElementID(), main(), AnaTrack::process_event(), AnaModule::process_event(), and SimpleTree::process_event().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getExpPositionX()

◆ getExpPositionY()

◆ getMomentum()

double Tracklet::getMomentum ( ) const

Definition at line 703 of file FastTracklet.cxx.

References getCharge(), getExpPositionX(), tx, and x0.

Referenced by merge(), operator*(), and operator+().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getMomentumSt1()

TVector3 Tracklet::getMomentumSt1 ( ) const

Definition at line 1066 of file FastTracklet.cxx.

References getXZInfoInSt1(), invP, and ty.

Referenced by getExpMomentum(), and print().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getMomentumSt3()

TVector3 Tracklet::getMomentumSt3 ( ) const

Definition at line 1075 of file FastTracklet.cxx.

References invP, tx, and ty.

Referenced by getExpMomentum(), and print().

+ Here is the caller graph for this function:

◆ getMomProb()

double Tracklet::getMomProb ( ) const

Definition at line 585 of file FastTracklet.cxx.

References invP.

◆ getNAllHits()

int Tracklet::getNAllHits ( )
inline

Definition at line 148 of file FastTracklet.h.

References hits.

◆ getNHits()

int Tracklet::getNHits ( ) const
inline

Definition at line 145 of file FastTracklet.h.

References nUHits, nVHits, and nXHits.

Referenced by MakeRTCurve::AnalyzeFile(), CalibData::FillTracklet(), SRMakeRTCurve::FindBestTracklet(), getProb(), operator<(), AnaTrack::process_event(), AnaModule::process_event(), SimpleTree::process_event(), and similarity().

+ Here is the caller graph for this function:

◆ getProb()

double Tracklet::getProb ( ) const

Definition at line 569 of file FastTracklet.cxx.

References chisq, getNHits(), nStations, and stationID.

Referenced by isValid(), and operator<().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getSignedHit()

SignedHit Tracklet::getSignedHit ( int  index)

Definition at line 973 of file FastTracklet.cxx.

References hits.

◆ getSRecTrack()

SRecTrack Tracklet::getSRecTrack ( bool  hyptest = true)

Definition at line 1009 of file FastTracklet.cxx.

References PropSegment::a, chisq, err_invP, err_tx, err_ty, err_x0, getCharge(), getExpPosErrorX(), getExpPosErrorY(), getExpPositionX(), getExpPositionY(), PropSegment::getNHits(), TriggerRoad::getRoadID(), getXZErrorInSt1(), getXZInfoInSt1(), hits, SRecTrack::insertCovariance(), SRecTrack::insertHitIndex(), SRecTrack::insertStateVector(), SRecTrack::insertZ(), invP, seg_x, seg_y, SRecTrack::setChisq(), SRecTrack::setNHitsInPT(), SRecTrack::setPTSlope(), SRecTrack::setTriggerRoad(), SRecTrack::swimToVertex(), tx, ty, and x0.

Referenced by KalmanFastTracking::processOneTracklet(), and KalmanDSTrk::processOneTracklet().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getXZErrorInSt1()

void Tracklet::getXZErrorInSt1 ( double &  err_tx_st1,
double &  err_x0_st1 
) const

Definition at line 764 of file FastTracklet.cxx.

References err_invP, err_tx, and err_x0.

Referenced by getSRecTrack(), KalmanFastTracking::resolveLeftRight(), and KalmanDSTrk::resolveLeftRight().

+ Here is the caller graph for this function:

◆ getXZInfoInSt1()

void Tracklet::getXZInfoInSt1 ( double &  tx_st1,
double &  x0_st1 
) const

Definition at line 750 of file FastTracklet.cxx.

References getCharge(), invP, tx, and x0.

Referenced by calcChisq(), getMomentumSt1(), getSRecTrack(), KalmanFastTracking::resolveLeftRight(), and KalmanDSTrk::resolveLeftRight().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ identify()

void Tracklet::identify ( std::ostream &  os = std::cout) const
inlinevirtual

identify Function from PHObject

Parameters
osOutput Stream

Reimplemented from PHObject.

Definition at line 129 of file FastTracklet.h.

References stationID.

◆ isValid()

int Tracklet::isValid ( ) const
virtual

isValid returns non zero if object contains vailid data

Reimplemented from PHObject.

Definition at line 506 of file FastTracklet.cxx.

References chisq, err_tx, err_ty, err_x0, err_y0, getProb(), hits, nStations, nUHits, nVHits, nXHits, stationID, tx, ty, x0, and y0.

Referenced by KalmanFastTracking::acceptTracklet(), KalmanDSTrk::acceptTracklet(), KalmanFastTracking::buildBackPartialTracks(), KalmanDSTrk::buildBackPartialTracks(), KalmanFastTracking::buildGlobalTracks(), KalmanDSTrk::buildGlobalTracks(), KalmanDSTrk::buildTrackletsInStation(), KalmanFastTracking::buildTrackletsInStation(), KalmanFastTrackletting::buildTrackletsInStation(), merge(), KalmanFastTracking::removeBadHits(), and KalmanDSTrk::removeBadHits().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ merge()

Tracklet Tracklet::merge ( Tracklet elem)

Definition at line 867 of file FastTracklet.cxx.

References calcChisq(), chisq_vtx, err_invP, err_tx, err_ty, err_x0, err_y0, getMomentum(), hits, invP, isValid(), seg_x, seg_y, stationID, tx, ty, x0, and y0.

Referenced by KalmanFastTracking::buildGlobalTracks(), and KalmanDSTrk::buildGlobalTracks().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ operator*()

Tracklet Tracklet::operator* ( const Tracklet elem) const

Definition at line 815 of file FastTracklet.cxx.

References calcChisq(), err_invP, err_tx, err_ty, err_x0, err_y0, getMomentum(), hits, invP, nStations, nUHits, nVHits, nXHits, stationID, tx, ty, x0, and y0.

+ Here is the call graph for this function:

◆ operator+()

Tracklet Tracklet::operator+ ( const Tracklet elem) const

Definition at line 779 of file FastTracklet.cxx.

References calcChisq(), err_invP, err_tx, err_ty, err_x0, err_y0, getMomentum(), hits, invP, nStations, nUHits, nVHits, nXHits, stationID, tx, ty, x0, and y0.

+ Here is the call graph for this function:

◆ operator<()

bool Tracklet::operator< ( const Tracklet elem) const

Definition at line 662 of file FastTracklet.cxx.

References chisq, getNHits(), and getProb().

+ Here is the call graph for this function:

◆ print()

void Tracklet::print ( std::ostream &  os = std::cout)

◆ Reset()

void Tracklet::Reset ( )
inlinevirtual

Clear Event.

Reimplemented from PHObject.

Definition at line 130 of file FastTracklet.h.

References Tracklet().

+ Here is the call graph for this function:

◆ similarity()

bool Tracklet::similarity ( const Tracklet elem) const

Definition at line 675 of file FastTracklet.cxx.

References getNHits(), and hits.

+ Here is the call graph for this function:

◆ sortHits()

void Tracklet::sortHits ( )
inline

Definition at line 142 of file FastTracklet.h.

References hits.

Referenced by addDummyHits(), KalmanDSTrk::buildTrackletsInStation(), KalmanFastTracking::buildTrackletsInStation(), and KalmanFastTrackletting::buildTrackletsInStation().

+ Here is the caller graph for this function:

Member Data Documentation

◆ chisq

◆ chisq_vtx

double Tracklet::chisq_vtx

◆ err_invP

◆ err_tx

◆ err_ty

◆ err_x0

◆ err_y0

◆ hits

◆ invP

◆ nUHits

◆ nVHits

◆ nXHits

◆ residual

double Tracklet::residual[nChamberPlanes]

◆ seg_x

◆ seg_y

◆ stationID

◆ tx

◆ ty

◆ x0

◆ y0


The documentation for this class was generated from the following files: