ATLAS Offline Software
SolenoidalIntersector.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2023 CERN for the benefit of the ATLAS collaboration
3 */
4 
6 // SolenoidalIntersector.cxx, (c) ATLAS Detector software
8 
9 #include "GaudiKernel/SystemOfUnits.h"
17 #include "TrkSurfaces/Surface.h"
18 
19 namespace Trk
20 {
21 
23  const TrackSurfaceIntersection& trackTrackSurfaceIntersection,
24  const double qOverP)
25  : m_sinTheta (trackTrackSurfaceIntersection.direction().perp()),
26  m_oneOverSinTheta (1./m_sinTheta),
27  m_cotTheta (trackTrackSurfaceIntersection.direction().z() * m_oneOverSinTheta),
28  m_qOverPt (qOverP * m_oneOverSinTheta),
29  m_solPar (solpar),
30  m_lastPosition (trackTrackSurfaceIntersection.position()),
31  m_solParams (solpar,
32  trackTrackSurfaceIntersection.position().perp(),
33  trackTrackSurfaceIntersection.position().z(),
34  m_cotTheta)
35 {
36 }
37 
39  const std::string& name,
40  const IInterface* parent)
41  : base_class(type, name, parent),
43  "Trk::RungeKuttaIntersector/RungeKuttaIntersector", this),
44  m_deltaPhiTolerance(0.01), // upper limit for small angle approx
48  declareProperty("RungeKuttaIntersector", m_rungeKuttaIntersector);
49  declareProperty("SurfaceTolerance", m_surfaceTolerance);
50 }
51 
54 {
57  return StatusCode::SUCCESS;
58 }
59 
62 {
63  ATH_MSG_DEBUG( "finalized after " << m_countExtrapolations << " extrapolations with "
64  << m_countRKSwitches << " switches to RK integration");
65 
66  return StatusCode::SUCCESS;
67 }
68 
69 
71 std::optional<Trk::TrackSurfaceIntersection>
73  const TrackSurfaceIntersection& trackIntersection,
74  const double qOverP) const
75 {
76 
77  const auto surfaceType = surface.type();
78  if (surfaceType == Trk::SurfaceType::Plane) {
79  return intersectPlaneSurface(static_cast<const PlaneSurface&>(surface),
80  trackIntersection, qOverP);
81  }
82  if (surfaceType == Trk::SurfaceType::Line) {
83  return m_rungeKuttaIntersector->approachStraightLineSurface(
84  static_cast<const StraightLineSurface&>(surface), trackIntersection,
85  qOverP);
86  }
87  if (surfaceType == Trk::SurfaceType::Cylinder) {
89  static_cast<const CylinderSurface&>(surface), trackIntersection,
90  qOverP);
91  }
92  if (surfaceType == Trk::SurfaceType::Disc) {
93  return intersectDiscSurface(static_cast<const DiscSurface&>(surface),
94  trackIntersection, qOverP);
95  }
96  if (surfaceType == Trk::SurfaceType::Perigee) {
97  return m_rungeKuttaIntersector->approachPerigeeSurface(
98  static_cast<const PerigeeSurface&>(surface), trackIntersection,
99  qOverP);
100  }
101 
102  ATH_MSG_WARNING( " unrecognized Surface" );
103  return std::nullopt;
104 }
105 
107 std::optional<Trk::TrackSurfaceIntersection>
109  const TrackSurfaceIntersection& trackIntersection,
110  const double qOverP) const
111 { return m_rungeKuttaIntersector->approachPerigeeSurface(surface, trackIntersection, qOverP); }
112 
114 std::optional<Trk::TrackSurfaceIntersection>
116  const TrackSurfaceIntersection& trackIntersection,
117  const double qOverP) const
118 { return m_rungeKuttaIntersector->approachStraightLineSurface(surface, trackIntersection, qOverP); }
119 
121 std::optional<Trk::TrackSurfaceIntersection>
123  const TrackSurfaceIntersection& trackIntersection,
124  const double qOverP) const
125 {
126  const SolenoidParametrization* solenoidParametrization =
128 
129  double endRadius = surface.globalReferencePoint().perp();
130  if (!solenoidParametrization || endRadius > solenoidParametrization->maximumR())
131  return m_rungeKuttaIntersector->intersectCylinderSurface(surface, trackIntersection, qOverP);
132 
133  Constants* com = nullptr;
134  std::optional<TrackSurfaceIntersection> isect = newIntersection(
135  trackIntersection, *solenoidParametrization, qOverP, com);
137 
138  double radius2 = isect->position().perp2();
139  if (std::abs(endRadius - sqrt(radius2)) > m_surfaceTolerance
140  && ! extrapolateToR(*isect, radius2, *com, endRadius)) return std::nullopt;
141 
142  return intersection(std::move(*isect), *com, surface);
143 }
144 
146 std::optional<Trk::TrackSurfaceIntersection>
148  const TrackSurfaceIntersection& trackIntersection,
149  const double qOverP) const
150 {
151  const SolenoidParametrization* solenoidParametrization =
153 
154  double endZ = surface.center().z();
155  if (!solenoidParametrization || std::abs(endZ) > solenoidParametrization->maximumZ())
156  return m_rungeKuttaIntersector->intersectDiscSurface(surface, trackIntersection, qOverP);
157 
158  Constants* com = nullptr;
159  std::optional<TrackSurfaceIntersection> isect =
160  newIntersection (trackIntersection,
161  *solenoidParametrization,
162  qOverP,
163  com);
164 
166 
167  if (std::abs(endZ -trackIntersection.position().z()) > m_surfaceTolerance
168  && ! extrapolateToZ(*isect, *com, endZ))
169  {
170  return std::nullopt;
171  }
172 
173  return intersection(std::move(*isect), *com, surface);
174 }
175 
177 std::optional<Trk::TrackSurfaceIntersection>
179  const TrackSurfaceIntersection& trackIntersection,
180  const double qOverP) const
181 {
182  const SolenoidParametrization* solenoidParametrization =
184 
185  if (!solenoidParametrization ||
186  std::abs(surface.center().z()) > solenoidParametrization->maximumZ()
187  || surface.center().perp() > solenoidParametrization->maximumR())
188  return m_rungeKuttaIntersector->intersectPlaneSurface(surface, trackIntersection, qOverP);
189 
190  Constants* com = nullptr;
191  std::optional<TrackSurfaceIntersection> isect =
192  newIntersection (trackIntersection,
193  *solenoidParametrization,
194  qOverP,
195  com);
196  Amg::Vector3D& pos = isect->position();
197  Amg::Vector3D& dir = isect->direction();
199  double radius2 = pos.perp2();
200 
201  // step until sufficiently near to plane surface
202  // this gives wrong answer!
203  // DistanceSolution solution = surface.straightLineDistanceEstimate(pos,dir);
204  // if (! solution.signedDistance()) return 0;
205  // double distance = solution.currentDistance(true);
206 
207  int numberSteps = 0;
208  double dot = surface.normal().dot(dir);
209  double offset = surface.normal().dot(surface.center() - pos);
210 
211  while (std::abs(offset) > m_surfaceTolerance * std::abs(dot)) {
212  // take care if grazing incidence - quit if looper
213  if (std::abs(dot) < 0.0001)
214  return std::nullopt;
215  double distance = offset / dot;
216 
217  // extrapolate
218  if (com->m_sinTheta < 0.9) {
219  if (!extrapolateToZ(*isect, *com, pos.z() + distance * dir.z()))
220  return std::nullopt;
221  radius2 = pos.perp2();
222  } else {
223  if (!extrapolateToR(*isect, radius2, *com,
224  (pos + distance * dir).perp()))
225  return std::nullopt;
226  }
227 
228  // check we are getting closer to the plane, switch to RK in case of
229  // difficulty
230  dot = surface.normal().dot(dir);
231  offset = surface.normal().dot(surface.center() - pos);
232  if (std::abs(offset) > m_surfaceTolerance * std::abs(dot) &&
233  (++numberSteps > 5 ||
234  std::abs(offset) > 0.5 * std::abs(distance * dot))) {
236  ATH_MSG_DEBUG(" switch to RK after "
237  << numberSteps << " steps at offset " << offset
238  << " dot " << surface.normal().dot(dir));
239 
240  return m_rungeKuttaIntersector->intersectPlaneSurface(
241  surface, trackIntersection, qOverP);
242  }
243  };
244 
245  return intersection(std::move(*isect), *com, surface);
246 }
247 
249 bool
251  Amg::Vector3D endPosition) const
252 {
253  const SolenoidParametrization* solenoidParametrization =
255 
256  // check cylinder bounds for valid parametrization
257  return solenoidParametrization &&
258 
259  std::abs(endPosition.z()) < solenoidParametrization->maximumZ()
260 
261  && endPosition.perp() < solenoidParametrization->maximumR()
262 
263  && getSolenoidParametrization()->validOrigin(startPosition);
264 }
265 
266 // private methods
267 
268 
269 bool
271  double& radius2,
272  Constants& com,
273  const double endR) const
274 {
275  Amg::Vector3D& pos = isect.position();
276  Amg::Vector3D& dir = isect.direction();
277 
278  double fieldComponent =
279  com.m_solPar.fieldComponent(pos.z(), com.m_solParams);
280  double curvature = fieldComponent * com.m_qOverPt;
281  double arcLength = linearArcLength(isect, com, radius2, endR);
282  if (std::abs(arcLength * curvature) > m_deltaPhiTolerance) {
283  double radiusOfCurvature = 1. / curvature;
284  double xCentre =
285  pos.x() - radiusOfCurvature * dir.y() * com.m_oneOverSinTheta;
286  double yCentre =
287  pos.y() + radiusOfCurvature * dir.x() * com.m_oneOverSinTheta;
288  double cosPhi;
289  double sinPhi;
290  arcLength =
291  circularArcLength(endR, radiusOfCurvature, xCentre, yCentre,
292  dir.x() * com.m_oneOverSinTheta,
293  dir.y() * com.m_oneOverSinTheta, cosPhi, sinPhi);
294  if (std::abs(arcLength * com.m_cotTheta) < m_surfaceTolerance) {
295  pos.x() = xCentre + radiusOfCurvature * sinPhi;
296  pos.y() = yCentre - radiusOfCurvature * cosPhi;
297  pos.z() += arcLength * com.m_cotTheta;
298  radius2 = endR * endR;
299  dir.x() = cosPhi * com.m_sinTheta;
300  dir.y() = sinPhi * com.m_sinTheta;
301  isect.pathlength() += arcLength * com.m_oneOverSinTheta;
302  arcLength = 0.;
303  }
304  }
305 
306  double deltaZ = arcLength * com.m_cotTheta;
307  if (std::abs(deltaZ) < m_surfaceTolerance) // avoid FPE with constant
308  // curvature parabolic approx
309  {
310  double cosPhi = dir.x() * com.m_oneOverSinTheta;
311  double sinPhi = dir.y() * com.m_oneOverSinTheta;
312  if (std::abs(arcLength) > m_surfaceTolerance) {
313  double sinDPhi = 0.5 * arcLength * curvature;
314  double cosDPhi =
315  1. - 0.5 * sinDPhi * sinDPhi * (1.0 + 0.25 * sinDPhi * sinDPhi);
316  double temp = cosPhi;
317  cosPhi = temp * cosDPhi - sinPhi * sinDPhi;
318  sinPhi = temp * sinDPhi + sinPhi * cosDPhi;
319  dir.x() = (cosPhi * cosDPhi - sinPhi * sinDPhi) * com.m_sinTheta;
320  dir.y() = (sinPhi * cosDPhi + cosPhi * sinDPhi) * com.m_sinTheta;
321  }
322 
323  pos.x() += arcLength * cosPhi;
324  pos.y() += arcLength * sinPhi;
325  pos.z() += arcLength * com.m_cotTheta;
326  radius2 = endR * endR;
327  isect.pathlength() += arcLength * com.m_oneOverSinTheta;
328  } else {
329  extrapolateToZ(isect, com, pos.z() + deltaZ);
330  radius2 = pos.perp2();
331  if (std::abs(endR - std::sqrt(radius2)) > m_surfaceTolerance) {
332  deltaZ = linearArcLength(isect, com, radius2, endR) * com.m_cotTheta;
333  extrapolateToZ(isect, com, pos.z() + deltaZ);
334  radius2 = pos.perp2();
335  }
336  }
337 
338  return true;
339 }
340 
341 bool
343  Constants& com,
344  const double endZ)
345 {
346  Amg::Vector3D& pos = isect.position();
347  Amg::Vector3D& dir = isect.direction();
348 
349  double firstIntegral = 0.;
350  double secondIntegral = 0.;
351  com.m_solPar.fieldIntegrals(firstIntegral, secondIntegral, pos.z(), endZ,
352  com.m_solParams);
353  double DFiMax = 0.1;
354  double cosPhi = dir.x() * com.m_oneOverSinTheta;
355  double sinPhi = dir.y() * com.m_oneOverSinTheta;
356  double cosBeta;
357  double sinBeta;
358  double deltaPhi2 =
359  secondIntegral * com.m_qOverPt / std::abs(com.m_cotTheta);
360  if (std::abs(deltaPhi2) < DFiMax) {
361  double deltaPhi2Squared = deltaPhi2 * deltaPhi2;
362  sinBeta = 1. - 0.166667 * deltaPhi2Squared;
363  cosBeta = -0.5 * deltaPhi2 * (1. - 0.083333 * deltaPhi2Squared);
364  } else if (2. * std::abs(deltaPhi2) < M_PI) {
365  sinBeta = std::sin(deltaPhi2) / deltaPhi2;
366  cosBeta = (std::cos(deltaPhi2) - 1.) / deltaPhi2;
367  } else {
368  return false;
369  }
370 
371  double radialDistance = (endZ - pos.z()) / com.m_cotTheta;
372  pos.x() += radialDistance * (sinPhi * cosBeta + cosPhi * sinBeta);
373  pos.y() += radialDistance * (sinPhi * sinBeta - cosPhi * cosBeta);
374  pos.z() = endZ;
375  isect.pathlength() += radialDistance * com.m_oneOverSinTheta;
376 
377  double cosAlpha;
378  double sinAlpha;
379  double deltaPhi1 = firstIntegral * com.m_qOverPt / std::abs(com.m_cotTheta);
380  if (std::abs(deltaPhi1) < DFiMax) {
381  double deltaPhi1Squared = deltaPhi1 * deltaPhi1;
382  sinAlpha = deltaPhi1 * (1. - 0.166667 * deltaPhi1Squared);
383  cosAlpha =
384  1. - 0.5 * deltaPhi1Squared * (1. - 0.083333 * deltaPhi1Squared);
385  } else {
386  sinAlpha = std::sin(deltaPhi1);
387  cosAlpha = std::cos(deltaPhi1);
388  }
389  dir.x() = (cosPhi * cosAlpha - sinPhi * sinAlpha) * com.m_sinTheta;
390  dir.y() = (sinPhi * cosAlpha + cosPhi * sinAlpha) * com.m_sinTheta;
391  return true;
392 }
393 
394 std::optional<TrackSurfaceIntersection>
396  const SolenoidParametrization& solpar,
397  const double qOverP,
398  Constants*& com)
399 {
400  const TrackSurfaceIntersection::IIntersectionCache* oldCache = isect.cache();
401  std::unique_ptr<Constants> cache;
402  const Amg::Vector3D* lastPosition = nullptr;
403 
404  if (oldCache) {
405  assert(typeid(*oldCache) == typeid(Constants));
406  cache =
407  std::make_unique<Constants>(*static_cast<const Constants*>(oldCache));
408  lastPosition = &cache->m_lastPosition;
409  } else {
410  cache = std::make_unique<Constants>(solpar, isect, qOverP);
411  }
412 
413  com = cache.get();
414  auto newIsect =
415  std::make_optional<TrackSurfaceIntersection>(isect, std::move(cache));
416  if (lastPosition) {
417  newIsect->position() = *lastPosition;
418  }
419  return newIsect;
420 }
421 
423  std::stringstream msg;
424  msg << "Invalid read handle for SolenoidParametrization " << m_solenoidParametrizationKey.key();
425  throw std::logic_error(msg.str());
426 }
427 
428 } // end of namespace
Trk::TrackSurfaceIntersection::cache
const IIntersectionCache * cache() const
Retrieve the associated cache block, if it exists.
Definition: TrackSurfaceIntersection.h:105
Trk::SolenoidalIntersector::approachPerigeeSurface
virtual std::optional< TrackSurfaceIntersection > approachPerigeeSurface(const PerigeeSurface &surface, const TrackSurfaceIntersection &trackTrackSurfaceIntersection, const double qOverP) const override
IIntersector interface method for specific Surface type : PerigeeSurface.
Definition: SolenoidalIntersector.cxx:108
StraightLineSurface.h
TrackParameters.h
Trk::z
@ z
global position (cartesian)
Definition: ParamDefs.h:57
PerigeeSurface.h
Surface.h
Trk::SolenoidalIntersector::Constants::m_lastPosition
Amg::Vector3D m_lastPosition
Definition: SolenoidalIntersector.h:62
Trk::SolenoidalIntersector::Constants::m_qOverPt
double m_qOverPt
Definition: SolenoidalIntersector.h:60
perp
Scalar perp() const
perp method - perpenticular length
Definition: AmgMatrixBasePlugin.h:44
Trk::SolenoidParametrization::fieldIntegrals
void fieldIntegrals(double &firstIntegral, double &secondIntegral, double zBegin, double zEnd, Parameters &parms) const
Definition: SolenoidParametrization.h:245
Trk::PerigeeSurface
Definition: PerigeeSurface.h:43
Trk::SolenoidParametrization::maximumR
double maximumR() const
Definition: SolenoidParametrization.h:267
Trk::SolenoidalIntersector::m_surfaceTolerance
double m_surfaceTolerance
Definition: SolenoidalIntersector.h:152
Trk::SolenoidalIntersector::Constants::m_sinTheta
double m_sinTheta
Definition: SolenoidalIntersector.h:57
M_PI
#define M_PI
Definition: ActiveFraction.h:11
Trk::SolenoidalIntersector::newIntersection
static std::optional< TrackSurfaceIntersection > newIntersection(const TrackSurfaceIntersection &oldIsect, const SolenoidParametrization &solpar, const double qOverP, Constants *&com)
Definition: SolenoidalIntersector.cxx:395
Trk::SolenoidalIntersector::intersectPlaneSurface
virtual std::optional< TrackSurfaceIntersection > intersectPlaneSurface(const PlaneSurface &surface, const TrackSurfaceIntersection &trackTrackSurfaceIntersection, const double qOverP) const override
IIntersector interface method for specific Surface type : PlaneSurface.
Definition: SolenoidalIntersector.cxx:178
Trk::TrackSurfaceIntersection
Definition: TrackSurfaceIntersection.h:32
Trk::SolenoidalIntersector::m_solenoidParametrizationKey
SG::ReadCondHandleKey< SolenoidParametrization > m_solenoidParametrizationKey
Definition: SolenoidalIntersector.h:147
Trk::SolenoidalIntersector::m_countExtrapolations
std::atomic< unsigned long long > m_countExtrapolations
Definition: SolenoidalIntersector.h:155
Trk::DiscSurface
Definition: DiscSurface.h:54
Trk::TrackSurfaceIntersection::IIntersectionCache
Base class for cache block.
Definition: TrackSurfaceIntersection.h:36
drawFromPickle.cos
cos
Definition: drawFromPickle.py:36
Trk::TrackSurfaceIntersection::pathlength
double pathlength() const
Method to retrieve the pathlength propagated till the Intersection.
Definition: TrackSurfaceIntersection.h:96
Trk::Surface::center
const Amg::Vector3D & center() const
Returns the center position of the Surface.
Trk::temp
Definition: V0VertexDict.h:23
Trk::SolenoidalIntersector::extrapolateToZ
static bool extrapolateToZ(TrackSurfaceIntersection &isect, Constants &com, const double endZ)
Definition: SolenoidalIntersector.cxx:342
Trk::SolenoidalIntersector::isValid
virtual bool isValid(Amg::Vector3D startPosition, Amg::Vector3D endPosition) const override
IIntersector interface method to check validity of parametrization within extrapolation range.
Definition: SolenoidalIntersector.cxx:250
xAOD::EgammaParameters::deltaPhi1
@ deltaPhi1
difference between the cluster eta (1st sampling) and the eta of the track extrapolated to the 1st sa...
Definition: EgammaEnums.h:196
Trk::SolenoidalIntersector::approachStraightLineSurface
virtual std::optional< TrackSurfaceIntersection > approachStraightLineSurface(const StraightLineSurface &surface, const TrackSurfaceIntersection &trackTrackSurfaceIntersection, const double qOverP) const override
IIntersector interface method for specific Surface type : StraightLineSurface.
Definition: SolenoidalIntersector.cxx:115
Trk::SolenoidalIntersector::Constants::Constants
Constants(const SolenoidParametrization &solpar, const TrackSurfaceIntersection &trackTrackSurfaceIntersection, const double qOverP)
Definition: SolenoidalIntersector.cxx:22
SolenoidalIntersector.h
Trk::SolenoidalIntersector::circularArcLength
double circularArcLength(double, double, double, double, double, double, double &, double &) const
Definition: SolenoidalIntersector.h:161
Trk::SolenoidalIntersector::m_deltaPhiTolerance
double m_deltaPhiTolerance
Definition: SolenoidalIntersector.h:151
Trk::SolenoidalIntersector::intersection
std::optional< TrackSurfaceIntersection > intersection(TrackSurfaceIntersection &&isect, Constants &com, const Surface &surface) const
Definition: SolenoidalIntersector.h:237
Trk::SolenoidParametrization::fieldComponent
double fieldComponent(double z, const Parameters &parms) const
Definition: SolenoidParametrization.h:225
Trk::TrackSurfaceIntersection::position
const Amg::Vector3D & position() const
Method to retrieve the position of the Intersection.
Definition: TrackSurfaceIntersection.h:80
EL::StatusCode
::StatusCode StatusCode
StatusCode definition for legacy code.
Definition: PhysicsAnalysis/D3PDTools/EventLoop/EventLoop/StatusCode.h:22
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
Trk::CylinderSurface
Definition: CylinderSurface.h:55
Trk::SolenoidalIntersector::intersectSurface
virtual std::optional< TrackSurfaceIntersection > intersectSurface(const Surface &surface, const TrackSurfaceIntersection &trackTrackSurfaceIntersection, const double qOverP) const override
IIntersector interface method for general Surface type.
Definition: SolenoidalIntersector.cxx:72
CylinderSurface.h
test_pyathena.parent
parent
Definition: test_pyathena.py:15
Trk::Surface::normal
virtual const Amg::Vector3D & normal() const
Returns the normal vector of the Surface (i.e.
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
python.SystemOfUnits.micrometer
int micrometer
Definition: SystemOfUnits.py:71
dot.dot
def dot(G, fn, nodesToHighlight=[])
Definition: dot.py:5
Trk::SolenoidalIntersector::initialize
virtual StatusCode initialize() override
Definition: SolenoidalIntersector.cxx:53
beamspotman.dir
string dir
Definition: beamspotman.py:623
Trk::SolenoidalIntersector::intersectDiscSurface
virtual std::optional< TrackSurfaceIntersection > intersectDiscSurface(const DiscSurface &surface, const TrackSurfaceIntersection &trackTrackSurfaceIntersection, const double qOverP) const override
IIntersector interface method for specific Surface type : DiscSurface.
Definition: SolenoidalIntersector.cxx:147
Athena::Units
Definition: Units.h:45
Trk
Ensure that the ATLAS eigen extensions are properly loaded.
Definition: FakeTrackBuilder.h:9
Trk::SolenoidalIntersector::Constants
Constants of motion and other cached values.
Definition: SolenoidalIntersector.h:50
Trk::SurfaceType::Perigee
@ Perigee
Trk::SolenoidalIntersector::intersectCylinderSurface
virtual std::optional< TrackSurfaceIntersection > intersectCylinderSurface(const CylinderSurface &surface, const TrackSurfaceIntersection &trackTrackSurfaceIntersection, const double qOverP) const override
IIntersector interface method for specific Surface type : CylinderSurface.
Definition: SolenoidalIntersector.cxx:122
Trk::SolenoidalIntersector::m_countRKSwitches
std::atomic< unsigned long long > m_countRKSwitches
Definition: SolenoidalIntersector.h:156
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:221
Trk::SolenoidParametrization::validOrigin
bool validOrigin(const Amg::Vector3D &origin) const
Definition: SolenoidParametrization.h:275
Trk::SolenoidalIntersector::getSolenoidParametrization
const SolenoidParametrization * getSolenoidParametrization() const
Definition: SolenoidalIntersector.h:118
xAOD::EgammaParameters::deltaPhi2
@ deltaPhi2
difference between the cluster phi (second sampling) and the phi of the track extrapolated to the sec...
Definition: EgammaEnums.h:204
Amg::Vector3D
Eigen::Matrix< double, 3, 1 > Vector3D
Definition: GeoPrimitives.h:47
Trk::TrackSurfaceIntersection::direction
const Amg::Vector3D & direction() const
Method to retrieve the direction at the Intersection.
Definition: TrackSurfaceIntersection.h:88
python.LumiBlobConversion.pos
pos
Definition: LumiBlobConversion.py:18
Trk::SolenoidalIntersector::SolenoidalIntersector
SolenoidalIntersector(const std::string &type, const std::string &name, const IInterface *parent)
Definition: SolenoidalIntersector.cxx:38
Trk::SolenoidalIntersector::Constants::m_cotTheta
double m_cotTheta
Definition: SolenoidalIntersector.h:59
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
Trk::SolenoidalIntersector::extrapolateToR
bool extrapolateToR(TrackSurfaceIntersection &isect, double &radius2, Constants &com, const double endRadius) const
Definition: SolenoidalIntersector.cxx:270
Trk::PlaneSurface
Definition: PlaneSurface.h:64
PlaneSurface.h
Trk::SolenoidalIntersector::Constants::m_oneOverSinTheta
double m_oneOverSinTheta
Definition: SolenoidalIntersector.h:58
python.CaloScaleNoiseConfig.type
type
Definition: CaloScaleNoiseConfig.py:78
Trk::SolenoidalIntersector::finalize
virtual StatusCode finalize() override
Definition: SolenoidalIntersector.cxx:61
Trk::qOverP
@ qOverP
perigee
Definition: ParamDefs.h:67
Trk::SurfaceType::Disc
@ Disc
Trk::SurfaceType::Cylinder
@ Cylinder
Trk::SolenoidalIntersector::throwMissingCondData
void throwMissingCondData() const
Definition: SolenoidalIntersector.cxx:422
convertTimingResiduals.offset
offset
Definition: convertTimingResiduals.py:71
DiscSurface.h
Trk::SolenoidalIntersector::Constants::m_solPar
const SolenoidParametrization & m_solPar
Definition: SolenoidalIntersector.h:61
Gaudi
=============================================================================
Definition: CaloGPUClusterAndCellDataMonitorOptions.h:273
Trk::SurfaceType::Plane
@ Plane
dot
Definition: dot.py:1
drawFromPickle.sin
sin
Definition: drawFromPickle.py:36
Trk::SolenoidalIntersector::linearArcLength
double linearArcLength(const TrackSurfaceIntersection &isect, const Constants &com, const double radius2, const double endRadius) const
Definition: SolenoidalIntersector.h:217
makeComparison.deltaZ
int deltaZ
Definition: makeComparison.py:46
Trk::SurfaceType::Line
@ Line
Trk::CylinderSurface::globalReferencePoint
virtual const Amg::Vector3D & globalReferencePoint() const override final
Returns a global reference point: For the Cylinder this is Where denotes the averagePhi() of the cy...
Definition: CylinderSurface.cxx:167
Trk::Surface
Definition: Tracking/TrkDetDescr/TrkSurfaces/TrkSurfaces/Surface.h:75
Trk::SolenoidParametrization
Definition: SolenoidParametrization.h:31
Amg::distance
float distance(const Amg::Vector3D &p1, const Amg::Vector3D &p2)
calculates the distance between two point in 3D space
Definition: GeoPrimitivesHelpers.h:54
python.AutoConfigFlags.msg
msg
Definition: AutoConfigFlags.py:7
Trk::Surface::type
constexpr virtual SurfaceType type() const =0
Returns the Surface type to avoid dynamic casts.
Trk::SolenoidalIntersector::Constants::m_solParams
SolenoidParametrization::Parameters m_solParams
Definition: SolenoidalIntersector.h:63
Trk::StraightLineSurface
Definition: StraightLineSurface.h:51
Trk::SolenoidParametrization::maximumZ
double maximumZ() const
Definition: SolenoidParametrization.h:271
Trk::SolenoidalIntersector::m_rungeKuttaIntersector
ToolHandle< IIntersector > m_rungeKuttaIntersector
Definition: SolenoidalIntersector.h:149