Back to home page

EIC code displayed by LXR

 
 

    


File indexing completed on 2025-01-18 09:11:03

0001 // This file is part of the ACTS project.
0002 //
0003 // Copyright (C) 2016 CERN for the benefit of the ACTS project
0004 //
0005 // This Source Code Form is subject to the terms of the Mozilla Public
0006 // License, v. 2.0. If a copy of the MPL was not distributed with this
0007 // file, You can obtain one at https://mozilla.org/MPL/2.0/.
0008 
0009 #pragma once
0010 
0011 #include "Acts/Definitions/Algebra.hpp"
0012 #include "Acts/Utilities/Intersection.hpp"
0013 
0014 #include <array>
0015 
0016 namespace Acts::detail {
0017 
0018 struct IntersectionHelper2D {
0019   /// Intersect two segments
0020   ///
0021   /// @param s0 The Start of the segment
0022   /// @param s1 The end of the segment
0023   /// @param origin The Start of intersection line
0024   /// @param dir The Direction of intersection line
0025   ///
0026   /// @return the intersection point with status
0027   static Intersection2D intersectSegment(const Vector2& s0, const Vector2& s1,
0028                                          const Vector2& origin,
0029                                          const Vector2& dir,
0030                                          bool boundCheck = false);
0031 
0032   /// Intersect ellipses
0033   ///
0034   /// @param Rx The radius in x
0035   /// @param Ry The radius in y
0036   /// @param origin The Start of intersection line
0037   /// @param dir The Direction of intersection line
0038   ///
0039   /// @return the intersection points
0040   static std::array<Intersection2D, 2> intersectEllipse(double Rx, double Ry,
0041                                                         const Vector2& origin,
0042                                                         const Vector2& dir);
0043 
0044   /// Intersect the circle
0045   ///
0046   /// @param R The radius
0047   /// @param origin The Start of intersection line
0048   /// @param dir The Direction of intersection line
0049   ///
0050   /// @return the intersection points
0051   static inline std::array<Intersection2D, 2> intersectCircle(
0052       double R, const Vector2& origin, const Vector2& dir) {
0053     return intersectEllipse(R, R, origin, dir);
0054   }
0055 
0056   /// Intersect a circle segment
0057   ///
0058   /// @note only forward solution is taken
0059   ///
0060   /// @param R The radius
0061   /// @param phiMin The minimum phi value
0062   /// @param phiMax The maximum phi value
0063   /// @param origin The Start of intersection line
0064   /// @param dir The Direction of intersection line
0065   ///
0066   /// @return the intersection points
0067   static Intersection2D intersectCircleSegment(double R, double phiMin,
0068                                                double phiMax,
0069                                                const Vector2& origin,
0070                                                const Vector2& dir);
0071 
0072 };  // struct IntersectionHelper2D
0073 
0074 }  // namespace Acts::detail