9 bool IsHodoX(
const std::string det_name)
11 return det_name.length() >= 3 && (det_name[2] ==
'T' || det_name[2] ==
'B');
29 int GetPlanePos(
const int det,
double& x,
double& y,
double& z)
38 int GetElementPos(
const int det,
const int ele,
double& x,
double& y,
double& z)
50 Track1D::Track1D(
const XY_t xy) : type_xy(xy), chi2(0), pos(0), slope(0), ndf(0)
59 for (
unsigned int ih = 0; ih <
list_hit.size(); ih++) {
60 short det =
list_hit[ih]->get_detector_id();
61 short ele =
list_hit[ih]->get_element_id();
62 double x_ele, y_ele, z_ele;
65 else graph.SetPoint(ih, z_ele, y_ele);
67 graph.Fit(
"pol1",
"Q0");
68 TF1* f1 =
graph.GetFunction(
"pol1");
69 chi2 = f1->GetChisquare();
71 pos = f1->GetParameter(0);
72 slope = f1->GetParameter(1);
User interface class about the geometry of detector planes.
static GeomSvc * instance()
singlton instance
double getPlaneCenterY(int detectorID) const
double getPlaneCenterX(int detectorID) const
double getPlaneCenterZ(int detectorID) const
int getPlaneNElements(int detectorID) const
double getPlaneSpacing(int detectorID) const
An SQ interface class to hold one detector hit.
virtual short get_detector_id() const
Return the detector ID of this hit.
int GetPlanePos(const int det, double &x, double &y, double &z)
bool IsHodoX(const int det_id)
bool IsHodoX(const std::string det_name)
int GetElementPos(const int det, const int ele, double &x, double &y, double &z)
bool IsHodoY(const int det_id)
TVector3 GetPos(const double z)