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

A generalized circle. More...

#include <GeneralizedCircle.h>

Collaboration diagram for GeneralizedCircle:

Public Member Functions

 GeneralizedCircle ()
 Default constructor for ROOT compatibility.
 
 GeneralizedCircle (double n0, double n1, double n2, double n3=0)
 Constructor with the four parameters of the generalized circle.
 
 GeneralizedCircle (double n0, const Vector2D &n12, double n3=0)
 Constructor with the four parameters of the generalized circle.
 
 GeneralizedCircle (const Line2D &n012)
 Constructor from a two dimensional line.
 
 GeneralizedCircle (const Circle2D &circle)
 Constructor from a two dimensional circle.
 
void setCenterAndRadius (const Vector2D &center, double absRadius, ERotation orientation=ERotation::c_CounterClockwise)
 Setter for the circle center and radius.
 
void setPerigeeParameters (double curvature, const Vector2D &tangential, double impact)
 Setter for the perigee parameters.
 
void setPerigeeParameters (const double curvature, const double tangentialPhi, const double impact)
 Setter for the perigee parameters.
 
void setN (const double n0, const double n1, const double n2, const double n3=0.0)
 Setter for all four circle parameters. More...
 
void setN (const double n0, const Vector2D &n12, const double n3=0.0)
 Setter for all four circle parameters. More...
 
void setN (const Line2D &n012)
 Setter for all four circle parameters from another circle.
 
void setN (const GeneralizedCircle &n0123)
 Setter for all four circle parameters from another circle.
 
void invalidate ()
 Sets all circle parameters to zero.
 
void reverse ()
 Flips the orientation of the circle in place.
 
void conformalTransform ()
 Transforms the generalized circle to conformal space inplace Applies the conformal map in the self-inverse form X = x / (x^2 + y^2) and Y = y / (x^2 +y^2) inplace It works most easily by the exchange of the circle parameters n0 <-> n3.
 
void passiveMoveBy (const Vector2D &by)
 Moves the coordinate system by the given vector. More...
 
double n0 () const
 Getter for the first circle parameter.
 
double n1 () const
 Getter for the second circle parameter.
 
double n2 () const
 Getter for the third circle parameter.
 
const Vector2Dn12 () const
 Getter for the second and third circle parameter which natuarally from a vector.
 
double n3 () const
 Getter for the fourth circle parameter.
 
bool isInvalid () const
 Indicates if all circle parameters are zero.
 
bool isValid () const
 Indicates if the combination of the circle parameters makes up a valid circle.
 
double normalizationSquared () const
 Calculates the generalized circle specific squared norm. More...
 
GeneralizedCircle reversed () const
 Returns a copy of the circle with opposite orientation.
 
GeneralizedCircle conformalTransformed () const
 Returns a copy of the circle in conformal space. More...
 
Vector2D gradient (const Vector2D &point) const
 Gradient of the distance field Gives the gradient of the approximated distance field for the given point. More...
 
Vector2D normal (const Vector2D &point) const
 Normal vector to the circle near the given position. More...
 
Vector2D tangential (const Vector2D &point) const
 Tangential vector to the circle near the given position. More...
 
Vector2D closest (const Vector2D &point) const
 Closest approach on the circle to the point. More...
 
Vector2D perigee () const
 Calculates the closest approach to the two dimensional origin.
 
Vector2D apogee () const
 Calculates the point on the circle that is furthest away from the origin. More...
 
EForwardBackward isForwardOrBackwardOf (const Vector2D &from, const Vector2D &to) const
 Calculates if the to vector is closer to the from vector following the along orientation of the circle or against. More...
 
Vector2D chooseNextForwardOf (const Vector2D &start, const Vector2D &end1, const Vector2D &end2) const
 Returns the end point which is first reached if one follows the forward direction of the circle starting from the start point. More...
 
std::pair< Belle2::TrackFindingCDC::Vector2D, Belle2::TrackFindingCDC::Vector2DatCylindricalR (double cylindricalR) const
 Calculates the two points with the given cylindrical radius on the generalised circle. More...
 
Vector2D atCylindricalRForwardOf (const Vector2D &startPoint, double cylindricalR) const
 Approach on the circle with the given cylindrical radius that lies in the forward direction of a start point. More...
 
double fastDistance (const Vector2D &point) const
 Approximate distance. More...
 
double fastImpact () const
 Approximate distance to the origin.
 
