Belle II Software  release-08-01-10
HitInZ0TanLambdaBox Class Reference

Predicate class to check for the containment of hits in a z0 tan lambda hough space part. More...

#include <HitInZ0TanLambdaBox.h>

Public Types

using HoughBox = Z0TanLambdaBox
 Use a Z0TanLambdaBox.
 

Public Member Functions

Weight operator() (const CDCRecoHit3D &recoHit, const HoughBox *z0TanLambdaBox)
 Checks if the wire hit is contained in a z0 tan lambda hough space. More...
 

Static Public Member Functions

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. More...
 
static const char * debugLine ()
 ROOT-compatible formula for z(s) = z0 + tanlambda * s.
 

Detailed Description

Predicate class to check for the containment of hits in a z0 tan lambda hough space part.

Note this part this code defines the performance of the search in the hough plain quite significantly and there is probably room for improvement.

Definition at line 25 of file HitInZ0TanLambdaBox.h.

Member Function Documentation

◆ compareDistances()

static bool compareDistances ( const HoughBox z0TanLambdaBox,
const CDCRecoHit3D lhsRecoHit,
const CDCRecoHit3D rhsRecoHit 
)
inlinestatic

Compares distances from two hits to the track represented by the given box.

The comparison is done based on reconstructed Z coordinates of hits and track Z position.

Definition at line 65 of file HitInZ0TanLambdaBox.h.

66  {
67  const double z0Mean = (z0TanLambdaBox.getLowerZ0() + z0TanLambdaBox.getUpperZ0()) / 2.0;
68  const double tanLambdaMean = (z0TanLambdaBox.getLowerTanLambda() + z0TanLambdaBox.getUpperTanLambda()) / 2.0;
69 
70  const double lhsZ = lhsRecoHit.getRecoZ();
71  const double rhsZ = rhsRecoHit.getRecoZ();
72 
73  const double lhsS = lhsRecoHit.getArcLength2D();
74  const double rhsS = rhsRecoHit.getArcLength2D();
75 
76  const double lhsZDistance = lhsS * tanLambdaMean + z0Mean - lhsZ;
77  const double rhsZDistance = rhsS * tanLambdaMean + z0Mean - rhsZ;
78 
79  return lhsZDistance < rhsZDistance;
80  }

◆ operator()()

Weight operator() ( const CDCRecoHit3D recoHit,
const HoughBox z0TanLambdaBox 
)
inline

Checks if the wire hit is contained in a z0 tan lambda hough space.

Returns 1.0 if it is contained, returns NAN if it is not contained.

Definition at line 35 of file HitInZ0TanLambdaBox.h.


The documentation for this class was generated from the following file: