5 #include <phfield/PHField.h>
27 if (ret != 0)
return ret;
41 _timers[
"global_st1"]->restart();
53 for(
int i = 0; i <= 4; i++)
55 std::cout <<
"=======================================================================================" << std::endl;
61 std::cout <<
"=======================================================================================" << std::endl;
71 int sID = stationID - 1;
74 std::list<SRawEvent::hit_pair> pairs_X, pairs_U, pairs_V;
75 if(pos_exp ==
nullptr)
89 if(pairs_X.empty() || pairs_U.empty() || pairs_V.empty())
return;
92 for(std::list<SRawEvent::hit_pair>::iterator xiter = pairs_X.begin(); xiter != pairs_X.end(); ++xiter)
94 bool has_x_2nd = xiter->second >= 0;
95 double x_pos = has_x_2nd ? 0.5*(
hitAll[xiter->first].pos +
hitAll[xiter->second].pos) :
hitAll[xiter->first].pos;
97 double u_max = u_min + 2.*
u_win[sID];
99 for(std::list<SRawEvent::hit_pair>::iterator uiter = pairs_U.begin(); uiter != pairs_U.end(); ++uiter)
101 bool has_u_2nd = uiter->second >= 0;
102 double u_pos = has_u_2nd ? 0.5*(
hitAll[uiter->first].pos +
hitAll[uiter->second].pos) :
hitAll[uiter->first].pos;
103 if(u_pos < u_min || u_pos > u_max)
continue;
110 double v_win2 = fabs((z_u + z_v - 2.*z_x)*
u_costheta[sID]*TX_MAX);
111 double v_win3 = fabs((z_v - z_u)*
u_sintheta[sID]*TY_MAX);
112 double v_win = v_win1 + v_win2 + v_win3 + 2.*
spacing_plane[
hitAll[uiter->first].detectorID];
113 double v_min = 2*x_pos*
u_costheta[sID] - u_pos - v_win;
114 double v_max = v_min + 2.*v_win;
116 for(std::list<SRawEvent::hit_pair>::iterator viter = pairs_V.begin(); viter != pairs_V.end(); ++viter)
118 bool has_v_2nd = viter->second >= 0;
119 double v_pos = has_v_2nd ? 0.5*(
hitAll[viter->first].pos +
hitAll[viter->second].pos) :
hitAll[viter->first].pos;
120 if(v_pos < v_min || v_pos > v_max)
continue;
123 for (
int LR_X1 = -1 ; LR_X1 <= +1; LR_X1 += 2) {
124 for (
int LR_X2 = (has_x_2nd ? -1 : +1); LR_X2 <= +1; LR_X2 += 2) {
125 for (
int LR_U1 = -1 ; LR_U1 <= +1; LR_U1 += 2) {
126 for (
int LR_U2 = (has_u_2nd ? -1 : +1); LR_U2 <= +1; LR_U2 += 2) {
127 for (
int LR_V1 = -1 ; LR_V1 <= +1; LR_V1 += 2) {
128 for (
int LR_V2 = (has_v_2nd ? -1 : +1); LR_V2 <= +1; LR_V2 += 2) {
157 if(tracklet_new.
isValid() == 0) {
168 iter->addDummyHits();
std::list< Tracklet > trackletsInSt[5]
double u_sintheta[nChamberPlanes/6]
double u_costheta[nChamberPlanes/6]
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)
int fitTracklet(Tracklet &tracklet)
virtual void buildBackPartialTracks()
double spacing_plane[nChamberPlanes+1]
std::vector< Hit > hitAll
double z_plane_x[nChamberPlanes/6]
double z_plane_u[nChamberPlanes/6]
std::map< std::string, PHTimer * > _timers
double u_win[nChamberPlanes/6]
double z_plane_v[nChamberPlanes/6]
virtual void buildTrackletsInStation(int stationID, int listID, double *pos_exp=nullptr, double *window=nullptr)
Tracklet finding stuff.
virtual int setRawEvent(SRawEvent *event_input)
KalmanFastTrackletting(const PHField *field, const TGeoManager *geom, bool flag=true, const int verb=0)
virtual ~KalmanFastTrackletting()
transient DST object for field storage and access
virtual double get_DoubleFlag(const std::string &name) const
std::list< SRawEvent::hit_pair > getPartialHitPairsInSuperDetector(Short_t detectorID)
std::list< SignedHit > hits
int isValid() const
isValid returns non zero if object contains vailid data
static recoConsts * instance()