Main Page
Namespaces
Classes
Package Documentation
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Properties
Friends
Macros
Pages
src
TrackingTools
GeomPropagators
interface
HelixExtrapolatorToLine2Order.h
Go to the documentation of this file.
1
#ifndef HelixExtrapolatorToLine2Order_h_
2
#define HelixExtrapolatorToLine2Order_h_
3
4
#include "
TrackingTools/GeomPropagators/interface/HelixLineExtrapolation.h
"
5
#include "
DataFormats/TrajectorySeed/interface/PropagationDirection.h
"
6
10
class
HelixExtrapolatorToLine2Order
:
public
HelixLineExtrapolation
{
11
public
:
13
HelixExtrapolatorToLine2Order
(
const
PositionType
&
point
,
14
const
DirectionType
&
direction
,
15
const
float
curvature
,
16
const
PropagationDirection
propDir =
alongMomentum
);
17
19
HelixExtrapolatorToLine2Order
(
const
double
& x0,
const
double
& y0,
const
double
& z0,
20
const
double
& cosPhi0,
const
double
& sinPhi0,
21
const
double
& cosTheta,
const
double
& sinTheta,
22
const
double
&
rho
,
23
const
PropagationDirection
propDir =
alongMomentum
) :
24
thePosition
(x0,y0,z0),
25
theDirection
(cosPhi0,sinPhi0,cosTheta/sinTheta),
26
theSinTheta
(sinTheta),
27
theRho
(rho),
28
thePropDir
(propDir) {}
29
30
// destructor
31
virtual
~HelixExtrapolatorToLine2Order
() {}
32
37
virtual
std::pair<bool,double>
pathLength
(
const
GlobalPoint
& point)
const
;
38
43
virtual
std::pair<bool,double>
pathLength
(
const
Line
&
line
)
const
;
44
46
virtual
PositionType
position
(
double
s
)
const
;
47
49
virtual
DirectionType
direction
(
double
s
)
const
;
50
52
PositionTypeDouble
positionInDouble
(
double
s
)
const
;
53
55
DirectionTypeDouble
directionInDouble
(
double
s
)
const
;
56
57
private
:
59
virtual
std::pair<bool,double>
pathLengthFromCoefficients
(
const
double
ceq[4])
const
;
61
int
solve3rdOrder
(
const
double
ceq[],
double
sol[])
const
;
63
int
solve2ndOrder
(
const
double
ceq[],
double
sol[])
const
;
64
65
private
:
66
const
PositionTypeDouble
thePosition
;
67
DirectionTypeDouble
theDirection
;
68
double
theSinTheta
;
69
const
double
theRho
;
70
const
PropagationDirection
thePropDir
;
71
};
72
73
#endif
74
75
HelixExtrapolatorToLine2Order::HelixExtrapolatorToLine2Order
HelixExtrapolatorToLine2Order(const PositionType &point, const DirectionType &direction, const float curvature, const PropagationDirection propDir=alongMomentum)
Constructor using point, direction and (transverse!) curvature.
Definition:
HelixExtrapolatorToLine2Order.cc:7
HelixExtrapolatorToLine2Order::positionInDouble
PositionTypeDouble positionInDouble(double s) const
Position at pathlength s from the starting point in double precision.
Definition:
HelixExtrapolatorToLine2Order.cc:215
HelixExtrapolatorToLine2Order::direction
virtual DirectionType direction(double s) const
Direction at pathlength s from the starting point.
Definition:
HelixExtrapolatorToLine2Order.cc:226
Line
Definition:
Line.h:10
HelixLineExtrapolation::PositionTypeDouble
Basic3DVector< double > PositionTypeDouble
Definition:
HelixLineExtrapolation.h:24
rho
Definition:
DDAxes.h:10
HelixExtrapolatorToLine2Order::solve3rdOrder
int solve3rdOrder(const double ceq[], double sol[]) const
Solutions of 3rd order equation.
Definition:
HelixExtrapolatorToLine2Order.cc:126
alongMomentum
Definition:
PropagationDirection.h:4
PropagationDirection
PropagationDirection
Definition:
PropagationDirection.h:4
HelixLineExtrapolation::DirectionTypeDouble
Basic3DVector< double > DirectionTypeDouble
Definition:
HelixLineExtrapolation.h:25
HelixLineExtrapolation::DirectionType
Basic3DVector< float > DirectionType
Definition:
HelixLineExtrapolation.h:23
HelixExtrapolatorToLine2Order::HelixExtrapolatorToLine2Order
HelixExtrapolatorToLine2Order(const double &x0, const double &y0, const double &z0, const double &cosPhi0, const double &sinPhi0, const double &cosTheta, const double &sinTheta, const double &rho, const PropagationDirection propDir=alongMomentum)
Fast constructor (for use by IterativeHelixExtrapolatorToLine).
Definition:
HelixExtrapolatorToLine2Order.h:19
geometryCSVtoXML.line
tuple line
Definition:
geometryCSVtoXML.py:15
PixelRecoUtilities::curvature
T curvature(T InversePt, const edm::EventSetup &iSetup)
Definition:
PixelRecoUtilities.h:41
HelixLineExtrapolation::PositionType
Basic3DVector< float > PositionType
Definition:
HelixLineExtrapolation.h:22
HelixLineExtrapolation.h
Basic3DVector< float >
HelixExtrapolatorToLine2Order::~HelixExtrapolatorToLine2Order
virtual ~HelixExtrapolatorToLine2Order()
Definition:
HelixExtrapolatorToLine2Order.h:31
HelixExtrapolatorToLine2Order::theSinTheta
double theSinTheta
Definition:
HelixExtrapolatorToLine2Order.h:68
PropagationDirection.h
HelixExtrapolatorToLine2Order
Definition:
HelixExtrapolatorToLine2Order.h:10
HelixExtrapolatorToLine2Order::solve2ndOrder
int solve2ndOrder(const double ceq[], double sol[]) const
Solutions of 2nd order equation.
Definition:
HelixExtrapolatorToLine2Order.cc:172
HelixLineExtrapolation
Definition:
HelixLineExtrapolation.h:15
HelixExtrapolatorToLine2Order::position
virtual PositionType position(double s) const
Position at pathlength s from the starting point.
Definition:
HelixExtrapolatorToLine2Order.cc:205
HelixExtrapolatorToLine2Order::thePropDir
const PropagationDirection thePropDir
Definition:
HelixExtrapolatorToLine2Order.h:70
HelixExtrapolatorToLine2Order::pathLengthFromCoefficients
virtual std::pair< bool, double > pathLengthFromCoefficients(const double ceq[4]) const
common part for propagation to point and line
Definition:
HelixExtrapolatorToLine2Order.cc:86
HelixExtrapolatorToLine2Order::theDirection
DirectionTypeDouble theDirection
Definition:
HelixExtrapolatorToLine2Order.h:67
HelixExtrapolatorToLine2Order::directionInDouble
DirectionTypeDouble directionInDouble(double s) const
Direction at pathlength s from the starting point in double precision.
Definition:
HelixExtrapolatorToLine2Order.cc:236
Point3DBase
Definition:
Point3DBase.h:11
asciidump.s
string s
Definition:
asciidump.py:422
HelixExtrapolatorToLine2Order::thePosition
const PositionTypeDouble thePosition
Definition:
HelixExtrapolatorToLine2Order.h:66
point
*vegas h *****************************************************used in the default bin number in original ***version of VEGAS is ***a higher bin number might help to derive a more precise ***grade subtle point
Definition:
invegas.h:5
HelixExtrapolatorToLine2Order::theRho
const double theRho
Definition:
HelixExtrapolatorToLine2Order.h:69
HelixExtrapolatorToLine2Order::pathLength
virtual std::pair< bool, double > pathLength(const GlobalPoint &point) const
Definition:
HelixExtrapolatorToLine2Order.cc:32
Generated for CMSSW Reference Manual by
1.8.5