double distance (const Vector2D &point) const
 Gives the proper distance of the point to the circle line retaining the sign of the fast distance.
 
double distance (double fastDistance) const
 Helper function to translate the fast linearized distance measure of the generalized circle to the proper distance from the circle retaining the sign of the distance.
 
double fastDistance (const double distance) const
 Helper function to translate the proper distance to the linearized distance measure of the generalized circle retaining the sign of the distance.
 
double impact () const
 Gives the signed distance of the origin to the circle.
 
double d0 () const
 Getter for the absolute distance to the z axes at the support point.
 
Vector2D tangential () const
 Gives the tangential vector at the closest approach to the origin / at the perigee.
 
double tangentialPhi () const
 Gives to azimuth angle phi of the direction of flight at the perigee.
 
double minimalCylindricalR () const
 Gives the minimal cylindrical radius the circle reaches (unsigned)
 
double maximalCylindricalR () const
 Gives the maximal cylindrical radius the circle reaches.
 
double absDistance (const Vector2D &point) const
 Gives the proper absolute distance of the point to the circle line.
 
ERightLeft isRightOrLeft (const Vector2D &point) const
 Indicates if the point is on the right or left side of the circle. More...
 
bool isLeft (const Vector2D &rhs) const
 Return if the point given is left of the line.
 
bool isRight (const Vector2D &rhs) const
 Return if the point given is right of the line.
 
bool isLine () const
 Indicates if the generalized circle is actually a line.
 
bool isCircle () const
 Indicates if the generalized circle is actually a circle.
 
double radius () const
 Gives the signed radius of the circle. If it was a line this will be infinity.
 
double absRadius () const
 Gives the signed radius of the circle. If it was a line this will be infinity.
 
double curvature () const
 Gives the signed curvature of the generalized circle.
 
double omega () const
 Gives the omega parameter as used by the framework helix. More...
 
Vector2D center () const
 Gives the center of the circle. If it was a line both components will be infinity.
 
double perimeter () const
 Gives the perimeter of the circle.
 
ERotation orientation () const
 Gives the orientation of the circle. More...
 
double arcLengthPeriod () const
 Getter for the arc length for a full round of the circle.
 
double arcLengthBetween (const Vector2D &from, const Vector2D &to) const
 Calculates the arc length between two points of closest approach on the circle. More...
 
double arcLengthTo (const Vector2D &to) const
 Calculates the arc length between the perigee and the given point.
 
double arcLengthToCylindricalR (double cylindricalR) const
 Calculates the two dimensional arc length till the cylindrical radius is reached If the radius can not be reached return NAN. More...
 
double arcLengthFactor (const double directDistance) const
 Helper function the calculate the factor between the length of a secant line and the length on the arc. More...
 
std::pair< Vector2D, Vector2Dintersections (const GeneralizedCircle &generalizedCircle) const
 Calculates the two points common to both circles. More...
 
Vector2D atArcLength (double arcLength) const
 Calculates the point, which lies at the give perpendicular travel distance (counted from the perigee)
 

Static Public Member Functions

static GeneralizedCircle fromCenterAndRadius (const Vector2D &center, double absRadius, ERotation orientation=ERotation::c_CounterClockwise)
 Constructor from center, radius and a optional orientation. More...
 
static GeneralizedCircle fromPerigeeParameters (double curvature, const Vector2D &tangential, double impact)
 Constructor of a generalized circle from perigee parameters. More...
 
static GeneralizedCircle fromPerigeeParameters (double curvature, double tangentialPhi, double impact)
 Constructor of a generalized circle from perigee parameters. More...
 
static double arcLengthFactor (double directDistance, double curvature)
 Helper function the calculate the factor between the length of a secant line and the length on the arc. More...
 

Protected Member Functions

void setN0 (const double n0)
 Setter for first circle parameter. More...
 
void setN1 (const double n1)
 Setter for second circle parameter. More...
 
void setN2 (const double n2)
 Setter for third circle parameter. More...
 
void setN12 (const double n1, const double n2)
 Setter for second and third circle parameter. More...
 
void setN12 (const Vector2D &n12)
 Setter for second and third circle parameter. More...
 
void setN3 (const double n3)
 Setter for fourth circle parameter. More...
 
void normalize ()
 Normalizes the circle parameters. More...
 

Private Member Functions

void scaleN (const double factor)
 Scales the circle parameters by a common factor.
 

Private Attributes

