42 TMatrixT<Double_t> returnMat(2,1);
44 checkPlane(hit, plane);
49 returnMat[0][0] = rC[6][0];
50 returnMat[1][0] = rC[7][0];
57 checkPlane(hit, plane);
59 TMatrixT<Double_t> returnCov(2,2);
62 returnCov[0][0] = rawCov[6][6];
63 returnCov[1][0] = rawCov[7][6];
64 returnCov[0][1] = rawCov[6][7];
65 returnCov[1][1] = rawCov[7][7];
77 assert(rC.GetNrows()==8);
79 TVector3 wire1(rC[0][0], rC[1][0], rC[2][0]);
80 TVector3 wire2(rC[3][0], rC[4][0], rC[5][0]);
81 TVector3 wiredirection = wire1 - wire2;
83 TVector3 vaxis = plane.
getV();
84 wiredirection.SetMag(1.);
87 if(fabs(TMath::Abs(wiredirection.Dot(vaxis)) - 1) > 1
e-3)
90 std::cout <<
"GFWirepointHitPolicy: plane not valid!!" << std::endl;
100 assert(x.GetNrows()==8);
101 TVector3 wire1(x[0][0],x[1][0],x[2][0]);
102 TVector3 wire2(x[3][0],x[4][0],x[5][0]);
105 Double_t d_from_refplane = fDetPlane.dist(wire1).Mag();
106 if(d_from_refplane < 1
e-5)
return fDetPlane;
110 TVector3 poca, poca_onwire, dirInPoca;
116 distance =
TMath::Sqrt(fabs(((wire1-poca).Mag2()*(wire2-wire1).Mag2()-pow((wire1-poca).Dot(wire2-wire1),2))/(wire2-wire1).Mag2()));
119 if(distance > fMaxdistance) {
120 throw GFException(
"distance poca-wire > maxdistance", __LINE__,__FILE__);
126 TVector3 fromwiretoextr = poca - poca_onwire;
127 fromwiretoextr.SetMag(1.);
129 TVector3 wiredirection = wire2 - wire1;
130 wiredirection.SetMag(1.);
133 if(fabs(fromwiretoextr * wiredirection) > 1
e-3) {
134 throw GFException(
"fromwiretoextr*wiredirection > 1e-3", __LINE__,__FILE__);
144 TVector3
O = (wire1 + wire2) * 0.5;
virtual void extrapolateToLine(const TVector3 &point1, const TVector3 &point2, TVector3 &poca, TVector3 &normVec, TVector3 &poca_onwire)
This method extrapolates to the point of closest approach to a line.
const GFDetPlane & detPlane(GFAbsRecoHit *, GFAbsTrackRep *)
Get detector plane.
process_name opflash particleana ie x
TMatrixT< Double_t > getRawHitCoord() const
Get raw hit coordinates.
TMatrixT< Double_t > hitCov(GFAbsRecoHit *, const GFDetPlane &)
Hit covariances in detector plane.
Base Class for genfit track representations. Defines interface for track parameterizations.
double distance(geo::Point_t const &point, CathodeDesc_t const &cathode)
Returns the distance of a point from the cathode.
TMatrixT< Double_t > hitCoord(GFAbsRecoHit *, const GFDetPlane &)
Hit coordinates in detector plane.
static const std::string fPolicyName
Exception class for error handling in GENFIT (provides storage for diagnostic information) ...
Var Sqrt(const Var &v)
Use to take sqrt of a var.
void checkPlane(GFAbsRecoHit *, const GFDetPlane &)
Check if the detector plane is valid.
TMatrixT< Double_t > getRawHitCov() const
Get raw hit covariances.
BEGIN_PROLOG could also be cout