TrackingTools
GeomPropagators
interface
StraightLineCylinderCrossing.h
Go to the documentation of this file.
1
#ifndef StraightLineCylinderCrossing_H
2
#define StraightLineCylinderCrossing_H
3
4
#include "
DataFormats/GeometryVector/interface/LocalPoint.h
"
5
#include "
DataFormats/GeometryVector/interface/LocalVector.h
"
6
#include "
DataFormats/GeometryVector/interface/Basic2DVector.h
"
7
8
#include "
DataFormats/TrajectorySeed/interface/PropagationDirection.h
"
9
10
#include <utility>
11
12
class
Cylinder
;
13
17
class
StraightLineCylinderCrossing
{
18
public
:
21
StraightLineCylinderCrossing
(
const
LocalPoint
& startingPos,
22
const
LocalVector
& startingDir,
23
const
PropagationDirection
propDir =
alongMomentum
,
24
double
tolerance
= 0);
25
29
std::pair<bool, double>
pathLength
(
const
Cylinder
& cyl)
const
;
30
36
LocalPoint
position
(
const
double
s
)
const
{
return
LocalPoint
(
theX0
+
s
*
theP0
); }
37
38
private
:
40
std::pair<bool, double>
chooseSolution
(
const
double
s1,
const
double
s2
)
const
;
41
42
private
:
43
//
44
// single precision is sufficient for intermediate vectors
45
//
46
typedef
LocalPoint
PositionType
;
47
typedef
LocalVector
DirectionType
;
48
typedef
Basic2DVector<float>
PositionType2D
;
49
typedef
Basic2DVector<float>
DirectionType2D
;
50
51
const
PositionType
theX0
;
52
const
DirectionType
theP0
;
53
const
PropagationDirection
thePropDir
;
54
double
theTolerance
;
55
};
56
57
#endif
Vector3DBase< float, LocalTag >
StraightLineCylinderCrossing::theTolerance
double theTolerance
Definition:
StraightLineCylinderCrossing.h:54
StraightLineCylinderCrossing::theX0
const PositionType theX0
Definition:
StraightLineCylinderCrossing.h:51
StraightLineCylinderCrossing::DirectionType
LocalVector DirectionType
Definition:
StraightLineCylinderCrossing.h:47
StraightLineCylinderCrossing::PositionType
LocalPoint PositionType
Definition:
StraightLineCylinderCrossing.h:46
indexGen.s2
s2
Definition:
indexGen.py:107
align::LocalPoint
Point3DBase< Scalar, LocalTag > LocalPoint
Definition:
Definitions.h:30
alignCSCRings.s
s
Definition:
alignCSCRings.py:92
StraightLineCylinderCrossing::DirectionType2D
Basic2DVector< float > DirectionType2D
Definition:
StraightLineCylinderCrossing.h:49
StraightLineCylinderCrossing::pathLength
std::pair< bool, double > pathLength(const Cylinder &cyl) const
Definition:
StraightLineCylinderCrossing.cc:16
Point3DBase< float, LocalTag >
Basic2DVector< float >
StraightLineCylinderCrossing::theP0
const DirectionType theP0
Definition:
StraightLineCylinderCrossing.h:52
StraightLineCylinderCrossing
Definition:
StraightLineCylinderCrossing.h:17
tolerance
const double tolerance
Definition:
HGCalGeomParameters.cc:29
StraightLineCylinderCrossing::PositionType2D
Basic2DVector< float > PositionType2D
Definition:
StraightLineCylinderCrossing.h:48
StraightLineCylinderCrossing::position
LocalPoint position(const double s) const
Definition:
StraightLineCylinderCrossing.h:36
PropagationDirection.h
Basic2DVector.h
LocalPoint.h
StraightLineCylinderCrossing::thePropDir
const PropagationDirection thePropDir
Definition:
StraightLineCylinderCrossing.h:53
PropagationDirection
PropagationDirection
Definition:
PropagationDirection.h:4
Cylinder
Definition:
Cylinder.h:19
LocalVector.h
StraightLineCylinderCrossing::chooseSolution
std::pair< bool, double > chooseSolution(const double s1, const double s2) const
Chooses the right solution w.r.t. the propagation direction.
Definition:
StraightLineCylinderCrossing.cc:49
alongMomentum
Definition:
PropagationDirection.h:4
StraightLineCylinderCrossing::StraightLineCylinderCrossing
StraightLineCylinderCrossing(const LocalPoint &startingPos, const LocalVector &startingDir, const PropagationDirection propDir=alongMomentum, double tolerance=0)
Definition:
StraightLineCylinderCrossing.cc:10
Generated for CMSSW Reference Manual by
1.8.16