double m_n3
 Memory for the fourth parameter.
 
Vector2D m_n12
 Memory for the second and third parameter.
 
double m_n0
 Memory for the first parameter.
 

Detailed Description

A generalized circle.

Makes a smooth generalization from a two dimensional normal line ( like Line2D ) to a circle.

The parameterisation is best suited for low curvature circle. The representation takes four parameters. They correspond to the normal circle parameters like
n0 = (m_x*m_x + m_y*m_y - r*r)/2r
n1 = -m_x/r
n2 = -m_y/r
n3 = 1/2r
where the normalization condtion is n1*n1 + n2*n2 - 4 * n0 * n3 = 1. The overall sign is fixed in the following way: If the last parameter is positiv the circle is assummed to be orientated counterclockwise else the circle is assummed to be orientated clockwise. The parameters n1 and n2 are indeed a vector in two dimensions and we keep them stored as Vector2D. Additionally we can represent a line with same parameters by setting n3 = 0. Compare Line2D.

Definition at line 51 of file GeneralizedCircle.h.

Member Function Documentation

◆ apogee()

Vector2D apogee ( ) const

Calculates the point on the circle that is furthest away from the origin.

This results in Vector2D(NAN, NAN) in the straight line case.

Definition at line 168 of file GeneralizedCircle.cc.

169 {
170  Vector2D result(n12());
171  result.setCylindricalR(-impact() - 2 * radius());
172  return result;
173 }
const Vector2D & n12() const
Getter for the second and third circle parameter which natuarally from a vector.
double radius() const
Gives the signed radius of the circle. If it was a line this will be infinity.
double impact() const
Gives the signed distance of the origin to the circle.
A two dimensional vector which is equipped with functions for correct handeling of orientation relat...
Definition: Vector2D.h:35

◆ arcLengthBetween()

double arcLengthBetween ( const Vector2D from,
const Vector2D to 
) const

Calculates the arc length between two points of closest approach on the circle.

The arc length is signed positiv for travel in orientation direction. In the circle case the arc length is between -pi*radius and pi*radius, hence the discontinuity is on the far side of the circle relative to the given from point. The points are essentially first taken to their closest approach before we take the length on the curve. For the line case the length is the distance component parallel to the line.

Definition at line 244 of file GeneralizedCircle.cc.

◆ arcLengthFactor() [1/2]

double arcLengthFactor ( const double  directDistance) const
inline

Helper function the calculate the factor between the length of a secant line and the length on the arc.

Smooth function expressing the relation between arc length and direct length only using the curvature of the circle as additional information. It enables better handling of the line limit compared to the former implementaiton which used the opening angle of the arc.

Definition at line 653 of file GeneralizedCircle.h.

654  {
655  return arcLengthFactor(directDistance, curvature());
656  }
double curvature() const
Gives the signed curvature of the generalized circle.
double arcLengthFactor(const double directDistance) const
Helper function the calculate the factor between the length of a secant line and the length on the ar...

◆ arcLengthFactor() [2/2]

double arcLengthFactor ( double  directDistance,
double  curvature 
)
static

Helper function the calculate the factor between the length of a secant line and the length on the arc.

Smooth function expressing the relation between arc length and direct length only using the curvature of the circle as additional information. It enables better handling of the line limit compared to the former implementaiton which used the opening angle of the arc.

Definition at line 290 of file GeneralizedCircle.cc.

◆ arcLengthToCylindricalR()

double arcLengthToCylindricalR ( double  cylindricalR) const

Calculates the two dimensional arc length till the cylindrical radius is reached If the radius can not be reached return NAN.

Note that there are two solutions which have equivalent arc lengths with different sign Always return the positive solution.

Definition at line 276 of file GeneralizedCircle.cc.

◆ atCylindricalR()

std::pair< Vector2D, Vector2D > atCylindricalR ( double  cylindricalR) const

Calculates the two points with the given cylindrical radius on the generalised circle.

Two versions in this case

Definition at line 209 of file GeneralizedCircle.cc.

◆ atCylindricalRForwardOf()

Vector2D atCylindricalRForwardOf ( const Vector2D startPoint,
double  cylindricalR 
) const

Approach on the circle with the given cylindrical radius that lies in the forward direction of a start point.

Calculates the point on the circle with cylindrical radius cylindricalR, which is closest following the circle in the direction of positive forward orientation This is particularly useful to extraplotate into a certain layer. In case no intersection with this cylindrical radius exists the function returns Vector2D(NAN,NAN)

