CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
TrackExtra.h
Go to the documentation of this file.
1 #ifndef TrackReco_TrackExtra_h
2 #define TrackReco_TrackExtra_h
3 
14 #include <Rtypes.h>
22 
23 namespace reco {
24  class TrackExtra : public TrackExtraBase {
25  public:
27  enum { dimension = 5 };
29  enum { covarianceSize = dimension * ( dimension + 1 ) / 2 };
37  typedef unsigned int index;
38 
42  outerOk_(false),
43  outerDetId_(0),
46  innerOk_(false),
47  innerDetId_(0),
49  seedRef_(),
51  {
52  index idx = 0;
53  for( index i = 0; i < dimension; ++ i ) {
54  for( index j = 0; j <= i; ++ j ) {
55  outerCovariance_[ idx ] = 0;
56  innerCovariance_[ idx ] = 0;
57  ++idx;
58  }
59  }
60  }
61 
63  TrackExtra( const Point & outerPosition, const Vector & outerMomentum, bool ok ,
64  const Point & innerPosition, const Vector & innerMomentum, bool iok,
65  const CovarianceMatrix& outerState, unsigned int outerId,
66  const CovarianceMatrix& innerState, unsigned int innerId,
67  PropagationDirection seedDir,
69 
71  const Point & outerPosition() const { return outerPosition_; }
73  const Vector & outerMomentum() const { return outerMomentum_; }
75  bool outerOk() const { return outerOk_; }
77  const Point & innerPosition() const { return innerPosition_; }
79  const Vector & innerMomentum() const { return innerMomentum_; }
81  bool innerOk() const { return innerOk_; }
83  double outerPx() const { return outerMomentum_.X(); }
85  double outerPy() const { return outerMomentum_.Y(); }
87  double outerPz() const { return outerMomentum_.Z(); }
89  double outerX() const { return outerPosition_.X(); }
91  double outerY() const { return outerPosition_.Y(); }
93  double outerZ() const { return outerPosition_.Z(); }
95  double outerP() const { return outerMomentum().R(); }
97  double outerPt() const { return outerMomentum().Rho(); }
99  double outerPhi() const { return outerMomentum().Phi(); }
101  double outerEta() const { return outerMomentum().Eta(); }
103  double outerTheta() const { return outerMomentum().Theta(); }
105  double outerRadius() const { return outerPosition().Rho(); }
106 
108  CovarianceMatrix outerStateCovariance() const;
110  CovarianceMatrix innerStateCovariance() const;
112  CovarianceMatrix & fillOuter( CovarianceMatrix & v ) const;
114  CovarianceMatrix & fillInner( CovarianceMatrix & v ) const;
116  unsigned int outerDetId() const { return outerDetId_; }
118  unsigned int innerDetId() const { return innerDetId_; }
119  // direction how the hits were sorted in the original seed
121 
131 
133  const TrackResiduals &residuals () const { return trackResiduals_; }
134 
135  private:
136 
142  bool outerOk_;
145  unsigned int outerDetId_;
146 
147 
153  bool innerOk_;
156  unsigned int innerDetId_;
157 
160 
163  };
164 
165 }
166 
167 #endif
bool innerOk_
innermost hit validity flag
Definition: TrackExtra.h:153
double outerPz() const
z coordinate of momentum vector at the outermost hit position
Definition: TrackExtra.h:87
Vector outerMomentum_
momentum vector at outermost hit position
Definition: TrackExtra.h:140
int i
Definition: DBlmapReader.cc:9
edm::RefToBase< TrajectorySeed > seedRef() const
Definition: TrackExtra.h:127
math::XYZVector Vector
spatial vector
Definition: TrackExtra.h:33
double outerTheta() const
polar angle of the momentum vector at the outermost hit position
Definition: TrackExtra.h:103
math::Error< 5 >::type CovarianceMatrix
5 parameter covariance matrix
Definition: TrackExtra.h:35
double outerPt() const
transverse momentum at the outermost hit position
Definition: TrackExtra.h:97
double outerRadius() const
polar radius of the outermost hit position
Definition: TrackExtra.h:105
unsigned int innerDetId() const
DetId of the detector on which surface the innermost state is located.
Definition: TrackExtra.h:118
bool outerOk_
outermost hit validity flag
Definition: TrackExtra.h:142
const Vector & outerMomentum() const
momentum vector at outermost hit position
Definition: TrackExtra.h:73
ErrorD< N >::type type
Definition: Error.h:29
void setSeedRef(edm::RefToBase< TrajectorySeed > &r)
Definition: TrackExtra.h:128
const TrackResiduals & residuals() const
get the residuals
Definition: TrackExtra.h:133
PropagationDirection
double outerX() const
x coordinate the outermost hit position
Definition: TrackExtra.h:89
float outerCovariance_[covarianceSize]
outermost trajectory state curvilinear errors
Definition: TrackExtra.h:144
math::XYZPoint Point
point in the space
Definition: TrackExtra.h:31
double outerP() const
magnitude of momentum vector at the outermost hit position
Definition: TrackExtra.h:95
CovarianceMatrix outerStateCovariance() const
outermost trajectory state curvilinear errors
Definition: TrackExtra.cc:26
TrackResiduals trackResiduals_
unbiased track residuals
Definition: TrackExtra.h:162
edm::RefToBase< TrajectorySeed > seedRef_
Definition: TrackExtra.h:159
int j
Definition: DBlmapReader.cc:9
const Vector & innerMomentum() const
momentum vector at innermost hit position
Definition: TrackExtra.h:79
double outerPy() const
y coordinate of momentum vector at the outermost hit position
Definition: TrackExtra.h:85
unsigned int index
index type
Definition: TrackExtra.h:37
unsigned int outerDetId_
Definition: TrackExtra.h:145
Vector innerMomentum_
momentum vector at innermost hit position
Definition: TrackExtra.h:151
const Point & innerPosition() const
innermost hit position
Definition: TrackExtra.h:77
unsigned int innerDetId_
Definition: TrackExtra.h:156
double outerZ() const
z coordinate the outermost hit position
Definition: TrackExtra.h:93
CovarianceMatrix & fillInner(CovarianceMatrix &v) const
fill outermost trajectory state curvilinear errors
Definition: TrackExtra.cc:38
TrackExtra()
default constructor
Definition: TrackExtra.h:40
double outerPhi() const
azimuthal angle of the momentum vector at the outermost hit position
Definition: TrackExtra.h:99
PropagationDirection seedDirection() const
Definition: TrackExtra.h:120
XYZVectorD XYZVector
spatial vector with cartesian internal representation
Definition: Vector3D.h:30
XYZPointD XYZPoint
point in space with cartesian internal representation
Definition: Point3D.h:12
tuple idx
DEBUGGING if hasattr(process,&quot;trackMonIterativeTracking2012&quot;): print &quot;trackMonIterativeTracking2012 D...
Point innerPosition_
innermost hit position
Definition: TrackExtra.h:149
bool innerOk() const
returns true if the innermost hit is valid
Definition: TrackExtra.h:81
CovarianceMatrix innerStateCovariance() const
innermost trajectory state curvilinear errors
Definition: TrackExtra.cc:30
Point outerPosition_
outermost hit position
Definition: TrackExtra.h:138
float innerCovariance_[covarianceSize]
innermost trajectory state
Definition: TrackExtra.h:155
unsigned int outerDetId() const
DetId of the detector on which surface the outermost state is located.
Definition: TrackExtra.h:116
double outerPx() const
x coordinate of momentum vector at the outermost hit position
Definition: TrackExtra.h:83
double outerY() const
y coordinate the outermost hit position
Definition: TrackExtra.h:91
volatile std::atomic< bool > shutdown_flag false
bool outerOk() const
returns true if the outermost hit is valid
Definition: TrackExtra.h:75
double outerEta() const
pseudorapidity the momentum vector at the outermost hit position
Definition: TrackExtra.h:101
const Point & outerPosition() const
outermost hit position
Definition: TrackExtra.h:71
PropagationDirection seedDir_
Definition: TrackExtra.h:158
CovarianceMatrix & fillOuter(CovarianceMatrix &v) const
fill outermost trajectory state curvilinear errors
Definition: TrackExtra.cc:34
void setResiduals(const TrackResiduals &r)
set the residuals
Definition: TrackExtra.h:130