10#include <tracking/trackFindingCDC/hough/boxes/Box.h>
11#include <tracking/trackFindingCDC/topology/ILayer.h>
21 namespace TrackFindingCDC {
53 const std::array<DiscretePhi0, 2>& phi0Vec = houghBox.getBounds<
DiscretePhi0>();
54 const std::array<ContinuousImpact, 2>& impact = houghBox.getBounds<
ContinuousImpact>();
56 std::array<float, 2> xRot;
57 xRot[0] = x * phi0Vec[0]->x() + y * phi0Vec[0]->y();
58 xRot[1] = x * phi0Vec[1]->x() + y * phi0Vec[1]->y();
61 if (onlyPositiveArm) {
63 if (xRot[0] < 0 and xRot[1] < 0)
return ESign::c_Invalid;
66 std::array<float, 2> yRotPlusL;
67 yRotPlusL[0] = -x * phi0Vec[0]->y() + y * phi0Vec[0]->x() + l;
68 yRotPlusL[1] = -x * phi0Vec[1]->y() + y * phi0Vec[1]->x() + l;
71 std::array<float, 4> dist;
72 dist[0b00] = yRotPlusL[0] -
static_cast<float>(impact[0]);
73 dist[0b10] = yRotPlusL[1] -
static_cast<float>(impact[0]);
74 dist[0b01] = yRotPlusL[0] -
static_cast<float>(impact[1]);
75 dist[0b11] = yRotPlusL[1] -
static_cast<float>(impact[1]);
The base class for all boxes.
Type to have values not based on discrete positions from an array.
Representation for a discrete position in an array of discrete positions.
Checker if a position is contained in a family of curves over phi0 and impact.
float m_curlCurv
Curler curvature - set to value greater zero to activate one arm exclusive finding.
ESign getDistanceSign(const HoughBox &houghBox, float x, float y, float l, float=0, float=0, ILayer=-1) const
Function that gives the sign of the distance from an observed drift circle to the family of curves.
InPhi0ImpactBox(float curlCurv=NAN)
Constructor taking the curler curvature - give a zero greater 0 to activate one arm exclusive finding...
ESign
Enumeration for the distinct sign values of floating point variables.
static ESign common(ESign n1, ESign n2)
Check if two values have a common sign.
Abstract base class for different kinds of events.