Parameters
startPointStart point from which to follow in the circle in the forward direction
cylindricalRCylindrical radius of interest
Returns
Close point in forward direction with same cylindrical radius on the circle.

Definition at line 237 of file GeneralizedCircle.cc.

◆ chooseNextForwardOf()

Vector2D chooseNextForwardOf ( const Vector2D start,
const Vector2D end1,
const Vector2D end2 
) const

Returns the end point which is first reached if one follows the forward direction of the circle starting from the start point.

Evaluates which of the given end points end1 and end2 is closer to start This espicially treats the discontinuity on the far side of the circle correctly. If the generalized circle is truely a line none of the points might lie in the forward direction and Vector2D(NAN,NAN) is returned.

Parameters
startPoint to start the traversal
end1One possible end point
end2Other possible end point
Returns
end1 or end2 depending, which lies closer to start in the forward direction or Vector2D(NAN,NAN) if neither end1 nor end2 are reachable in the forward direction (line case only)

Definition at line 175 of file GeneralizedCircle.cc.

◆ closest()

Vector2D closest ( const Vector2D point) const

Closest approach on the circle to the point.

Calculates the closest point on the circle relative to the given point.

Parameters
pointPoint in the plane to calculate the closest approach to
Returns
Point of closest approach on the circle.

Definition at line 116 of file GeneralizedCircle.cc.

◆ conformalTransformed()

GeneralizedCircle conformalTransformed ( ) const
inline

Returns a copy of the circle in conformal space.

Applies the conformal map in the self-inverse from X = x / (x^2 + y^2) and Y = y / (x^2 +y^2) and returns the result as a new GeneralizedCircle. It works most easily by the exchange of the circle parameters n0 <-> n3

Definition at line 335 of file GeneralizedCircle.h.

◆ fastDistance()

double fastDistance ( const Vector2D point) const
inline

Approximate distance.

Gives a fast signed approximation of the distance to the circle. The absolute value of the fast distance is accurate up to first order of distance/circle radius, hence best used with big circles and small distances. The sign of the fast distance indicates if the point is to the right or to the left of the circle.

Definition at line 459 of file GeneralizedCircle.h.

◆ fromCenterAndRadius()

GeneralizedCircle fromCenterAndRadius ( const Vector2D center,
double  absRadius,
ERotation  orientation = ERotation::c_CounterClockwise 
)
static

Constructor from center, radius and a optional orientation.

The center and radius alone do not carry any orientation. However the generalized circle does. This constructor makes an orientated representation from them. If not given the orientation defaults to mathematical positiv counterclockwise.

Definition at line 67 of file GeneralizedCircle.cc.

◆ fromPerigeeParameters() [1/2]

GeneralizedCircle fromPerigeeParameters ( double  curvature,
const Vector2D tangential,
double  impact 
)
static

Constructor of a generalized circle from perigee parameters.

Tangential at perigee given as two dimensional vector.

Definition at line 76 of file GeneralizedCircle.cc.

◆ fromPerigeeParameters() [2/2]

GeneralizedCircle fromPerigeeParameters ( double  curvature,
double  tangentialPhi,
double  impact 
)
static

Constructor of a generalized circle from perigee parameters.

Tangential at perigee given as azimuth angle.

Definition at line 85 of file GeneralizedCircle.cc.

◆ gradient()

Vector2D gradient ( const Vector2D point) const
inline

Gradient of the distance field Gives the gradient of the approximated distance field for the given point.

Parameters
pointPoint in the plane to calculate the gradient
Returns
Gradient of the distance field

Definition at line 347 of file GeneralizedCircle.h.

◆ intersections()

std::pair< Vector2D, Vector2D > intersections ( const GeneralizedCircle generalizedCircle) const

Calculates the two points common to both circles.

If the two points coincide both returned points are the same. If there is no common point both returned points will be made of NAN.

Definition at line 322 of file GeneralizedCircle.cc.

◆ isForwardOrBackwardOf()

EForwardBackward isForwardOrBackwardOf ( const Vector2D from,
const Vector2D to 
) const
inline

Calculates if the to vector is closer to the from vector following the along orientation of the circle or against.

Returns
  • EForwardBackward::c_Forward in case the to vector is closer following the along the orientation
  • EForwardBackward::c_Backward in case the to vector is closer against the orientation.
  • EForwardBackward::c_Unknown if neither can be determined.

