9 #include <tracking/trackFindingCDC/eventdata/hits/CDCRecoHit3D.h>
10 #include <tracking/trackFindingCDC/hough/boxes/Z0TanLambdaBox.h>
11 #include <tracking/trackFindingCDC/hough/baseelements/SameSignChecker.h>
18 namespace TrackFindingCDC {
45 float reconstructedZ = recoHit.
getRecoZ();
47 float distLowerZ0LowerTanLambda = perpS * lowerTanLambda - reconstructedZ + lowerZ0;
48 float distUpperZ0LowerTanLambda = perpS * lowerTanLambda - reconstructedZ + upperZ0;
49 float distLowerZ0UpperTanLambda = perpS * upperTanLambda - reconstructedZ + lowerZ0;
50 float distUpperZ0UpperTanLambda = perpS * upperTanLambda - reconstructedZ + upperZ0;
53 distLowerZ0UpperTanLambda, distUpperZ0UpperTanLambda);
70 const double lhsZ = lhsRecoHit.
getRecoZ();
71 const double rhsZ = rhsRecoHit.
getRecoZ();
76 const double lhsZDistance = lhsS * tanLambdaMean + z0Mean - lhsZ;
77 const double rhsZDistance = rhsS * tanLambdaMean + z0Mean - rhsZ;
79 return lhsZDistance < rhsZDistance;
83 static const char*
debugLine() {
return "[0] + [1] * x";}
Class representing a three dimensional reconstructed hit.
double getRecoZ() const
Getter for the z coordinate of the reconstructed position.
double getArcLength2D() const
Getter for the travel distance in the xy projection.
Predicate class to check for the containment of hits in a z0 tan lambda hough space part.
Weight operator()(const CDCRecoHit3D &recoHit, const HoughBox *z0TanLambdaBox)
Checks if the wire hit is contained in a z0 tan lambda hough space.
static bool compareDistances(const HoughBox &z0TanLambdaBox, const CDCRecoHit3D &lhsRecoHit, const CDCRecoHit3D &rhsRecoHit)
Compares distances from two hits to the track represented by the given box.
static const char * debugLine()
ROOT-compatible formula for z(s) = z0 + tanlambda * s.
static bool sameSign(double n1, double n2)
Check if two values have the same sign.
A rectangular domain for the hough space over phi0 and two dimensional curvature.
float getLowerTanLambda() const
Concise getter for the lower tan lambda bound.
float getUpperZ0() const
Concise getter for the upper z0 bound.
float getLowerZ0() const
Concise getter for the lower z0 bound.
float getUpperTanLambda() const
Concise getter for the upper tan lambda bound.
Abstract base class for different kinds of events.