|
ACTS
Experiment-independent tracking
|
Class to describe the bounds for a planar DiscSurface. More...
#include <Acts/Surfaces/RadialBounds.hpp>
Public Types | |
| enum | BoundValues { eMinR = 0 , eMaxR = 1 , eHalfPhiSector = 2 , eAveragePhi = 3 , eSize = 4 } |
| Enumeration for the bound values. More... | |
| Public Types inherited from Acts::SurfaceBounds | |
| enum | BoundsType : int { eCone = 0 , eCylinder = 1 , eDiamond = 2 , eDisc = 3 , eEllipse = 4 , eLine = 5 , eRectangle = 6 , eTrapezoid = 7 , eTriangle = 8 , eDiscTrapezoid = 9 , eConvexPolygon = 10 , eAnnulus = 11 , eBoundless = 12 , eOther = 13 } |
| This is nested to the SurfaceBounds, as also VolumeBounds will have Bounds Type. More... | |
Public Member Functions | |
| RadialBounds (const std::array< double, eSize > &values) noexcept(false) | |
| Constructor from array values. | |
| RadialBounds (double minR, double maxR, double halfPhi=std::numbers::pi, double avgPhi=0.) noexcept(false) | |
| Constructor for full disc of symmetric disc around phi=0. | |
| double | binningValuePhi () const final |
| Return a reference phi value for binning. | |
| double | binningValueR () const final |
| Return a reference radius for binning. | |
| SquareMatrix2 | boundToCartesianJacobian (const Vector2 &lposition) const final |
| Computes the bound to cartesian jacobian at a given local position. | |
| SquareMatrix2 | boundToCartesianMetric (const Vector2 &lposition) const final |
| Computes the bound to cartesian metric at a given local position. | |
| Vector2 | center () const final |
| Calculate the center of the surface bounds in local coordinates. | |
| Vector2 | closestPoint (const Vector2 &lposition, const SquareMatrix2 &metric) const final |
| Calculates the closest point on the bounds to a given local position. | |
| bool | coversFullAzimuth () const final |
| Returns true for full phi coverage. | |
| double | get (BoundValues bValue) const |
| Access to the bound values. | |
| bool | inside (const Vector2 &lposition) const final |
| Inside check for the bounds object. | |
| virtual bool | inside (const Vector2 &lposition, const BoundaryTolerance &boundaryTolerance) const |
| Inside check for the bounds object given a boundary tolerance. | |
| bool | insideRadialBounds (double R, double tolerance=0.) const final |
| Checks if this is inside the radial coverage given the a tolerance. | |
| bool | isCartesian () const final |
| Check if the bound coordinates are cartesian. | |
| double | rMax () const final |
| Return method for outer Radius. | |
| double | rMin () const final |
| Return method for inner Radius. | |
| std::ostream & | toStream (std::ostream &sl) const final |
| Outstream operator. | |
| BoundsType | type () const final |
| Return the bounds type - for persistency optimization. | |
| std::vector< double > | values () const final |
| Return the bound values as dynamically sized vector. | |
| Public Member Functions inherited from Acts::SurfaceBounds | |
| virtual | ~SurfaceBounds ()=default |
| virtual double | distance (const Vector2 &lposition) const |
| Calculates the distance to the bounds from a given local position. | |
Class to describe the bounds for a planar DiscSurface.
By providing an argument for hphisec, the bounds can be restricted to a phi-range around the center position.
|
explicit |
Constructor for full disc of symmetric disc around phi=0.
| minR | The inner radius (0 for full disc) |
| maxR | The outer radius |
| halfPhi | The half opening angle (Pi for full angular coverage) |
| avgPhi | The average phi for the disc/ring sector |
|
explicit |
Constructor from array values.
| values | The bound values |
|
finalvirtual |
Return a reference phi value for binning.
Implements Acts::DiscBounds.
|
finalvirtual |
Return a reference radius for binning.
Implements Acts::DiscBounds.
|
finalvirtual |
Computes the bound to cartesian jacobian at a given local position.
| lposition | is the local position at which the jacobian is computed |
Implements Acts::SurfaceBounds.
|
finalvirtual |
Computes the bound to cartesian metric at a given local position.
| lposition | is the local position at which the metric is computed |
Implements Acts::SurfaceBounds.
|
finalvirtual |
Calculate the center of the surface bounds in local coordinates.
This method returns a representative center point of the bounds region. The exact definition varies by bounds type and coordinate system:
Cartesian bounds (Rectangle, Diamond, Trapezoid):
Polar/Cylindrical bounds (Radial, Cylinder, Cone):
Complex bounds (Annulus, ConvexPolygon):
Infinite bounds: Returns conceptual center at (0,0)
Implements Acts::SurfaceBounds.
|
finalvirtual |
Calculates the closest point on the bounds to a given local position.
| lposition | is the local position |
| metric | to be used for the distance calculation |
Implements Acts::SurfaceBounds.
|
finalvirtual |
Returns true for full phi coverage.
Implements Acts::DiscBounds.
| double Acts::RadialBounds::get | ( | BoundValues | bValue | ) | const |
Access to the bound values.
| bValue | the class nested enum for the array access |
|
finalvirtual |
Inside check for the bounds object.
| lposition | is the local position |
Implements Acts::SurfaceBounds.
|
virtual |
Inside check for the bounds object given a boundary tolerance.
| lposition | is the local position |
| boundaryTolerance | is the boundary tolerance object |
Reimplemented from Acts::SurfaceBounds.
|
finalvirtual |
Checks if this is inside the radial coverage given the a tolerance.
| R | Radius value to check |
| tolerance | Tolerance for the boundary check |
Implements Acts::DiscBounds.
|
finalvirtual |
Check if the bound coordinates are cartesian.
Implements Acts::SurfaceBounds.
|
finalvirtual |
Return method for outer Radius.
Implements Acts::DiscBounds.
|
finalvirtual |
Return method for inner Radius.
Implements Acts::DiscBounds.
|
finalvirtual |
Outstream operator.
| sl | is the ostream to be dumped into |
Implements Acts::SurfaceBounds.
|
finalvirtual |
Return the bounds type - for persistency optimization.
Implements Acts::SurfaceBounds.
|
finalvirtual |
Return the bound values as dynamically sized vector.
Implements Acts::SurfaceBounds.