Definition at line 408 of file GeneralizedCircle.h.

◆ isRightOrLeft()

ERightLeft isRightOrLeft ( const Vector2D point) const
inline

Indicates if the point is on the right or left side of the circle.

This is also refered to as alpha.

Definition at line 538 of file GeneralizedCircle.h.

◆ normal()

Vector2D normal ( const Vector2D point) const
inline

Normal vector to the circle near the given position.

Gives the unit normal vector to the circle line. It points to the outside of the circle for counterclockwise orientation, and inwards for the clockwise orientation. It is essentially the gradient normalized to unit length

Parameters
pointPoint in the plane to calculate the tangential
Returns
Unit normal vector to the circle line

Definition at line 361 of file GeneralizedCircle.h.

◆ normalizationSquared()

double normalizationSquared ( ) const
inline

Calculates the generalized circle specific squared norm.

Correctly normalized this should give one.

Definition at line 315 of file GeneralizedCircle.h.

◆ normalize()

void normalize ( )
inlineprotected

Normalizes the circle parameters.

The normalization is only made if the circle parameters have a valid positiv norm. If the normalization of the cirlce is negativ or zero all circle parameters are not changed.

Definition at line 252 of file GeneralizedCircle.h.

◆ omega()

double omega ( ) const
inline

Gives the omega parameter as used by the framework helix.

It is the signed curvature of the generalized circle with the opposite sign.

Definition at line 589 of file GeneralizedCircle.h.

◆ orientation()

ERotation orientation ( ) const
inline

Gives the orientation of the circle.

The circle can be either orientated counterclockwise or clockwise.

Returns
ERotation::c_CounterClockwise for counterclockwise travel, ERotation::c_Clockwise for clockwise.

Definition at line 612 of file GeneralizedCircle.h.

◆ passiveMoveBy()

void passiveMoveBy ( const Vector2D by)
inline

Moves the coordinate system by the given vector.

Updates the circle parameters inplace.

Definition at line 239 of file GeneralizedCircle.h.

◆ setN() [1/2]

void setN ( const double  n0,
const double  n1,
const double  n2,
const double  n3 = 0.0 
)
inline

Setter for all four circle parameters.

Makes a normalization after setting. The normal representation of a line leave out the last parameter.

Definition at line 178 of file GeneralizedCircle.h.

◆ setN() [2/2]

void setN ( const double  n0,
const Vector2D n12,
const double  n3 = 0.0 
)
inline

Setter for all four circle parameters.

Makes a normalization after setting. The normal representation of a line leave out the last parameter.

Definition at line 191 of file GeneralizedCircle.h.

◆ setN0()

void setN0 ( const double  n0)
inlineprotected

Setter for first circle parameter.

Makes no normalization after setting. Use is discouraged.

Definition at line 102 of file GeneralizedCircle.h.

◆ setN1()

void setN1 ( const double  n1)
inlineprotected

Setter for second circle parameter.

Makes no normalization after setting. Use is discouraged.

Definition at line 112 of file GeneralizedCircle.h.

◆ setN12() [1/2]

void setN12 ( const double  n1,
const double  n2 
)
inlineprotected

Setter for second and third circle parameter.

Makes no normalization after setting. Use is discouraged.

Definition at line 132 of file GeneralizedCircle.h.

◆ setN12() [2/2]

void setN12 ( const Vector2D n12)
inlineprotected

Setter for second and third circle parameter.

Makes no normalization after setting. Use is discouraged.

Definition at line 142 of file GeneralizedCircle.h.

◆ setN2()

void setN2 ( const double  n2)
inlineprotected

Setter for third circle parameter.

Makes no normalization after setting. Use is discouraged.

Definition at line 122 of file GeneralizedCircle.h.

◆ setN3()

void setN3 ( const double  n3)
inlineprotected

Setter for fourth circle parameter.

Makes no normalization after setting. Use is discouraged.

Definition at line 152 of file GeneralizedCircle.h.

◆ tangential()

Vector2D tangential ( const Vector2D point) const
inline

Tangential vector to the circle near the given position.

Gives the unit tangential vector to the circle line. It always points in the direction of positiv advance at the point of closest approach from the given point.

Parameters
pointPoint in the plane to calculate the tangential
Returns
Unit tangential vector to the circle line

Definition at line 374 of file GeneralizedCircle.h.


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