10 #ifndef _KALMANFASTTRACKING_H
11 #define _KALMANFASTTRACKING_H
20 #include <Math/Factory.h>
21 #include <Math/Minimizer.h>
22 #include <Math/Functor.h>
55 virtual void buildTrackletsInStation(
int stationID,
int listID,
double* pos_exp =
nullptr,
double* window =
nullptr);
118 void chi2fit(
int n,
double x[],
double y[],
double& a,
double& b);
User interface class about the geometry of detector planes.
bool acceptEvent(SRawEvent *rawEvent)
std::list< SRecTrack > & getSRecTracks()
std::list< Tracklet > trackletsInSt[5]
void setRawEventDebug(SRawEvent *event_input)
std::vector< int > detectorIDs_maskY[4]
double costheta_plane[nChamberPlanes+1]
unsigned int outputListIdx
double u_sintheta[nChamberPlanes/6]
double u_costheta[nChamberPlanes/6]
double z_mask[nHodoPlanes+nPropPlanes]
std::list< SRecTrack > stracks
void removeBadHits(Tracklet &tracklet)
std::vector< int > stationIDs_mask[nStations]
bool hodoMask(Tracklet &tracklet)
std::vector< int > superIDs[nChamberPlanes/6+2]
For following part, id = 0, 1, 2, 3, 4, 5, 6 stand for station 0, 1, 2, 3+, 3-, and prop tubes X-Z an...
double z_plane[nChamberPlanes+1]
int setRawEventPrep(SRawEvent *event_input)
void getExtrapoWindowsInSt1(Tracklet &tracklet, double *pos_exp, double *window, int st1ID)
void setOutputListIndex(unsigned int i)
Set the index of the final output tracklet list.
void resolveLeftRight(SRawEvent::hit_pair hpair, int &LR1, int &LR2)
virtual ~KalmanFastTracking()
bool acceptTracklet(Tracklet &tracklet)
std::list< Tracklet > & getTrackletList(int i)
double intersection_max[nChamberPlanes+1]
void chi2fit(int n, double x[], double y[], double &a, double &b)
Tool, a simple-minded chi square fit.
virtual void buildTrackletsInStation(int stationID, int listID, double *pos_exp=nullptr, double *window=nullptr)
Tracklet finding stuff.
int fitTracklet(Tracklet &tracklet)
virtual void buildGlobalTracks()
virtual void buildBackPartialTracks()
KalmanFastTracking(const PHField *field, const TGeoManager *geom, bool flag=true, const int verb=0)
double slope_max[nChamberPlanes+1]
std::list< Tracklet > & getFinalTracklets()
Final output.
void Verbosity(const int a)
int reduceTrackletList(std::list< Tracklet > &tracklets)
int detectorIDs_muid[2][4]
std::list< PropSegment > & getPropSegments(int i)
bool muonID_comp(Tracklet &tracklet)
double spacing_plane[nChamberPlanes+1]
void getSagittaWindowsInSt1(Tracklet &tracklet, double *pos_exp, double *window, int st1ID)
std::vector< int > detectorIDs_mask[4]
Configurations of tracklet finding.
double resol_plane[nChamberPlanes+1]
std::vector< int > detectorIDs_muidHodoAid[2]
std::list< int > hitIDs_mask[4]
std::vector< Hit > hitAll
double z_plane_x[nChamberPlanes/6]
bool muonID_hodoAid(Tracklet &tracklet)
double z_plane_u[nChamberPlanes/6]
SRecTrack processOneTracklet(Tracklet &tracklet)
Track fitting stuff.
void resolveSingleLeftRight(Tracklet &tracklet)
std::vector< int > detectorIDs_maskX[4]
std::map< std::string, PHTimer * > _timers
double y_mask_max[nHodoPlanes+nPropPlanes][72]
double x_mask_min[nHodoPlanes+nPropPlanes][72]
void printAtDetectorBack(int stationID, std::string outputFileName)
virtual int setRawEvent(SRawEvent *event_input)
bool fitTrack(KalmanTrack &kmtrk)
double x_mask_max[nHodoPlanes+nPropPlanes][72]
double u_win[nChamberPlanes/6]
bool muonID_search(Tracklet &tracklet)
std::list< PropSegment > propSegs[2]
std::list< int > hitIDs_muidHodoAid[2]
double y_mask_min[nHodoPlanes+nPropPlanes][72]
std::list< int > hitIDs_muid[2][4]
std::list< Tracklet > & getBackPartials()
double sintheta_plane[nChamberPlanes+1]
SQTrackletFitter * trackletFitter
double z_plane_v[nChamberPlanes/6]
transient DST object for field storage and access
std::pair< Int_t, Int_t > hit_pair
Type of pair with two adjacent wires.