CMS 3D CMS Logo

List of all members | Public Member Functions | Private Member Functions | Private Attributes
reco::GsfTransientTrack Class Reference

#include <GsfTransientTrack.h>

Inheritance diagram for reco::GsfTransientTrack:
reco::GsfTrack reco::BasicTransientTrack reco::Track reco::TrackBase

Public Member Functions

TrackCharge charge () const override
 
double dtErrorExt () const override
 
const MagneticFieldfield () const override
 
 GsfTransientTrack ()
 
 GsfTransientTrack (const GsfTrack &tk, const MagneticField *field)
 
 GsfTransientTrack (const GsfTrack &tk, const double time, const double dtime, const MagneticField *field)
 
 GsfTransientTrack (const GsfTrackRef &tk, const MagneticField *field)
 
 GsfTransientTrack (const GsfTrackRef &tk, const double time, const double dtime, const MagneticField *field)
 
 GsfTransientTrack (const GsfTrackRef &tk, const MagneticField *field, const edm::ESHandle< GlobalTrackingGeometry > &trackingGeometry)
 
 GsfTransientTrack (const GsfTrackRef &tk, const double time, const double dtime, const MagneticField *field, const edm::ESHandle< GlobalTrackingGeometry > &trackingGeometry)
 
 GsfTransientTrack (const GsfTrack &tk, const MagneticField *field, const edm::ESHandle< GlobalTrackingGeometry > &trackingGeometry)
 
 GsfTransientTrack (const GsfTrack &tk, const double time, const double dtime, const MagneticField *field, const edm::ESHandle< GlobalTrackingGeometry > &trackingGeometry)
 
 GsfTransientTrack (const GsfTransientTrack &tt)
 
TrajectoryStateOnSurface impactPointState () const override
 
bool impactPointStateAvailable () const override
 
TrajectoryStateClosestToPoint impactPointTSCP () const override
 
FreeTrajectoryState initialFreeState () const override
 
TrajectoryStateOnSurface innermostMeasurementState () const override
 
GsfTransientTrackoperator= (const GsfTransientTrack &tt)
 
TrajectoryStateOnSurface outermostMeasurementState () const override
 
GsfTrackRef persistentTrackRef () const
 
void setBeamSpot (const reco::BeamSpot &beamSpot) override
 
void setES (const edm::EventSetup &) override
 
void setTrackingGeometry (const edm::ESHandle< GlobalTrackingGeometry > &) override
 
TrajectoryStateClosestToBeamLine stateAtBeamLine () const override
 
TrajectoryStateOnSurface stateOnSurface (const GlobalPoint &point) const override
 
double timeExt () const override
 
const Tracktrack () const override
 
TrackBaseRef trackBaseRef () const override
 
TrajectoryStateClosestToPoint trajectoryStateClosestToPoint (const GlobalPoint &point) const override
 
- Public Member Functions inherited from reco::GsfTrack
int chargeMode () const
 track electric charge from mode More...
 
CovarianceMatrixMode covarianceMode () const
 return track covariance matrix from mode More...
 
double covarianceMode (int i, int j) const
 (i,j)-th element of covarianve matrix ( i, j = 0, ... 2 ) from mode More...
 
double errorMode (int i) const
 error on specified element from mode More...
 
double etaMode () const
 pseudorapidity of momentum vector from mode More...
 
double etaModeError () const
 error on eta from mode More...
 
const GsfTrackExtraRefgsfExtra () const
 reference to "extra" object More...
 
 GsfTrack ()
 default constructor More...
 
 GsfTrack (double chi2, double ndof, const Point &, const Vector &, int charge, const CovarianceMatrix &)
 
double lambdaMode () const
 Lambda angle from mode. More...
 
double lambdaModeError () const
 error on lambda from mode More...
 
const VectormomentumMode () const
 track momentum vector from mode More...
 
double parameterMode (int i) const
 i-th parameter ( i = 0, ... 2 ) from mode More...
 
ParameterVectorMode parametersMode () const
 Track parameters with one-to-one correspondence to the covariance matrix from mode. More...
 
double phiMode () const
 azimuthal angle of momentum vector from mode More...
 
double phiModeError () const
 error on phi from mode More...
 
double pMode () const
 momentum vector magnitude from mode More...
 
double ptMode () const
 track transverse momentum from mode More...
 
double ptModeError () const
 error on Pt (set to 1000 TeV if charge==0 for safety) from mode More...
 
double pxMode () const
 x coordinate of momentum vector from mode More...
 
double pyMode () const
 y coordinate of momentum vector from mode More...
 
double pzMode () const
 z coordinate of momentum vector from mode More...
 
double qoverpMode () const
 q/p from mode More...
 
double qoverpModeError () const
 error on signed transverse curvature from mode More...
 
void setGsfExtra (const GsfTrackExtraRef &ref)
 set reference to GSF "extra" object More...
 
void setMode (int chargeMode, const Vector &momentumMode, const CovarianceMatrixMode &covarianceMode)
 set mode parameters More...
 
double thetaMode () const
 polar angle from mode More...
 
double thetaModeError () const
 error on theta from mode More...
 
- Public Member Functions inherited from reco::Track
const TrackExtraRefextra () const
 reference to "extra" object More...
 
CovarianceMatrixfillInner (CovarianceMatrix &v) const
 
CovarianceMatrixfillOuter (CovarianceMatrix &v) const
 fill outermost trajectory state curvilinear errors More...
 
unsigned short found () const
 Number of valid hits on track. More...
 
unsigned int innerDetId () const
 DetId of the detector on which surface the innermost state is located. More...
 
const math::XYZVectorinnerMomentum () const
 momentum vector at the innermost hit position More...
 
bool innerOk () const
 return true if the innermost hit is valid More...
 
const math::XYZPointinnerPosition () const
 position of the innermost hit More...
 
CovarianceMatrix innerStateCovariance () const
 innermost trajectory state curvilinear errors More...
 
unsigned short lost () const
 Number of lost (=invalid) hits on track. More...
 
unsigned int outerDetId () const
 DetId of the detector on which surface the outermost state is located. More...
 
double outerEta () const
 pseudorapidity of the momentum vector at the outermost hit position More...
 
const math::XYZVectorouterMomentum () const
 momentum vector at the outermost hit position More...
 
bool outerOk () const
 return true if the outermost hit is valid More...
 
double outerP () const
 magnitude of momentum vector at the outermost hit position More...
 
double outerPhi () const
 azimuthal angle of the momentum vector at the outermost hit position More...
 
const math::XYZPointouterPosition () const
 position of the outermost hit More...
 
double outerPt () const
 transverse momentum at the outermost hit position More...
 
double outerPx () const
 x coordinate of momentum vector at the outermost hit position More...
 
double outerPy () const
 y coordinate of momentum vector at the outermost hit position More...
 
double outerPz () const
 z coordinate of momentum vector at the outermost hit position More...
 
double outerRadius () const
 polar radius of the outermost hit position More...
 
CovarianceMatrix outerStateCovariance () const
 outermost trajectory state curvilinear errors More...
 
double outerTheta () const
 polar angle of the momentum vector at the outermost hit position More...
 
double outerX () const
 x coordinate of the outermost hit position More...
 
double outerY () const
 y coordinate of the outermost hit position More...
 
double outerZ () const
 z coordinate of the outermost hit position More...
 
TrackingRecHitRef recHit (size_t i) const
 Get i-th hit on the track. More...
 
trackingRecHit_iterator recHitsBegin () const
 Iterator to first hit on the track. More...
 
trackingRecHit_iterator recHitsEnd () const
 Iterator to last hit on the track. More...
 
size_t recHitsSize () const
 Get number of RecHits. (Warning, this includes invalid hits, which are not physical hits). More...
 
const TrackResidualsresiduals () const
 get the residuals More...
 
const PropagationDirectionseedDirection () const
 direction of how the hits were sorted in the original seed More...
 
const edm::RefToBase< TrajectorySeed > & seedRef () const
 
void setExtra (const TrackExtraRef &ref)
 set reference to "extra" object More...
 
 Track ()
 default constructor More...
 
 Track (double chi2, double ndof, const Point &referencePoint, const Vector &momentum, int charge, const CovarianceMatrix &, TrackAlgorithm=undefAlgorithm, TrackQuality quality=undefQuality)
 constructor from fit parameters and error matrix More...
 
 ~Track () override
 virtual destructor More...
 
- Public Member Functions inherited from reco::TrackBase
TrackAlgorithm algo () const
 
AlgoMask algoMask () const
 
unsigned long long algoMaskUL () const
 
std::string algoName () const
 
bool appendHitPattern (const TrackingRecHit &hit, const TrackerTopology &ttopo)
 append a single hit to the HitPattern More...
 
bool appendHitPattern (const DetId &id, TrackingRecHit::Type hitType, const TrackerTopology &ttopo)
 
bool appendHitPattern (const uint16_t pattern, TrackingRecHit::Type hitType)
 
template<typename C >
bool appendHits (const C &c, const TrackerTopology &ttopo)
 append hit patterns from vector of hit references More...
 
template<typename I >
bool appendHits (const I &begin, const I &end, const TrackerTopology &ttopo)
 
bool appendMuonHitPattern (const DetId &id, TrackingRecHit::Type hitType)
 
bool appendTrackerHitPattern (uint16_t subdet, uint16_t layer, uint16_t stereo, TrackingRecHit::Type hitType)
 
int charge () const
 track electric charge More...
 
double chi2 () const
 chi-squared of the fit More...
 
CovarianceMatrix covariance () const
 return track covariance matrix More...
 
double covariance (int i, int j) const
 (i,j)-th element of covariance matrix (i, j = 0, ... 4) More...
 
double d0 () const
 dxy parameter in perigee convention (d0 = -dxy) More...
 
double d0Error () const
 error on d0 More...
 
double dsz () const
 dsz parameter (THIS IS NOT the SZ impact parameter to (0,0,0) if refPoint is far from (0,0,0): see parametrization definition above for details) More...
 
double dsz (const Point &myBeamSpot) const
 dsz parameter with respect to a user-given beamSpot (WARNING: this quantity can only be interpreted as the distance in the S-Z plane to the beamSpot, if the beam spot is reasonably close to the refPoint, since linear approximations are involved). This is a good approximation for Tracker tracks. More...
 
double dszError () const
 error on dsz More...
 
double dxy () const
 dxy parameter. (This is the transverse impact parameter w.r.t. to (0,0,0) ONLY if refPoint is close to (0,0,0): see parametrization definition above for details). See also function dxy(myBeamSpot). More...
 
double dxy (const Point &myBeamSpot) const
 dxy parameter with respect to a user-given beamSpot (WARNING: this quantity can only be interpreted as a minimum transverse distance if beamSpot, if the beam spot is reasonably close to the refPoint, since linear approximations are involved). This is a good approximation for Tracker tracks. More...
 
double dxy (const BeamSpot &theBeamSpot) const
 dxy parameter with respect to the beamSpot taking into account the beamspot slopes (WARNING: this quantity can only be interpreted as a minimum transverse distance if beamSpot, if the beam spot is reasonably close to the refPoint, since linear approximations are involved). This is a good approximation for Tracker tracks. More...
 
double dxyError () const
 error on dxy More...
 
double dz () const
 dz parameter (= dsz/cos(lambda)). This is the track z0 w.r.t (0,0,0) only if the refPoint is close to (0,0,0). See also function dz(myBeamSpot) More...
 
double dz (const Point &myBeamSpot) const
 dz parameter with respect to a user-given beamSpot (WARNING: this quantity can only be interpreted as the track z0, if the beamSpot is reasonably close to the refPoint, since linear approximations are involved). This is a good approximation for Tracker tracks. More...
 
double dzError () const
 error on dz More...
 
double error (int i) const
 error on specified element More...
 
double eta () const
 pseudorapidity of momentum vector More...
 
double etaError () const
 error on eta More...
 
CovarianceMatrixfill (CovarianceMatrix &v) const
 fill SMatrix More...
 
const HitPatternhitPattern () const
 Access the hit pattern, indicating in which Tracker layers the track has hits. More...
 
bool isAlgoInMask (TrackAlgorithm a) const
 
bool isLooper () const
 
double lambda () const
 Lambda angle. More...
 
double lambdaError () const
 error on lambda More...
 
const Vectormomentum () const
 track momentum vector More...
 
double ndof () const
 number of degrees of freedom of the fit More...
 
signed char nLoops () const
 
double normalizedChi2 () const
 chi-squared divided by n.d.o.f. (or chi-squared * 1e6 if n.d.o.f. is zero) More...
 
unsigned short numberOfLostHits () const
 number of cases where track crossed a layer without getting a hit. More...
 
unsigned short numberOfValidHits () const
 number of valid hits found More...
 
TrackAlgorithm originalAlgo () const
 
double p () const
 momentum vector magnitude More...
 
double parameter (int i) const
 i-th parameter ( i = 0, ... 4 ) More...
 
ParameterVector parameters () const
 Track parameters with one-to-one correspondence to the covariance matrix. More...
 
double phi () const
 azimuthal angle of momentum vector More...
 
double phiError () const
 error on phi More...
 
double pt () const
 track transverse momentum More...
 
double ptError () const
 error on Pt (set to 1000 TeV if charge==0 for safety) More...
 
double px () const
 x coordinate of momentum vector More...
 
double py () const
 y coordinate of momentum vector More...
 
double pz () const
 z coordinate of momentum vector More...
 
double qoverp () const
 q / p More...
 
double qoverpError () const
 error on signed transverse curvature More...
 
bool quality (const TrackQuality) const
 Track quality. More...
 
int qualityMask () const
 
const PointreferencePoint () const
 Reference point on the track. More...
 
void resetHitPattern ()
 Sets HitPattern as empty. More...
 
void setAlgoMask (AlgoMask a)
 
void setAlgorithm (const TrackAlgorithm a)
 Track algorithm. More...
 
void setNLoops (signed char value)
 
void setOriginalAlgorithm (const TrackAlgorithm a)
 
void setQuality (const TrackQuality)
 
void setQualityMask (int qualMask)
 
void setStopReason (uint8_t value)
 
uint8_t stopReason () const
 
double theta () const
 polar angle More...
 
double thetaError () const
 error on theta More...
 
 TrackBase ()
 default constructor More...
 
 TrackBase (double chi2, double ndof, const Point &vertex, const Vector &momentum, int charge, const CovarianceMatrix &cov, TrackAlgorithm=undefAlgorithm, TrackQuality quality=undefQuality, signed char nloops=0, uint8_t stopReason=0)
 constructor from fit parameters and error matrix More...
 
double validFraction () const
 fraction of valid hits on the track More...
 
const Pointvertex () const
 reference point on the track. This method is DEPRECATED, please use referencePoint() instead More...
 
double vx () const
 x coordinate of the reference point on track More...
 
double vy () const
 y coordinate of the reference point on track More...
 
double vz () const
 z coordinate of the reference point on track More...
 
virtual ~TrackBase ()
 virtual destructor More...
 
- Public Member Functions inherited from reco::BasicTransientTrack
virtual CandidatePtr candidate () const
 
virtual ~BasicTransientTrack ()
 

Private Member Functions

void calculateTSOSAtVertex () const
 
void init ()
 

Private Attributes

bool blStateAvailable
 
TSCPBuilderNoMaterial builder
 
double dtErrorExt_
 
bool hasTime
 
FreeTrajectoryState initialFTS
 
TrajectoryStateClosestToPoint initialTSCP
 
bool initialTSCPAvailable
 
TrajectoryStateOnSurface initialTSOS
 
bool initialTSOSAvailable
 
reco::BeamSpot theBeamSpot
 
const MagneticFieldtheField
 
TransverseImpactPointExtrapolator theTIPExtrapolator
 
edm::ESHandle< GlobalTrackingGeometrytheTrackingGeometry
 
double timeExt_
 
GsfTrackRef tkr_
 
TrajectoryStateClosestToBeamLine trajectoryStateClosestToBeamLine
 

Additional Inherited Members

- Public Types inherited from reco::GsfTrack
enum  { dimensionMode = 3 }
 parameter dimension mode More...
 
enum  { covarianceSizeMode = dimensionMode * ( dimensionMode + 1 ) / 2 }
 error matrix size mode More...
 
typedef math::Error< dimensionMode >::type CovarianceMatrixMode
 3 parameter covariance matrix (momentum part) from mode More...
 
typedef math::Vector< dimensionMode >::type ParameterVectorMode
 parameter vector (momentum part) from mode More...
 
- Public Types inherited from reco::TrackBase
enum  { dimension = 5 }
 parameter dimension More...
 
enum  { covarianceSize = dimension * (dimension + 1) / 2 }
 error matrix size More...
 
enum  {
  i_qoverp = 0, i_lambda, i_phi, i_dxy,
  i_dsz
}
 enumerator provided indices to the five parameters More...
 
typedef std::bitset< algoSizeAlgoMask
 algo mask More...
 
typedef math::Error< dimension >::type CovarianceMatrix
 5 parameter covariance matrix More...
 
typedef unsigned int index
 index type More...
 
typedef math::Vector< dimension >::type ParameterVector
 parameter vector More...
 
typedef math::XYZPoint Point
 point in the space More...
 
enum  TrackAlgorithm {
  undefAlgorithm = 0, ctf = 1, duplicateMerge = 2, cosmics = 3,
  initialStep = 4, lowPtTripletStep = 5, pixelPairStep = 6, detachedTripletStep = 7,
  mixedTripletStep = 8, pixelLessStep = 9, tobTecStep = 10, jetCoreRegionalStep = 11,
  conversionStep = 12, muonSeededStepInOut = 13, muonSeededStepOutIn = 14, outInEcalSeededConv = 15,
  inOutEcalSeededConv = 16, nuclInter = 17, standAloneMuon = 18, globalMuon = 19,
  cosmicStandAloneMuon = 20, cosmicGlobalMuon = 21, highPtTripletStep = 22, lowPtQuadStep = 23,
  detachedQuadStep = 24, reservedForUpgrades1 = 25, reservedForUpgrades2 = 26, bTagGhostTracks = 27,
  beamhalo = 28, gsf = 29, hltPixel = 30, hltIter0 = 31,
  hltIter1 = 32, hltIter2 = 33, hltIter3 = 34, hltIter4 = 35,
  hltIterX = 36, hiRegitMuInitialStep = 37, hiRegitMuLowPtTripletStep = 38, hiRegitMuPixelPairStep = 39,
  hiRegitMuDetachedTripletStep = 40, hiRegitMuMixedTripletStep = 41, hiRegitMuPixelLessStep = 42, hiRegitMuTobTecStep = 43,
  hiRegitMuMuonSeededStepInOut = 44, hiRegitMuMuonSeededStepOutIn = 45, algoSize = 46
}
 track algorithm More...
 
enum  TrackQuality {
  undefQuality = -1, loose = 0, tight = 1, highPurity = 2,
  confirmed = 3, goodIterative = 4, looseSetWithPV = 5, highPuritySetWithPV = 6,
  discarded = 7, qualitySize = 8
}
 track quality More...
 
typedef math::XYZVector Vector
 spatial vector More...
 
- Public Types inherited from reco::BasicTransientTrack
using BTT = BasicTransientTrack
 
using Proxy = ProxyBase11< BTT >
 
- Static Public Member Functions inherited from reco::TrackBase
static TrackAlgorithm algoByName (const std::string &name)
 
static std::string algoName (TrackAlgorithm)
 
static index covIndex (index i, index j)
 covariance matrix index in array More...
 
static TrackQuality qualityByName (const std::string &name)
 
static std::string qualityName (TrackQuality)
 
- Static Public Attributes inherited from reco::TrackBase
static const std::string algoNames []
 
static const std::string qualityNames []
 

Detailed Description

Definition at line 19 of file GsfTransientTrack.h.

Constructor & Destructor Documentation

GsfTransientTrack::GsfTransientTrack ( )

Definition at line 15 of file GsfTransientTrack.cc.

15  :
16  GsfTrack(), tkr_(), hasTime(false), timeExt_(0.), dtErrorExt_(0.),
17  theField(nullptr), initialTSOSAvailable(false),
19 {}
GsfTrack()
default constructor
Definition: GsfTrack.cc:4
TransverseImpactPointExtrapolator theTIPExtrapolator
const MagneticField * theField
GsfTransientTrack::GsfTransientTrack ( const GsfTrack tk,
const MagneticField field 
)

Definition at line 21 of file GsfTransientTrack.cc.

References trajectoryStateTransform::initialFreeState(), and initialFTS.

21  :
22  GsfTrack(tk),
23  tkr_(), hasTime(false), timeExt_(0.), dtErrorExt_(0.),
24  theField(field), initialTSOSAvailable(false),
26 {
27 
29 }
GsfTrack()
default constructor
Definition: GsfTrack.cc:4
const MagneticField * theField
FreeTrajectoryState initialFTS
FreeTrajectoryState initialFreeState(const reco::Track &tk, const MagneticField *field, bool withErr=true)
GsfTransientTrack::GsfTransientTrack ( const GsfTrack tk,
const double  time,
const double  dtime,
const MagneticField field 
)

Definition at line 31 of file GsfTransientTrack.cc.

References trajectoryStateTransform::initialFreeState(), and initialFTS.

33  :
34  GsfTrack(tk),
35  tkr_(), hasTime(true), timeExt_(time), dtErrorExt_(dtime),
36  theField(field), initialTSOSAvailable(false),
38 {
39 
41 }
GsfTrack()
default constructor
Definition: GsfTrack.cc:4
const MagneticField * theField
FreeTrajectoryState initialFTS
FreeTrajectoryState initialFreeState(const reco::Track &tk, const MagneticField *field, bool withErr=true)
GsfTransientTrack::GsfTransientTrack ( const GsfTrackRef tk,
const MagneticField field 
)

Definition at line 44 of file GsfTransientTrack.cc.

References trajectoryStateTransform::initialFreeState(), and initialFTS.

44  :
45  GsfTrack(*tk),
46  tkr_(tk), hasTime(false), timeExt_(0.), dtErrorExt_(0.),
47  theField(field), initialTSOSAvailable(false),
50 {
51 
53 }
GsfTrack()
default constructor
Definition: GsfTrack.cc:4
TransverseImpactPointExtrapolator theTIPExtrapolator
const MagneticField * theField
FreeTrajectoryState initialFTS
FreeTrajectoryState initialFreeState(const reco::Track &tk, const MagneticField *field, bool withErr=true)
GsfTransientTrack::GsfTransientTrack ( const GsfTrackRef tk,
const double  time,
const double  dtime,
const MagneticField field 
)

Definition at line 55 of file GsfTransientTrack.cc.

References trajectoryStateTransform::initialFreeState(), and initialFTS.

58  :
59  GsfTrack(*tk),
60  tkr_(tk), hasTime(true), timeExt_(time), dtErrorExt_(dtime),
61  theField(field), initialTSOSAvailable(false),
64 {
65 
67 }
GsfTrack()
default constructor
Definition: GsfTrack.cc:4
TransverseImpactPointExtrapolator theTIPExtrapolator
const MagneticField * theField
FreeTrajectoryState initialFTS
FreeTrajectoryState initialFreeState(const reco::Track &tk, const MagneticField *field, bool withErr=true)
GsfTransientTrack::GsfTransientTrack ( const GsfTrackRef tk,
const MagneticField field,
const edm::ESHandle< GlobalTrackingGeometry > &  trackingGeometry 
)

Definition at line 96 of file GsfTransientTrack.cc.

References trajectoryStateTransform::initialFreeState(), and initialFTS.

97  :
98  GsfTrack(*tk),
99  tkr_(tk), hasTime(false), timeExt_(0.), dtErrorExt_(0.),
100  theField(field), initialTSOSAvailable(false),
103 {
104 
106 }
GsfTrack()
default constructor
Definition: GsfTrack.cc:4
TransverseImpactPointExtrapolator theTIPExtrapolator
const MagneticField * theField
FreeTrajectoryState initialFTS
FreeTrajectoryState initialFreeState(const reco::Track &tk, const MagneticField *field, bool withErr=true)
edm::ESHandle< GlobalTrackingGeometry > theTrackingGeometry
GsfTransientTrack::GsfTransientTrack ( const GsfTrackRef tk,
const double  time,
const double  dtime,
const MagneticField field,
const edm::ESHandle< GlobalTrackingGeometry > &  trackingGeometry 
)

Definition at line 108 of file GsfTransientTrack.cc.

References trajectoryStateTransform::initialFreeState(), and initialFTS.

111  :
112  GsfTrack(*tk),
113  tkr_(tk), hasTime(true), timeExt_(time), dtErrorExt_(dtime),
114  theField(field), initialTSOSAvailable(false),
117 {
118 
120 }
GsfTrack()
default constructor
Definition: GsfTrack.cc:4
TransverseImpactPointExtrapolator theTIPExtrapolator
const MagneticField * theField
FreeTrajectoryState initialFTS
FreeTrajectoryState initialFreeState(const reco::Track &tk, const MagneticField *field, bool withErr=true)
edm::ESHandle< GlobalTrackingGeometry > theTrackingGeometry
GsfTransientTrack::GsfTransientTrack ( const GsfTrack tk,
const MagneticField field,
const edm::ESHandle< GlobalTrackingGeometry > &  trackingGeometry 
)

Definition at line 69 of file GsfTransientTrack.cc.

References trajectoryStateTransform::initialFreeState(), and initialFTS.

70  :
71  GsfTrack(tk),
72  tkr_(), hasTime(false), timeExt_(0.), dtErrorExt_(0.),
73  theField(field), initialTSOSAvailable(false),
76 {
77 
79 }
GsfTrack()
default constructor
Definition: GsfTrack.cc:4
TransverseImpactPointExtrapolator theTIPExtrapolator
const MagneticField * theField
FreeTrajectoryState initialFTS
FreeTrajectoryState initialFreeState(const reco::Track &tk, const MagneticField *field, bool withErr=true)
edm::ESHandle< GlobalTrackingGeometry > theTrackingGeometry
GsfTransientTrack::GsfTransientTrack ( const GsfTrack tk,
const double  time,
const double  dtime,
const MagneticField field,
const edm::ESHandle< GlobalTrackingGeometry > &  trackingGeometry 
)

Definition at line 81 of file GsfTransientTrack.cc.

References trajectoryStateTransform::initialFreeState(), and initialFTS.

84  :
85  GsfTrack(tk),
86  tkr_(),
87  hasTime(true), timeExt_(time), dtErrorExt_(dtime),
88  theField(field), initialTSOSAvailable(false),
91 {
92 
94 }
GsfTrack()
default constructor
Definition: GsfTrack.cc:4
TransverseImpactPointExtrapolator theTIPExtrapolator
const MagneticField * theField
FreeTrajectoryState initialFTS
FreeTrajectoryState initialFreeState(const reco::Track &tk, const MagneticField *field, bool withErr=true)
edm::ESHandle< GlobalTrackingGeometry > theTrackingGeometry
GsfTransientTrack::GsfTransientTrack ( const GsfTransientTrack tt)

Definition at line 123 of file GsfTransientTrack.cc.

References impactPointState(), impactPointTSCP(), initialTSCP, initialTSCPAvailable, initialTSOS, and initialTSOSAvailable.

123  :
124  GsfTrack(tt),
125  tkr_(tt.persistentTrackRef()),
127  theField(tt.field()),
129  initialTSCPAvailable(false),
131 {
132  if (tt.initialTSOSAvailable) {
134  initialTSOSAvailable = true;
135  }
136  if (tt.initialTSCPAvailable) {
138  initialTSCPAvailable = true;
139  }
140 }
TrajectoryStateClosestToPoint impactPointTSCP() const override
const MagneticField * field() const override
GsfTrack()
default constructor
Definition: GsfTrack.cc:4
TrajectoryStateOnSurface initialTSOS
TransverseImpactPointExtrapolator theTIPExtrapolator
FreeTrajectoryState initialFreeState() const override
TrajectoryStateClosestToPoint initialTSCP
const MagneticField * theField
FreeTrajectoryState initialFTS
GsfTrackRef persistentTrackRef() const
TrajectoryStateOnSurface impactPointState() const override

Member Function Documentation

void GsfTransientTrack::calculateTSOSAtVertex ( ) const
private
TrackCharge reco::GsfTransientTrack::charge ( void  ) const
inlineoverridevirtual

Implements reco::BasicTransientTrack.

Definition at line 88 of file GsfTransientTrack.h.

References reco::TrackBase::charge().

88 {return GsfTrack::charge();}
int charge() const
track electric charge
Definition: TrackBase.h:567
double reco::GsfTransientTrack::dtErrorExt ( ) const
inlineoverridevirtual

Implements reco::BasicTransientTrack.

Definition at line 98 of file GsfTransientTrack.h.

References calculateTSOSAtVertex(), dtErrorExt_, hasTime, and init().

98 { return ( hasTime ? dtErrorExt_ : std::numeric_limits<double>::quiet_NaN() ); }
const MagneticField* reco::GsfTransientTrack::field ( ) const
inlineoverridevirtual

Implements reco::BasicTransientTrack.

Definition at line 90 of file GsfTransientTrack.h.

References theField.

90 {return theField;}
const MagneticField * theField
TrajectoryStateOnSurface GsfTransientTrack::impactPointState ( ) const
overridevirtual

The TSOS at the initial state, made from the stored singl-component state.

Implements reco::BasicTransientTrack.

Definition at line 163 of file GsfTransientTrack.cc.

References calculateTSOSAtVertex(), initialTSOS, and initialTSOSAvailable.

Referenced by GsfTransientTrack(), and initialFreeState().

164 {
166  return initialTSOS;
167 }
TrajectoryStateOnSurface initialTSOS
void calculateTSOSAtVertex() const
bool reco::GsfTransientTrack::impactPointStateAvailable ( ) const
inlineoverridevirtual

Implements reco::BasicTransientTrack.

Definition at line 79 of file GsfTransientTrack.h.

References initialTSOSAvailable.

TrajectoryStateClosestToPoint GsfTransientTrack::impactPointTSCP ( ) const
overridevirtual

The TrajectoryStateClosestToPoint at the initial state, made from the stored singl-component state.

Implements reco::BasicTransientTrack.

Definition at line 169 of file GsfTransientTrack.cc.

References builder, initialFTS, initialTSCP, initialTSCPAvailable, and FreeTrajectoryState::position().

Referenced by GsfTransientTrack(), and initialFreeState().

170 {
171  if (!initialTSCPAvailable) {
173  initialTSCPAvailable = true;
174  }
175  return initialTSCP;
176 }
TSCPBuilderNoMaterial builder
TrajectoryStateClosestToPoint initialTSCP
GlobalPoint position() const
FreeTrajectoryState initialFTS
void reco::GsfTransientTrack::init ( )
private

Referenced by dtErrorExt().

FreeTrajectoryState reco::GsfTransientTrack::initialFreeState ( ) const
inlineoverridevirtual
TrajectoryStateOnSurface GsfTransientTrack::innermostMeasurementState ( ) const
overridevirtual

Implements reco::BasicTransientTrack.

Definition at line 184 of file GsfTransientTrack.cc.

References MultiTrajectoryStateTransform::innerStateOnSurface(), theField, and theTrackingGeometry.

Referenced by initialFreeState(), and stateOnSurface().

185 {
186  MultiTrajectoryStateTransform theMTransform;
187  return theMTransform.innerStateOnSurface((*this),*theTrackingGeometry,theField);
188 }
const MagneticField * theField
TrajectoryStateOnSurface innerStateOnSurface(const reco::GsfTrack &tk) const
edm::ESHandle< GlobalTrackingGeometry > theTrackingGeometry
GsfTransientTrack& reco::GsfTransientTrack::operator= ( const GsfTransientTrack tt)
TrajectoryStateOnSurface GsfTransientTrack::outermostMeasurementState ( ) const
overridevirtual

Implements reco::BasicTransientTrack.

Definition at line 178 of file GsfTransientTrack.cc.

References MultiTrajectoryStateTransform::outerStateOnSurface(), theField, and theTrackingGeometry.

Referenced by initialFreeState().

179 {
180  MultiTrajectoryStateTransform theMTransform;
181  return theMTransform.outerStateOnSurface((*this),*theTrackingGeometry,theField);
182 }
TrajectoryStateOnSurface outerStateOnSurface(const reco::GsfTrack &tk) const
const MagneticField * theField
edm::ESHandle< GlobalTrackingGeometry > theTrackingGeometry
GsfTrackRef reco::GsfTransientTrack::persistentTrackRef ( ) const
inline

access to original persistent track

Definition at line 84 of file GsfTransientTrack.h.

References tkr_.

Referenced by KinematicVertex::operator reco::Vertex().

84 { return tkr_; }
void GsfTransientTrack::setBeamSpot ( const reco::BeamSpot beamSpot)
overridevirtual
void GsfTransientTrack::setES ( const edm::EventSetup setup)
overridevirtual

Implements reco::BasicTransientTrack.

Definition at line 144 of file GsfTransientTrack.cc.

References edm::EventSetup::get(), and theTrackingGeometry.

144  {
145 
147 
148 }
T get() const
Definition: EventSetup.h:63
edm::ESHandle< GlobalTrackingGeometry > theTrackingGeometry
void GsfTransientTrack::setTrackingGeometry ( const edm::ESHandle< GlobalTrackingGeometry > &  tg)
overridevirtual

Implements reco::BasicTransientTrack.

Definition at line 150 of file GsfTransientTrack.cc.

References theTrackingGeometry.

150  {
151 
152  theTrackingGeometry = tg;
153 
154 }
edm::ESHandle< GlobalTrackingGeometry > theTrackingGeometry
TrajectoryStateClosestToBeamLine GsfTransientTrack::stateAtBeamLine ( ) const
overridevirtual

Implements reco::BasicTransientTrack.

Definition at line 210 of file GsfTransientTrack.cc.

References blStateAvailable, initialFTS, theBeamSpot, and trajectoryStateClosestToBeamLine.

Referenced by track().

211 {
212  if (!blStateAvailable) {
213  TSCBLBuilderNoMaterial blsBuilder;
215  blStateAvailable = true;
216  }
218 }
TrajectoryStateClosestToBeamLine trajectoryStateClosestToBeamLine
FreeTrajectoryState initialFTS
TrajectoryStateOnSurface GsfTransientTrack::stateOnSurface ( const GlobalPoint point) const
overridevirtual

The TSOS at any point. The inner-most multi-state state will be used for the propagation. The TSOS will therefore have multiple components.

Implements reco::BasicTransientTrack.

Definition at line 198 of file GsfTransientTrack.cc.

References TransverseImpactPointExtrapolator::extrapolate(), innermostMeasurementState(), and theTIPExtrapolator.

Referenced by initialFreeState(), and trajectoryStateClosestToPoint().

199 {
201 }
TransverseImpactPointExtrapolator theTIPExtrapolator
TrajectoryStateOnSurface innermostMeasurementState() const override
TrajectoryStateOnSurface extrapolate(const FreeTrajectoryState &fts, const GlobalPoint &vtx) const
extrapolation with default (=geometrical) propagator
double reco::GsfTransientTrack::timeExt ( ) const
inlineoverridevirtual

Implements reco::BasicTransientTrack.

Definition at line 96 of file GsfTransientTrack.h.

References hasTime, and timeExt_.

96 { return ( hasTime ? timeExt_ : std::numeric_limits<double>::quiet_NaN() ); }
const Track& reco::GsfTransientTrack::track ( ) const
inlineoverridevirtual

Implements reco::BasicTransientTrack.

Definition at line 92 of file GsfTransientTrack.h.

References stateAtBeamLine().

92 {return *this;}
TrackBaseRef reco::GsfTransientTrack::trackBaseRef ( ) const
inlineoverridevirtual

Implements reco::BasicTransientTrack.

Definition at line 86 of file GsfTransientTrack.h.

References tkr_.

86 {return TrackBaseRef(tkr_);}
edm::RefToBase< reco::Track > TrackBaseRef
persistent reference to a Track, using views
Definition: TrackFwd.h:32
TrajectoryStateClosestToPoint GsfTransientTrack::trajectoryStateClosestToPoint ( const GlobalPoint point) const
overridevirtual

The TrajectoryStateClosestToPoint at any point. The inner-most multi-state state will be used for the propagation. The TSCP will be built out of the collapsed mult-component TSOS.

Implements reco::BasicTransientTrack.

Definition at line 205 of file GsfTransientTrack.cc.

References builder, and stateOnSurface().

Referenced by initialFreeState().

206 {
207  return builder(stateOnSurface(point), point);
208 }
TSCPBuilderNoMaterial builder
TrajectoryStateOnSurface stateOnSurface(const GlobalPoint &point) const override

Member Data Documentation

bool reco::GsfTransientTrack::blStateAvailable
mutableprivate

Definition at line 111 of file GsfTransientTrack.h.

Referenced by setBeamSpot(), and stateAtBeamLine().

TSCPBuilderNoMaterial reco::GsfTransientTrack::builder
private

Definition at line 114 of file GsfTransientTrack.h.

Referenced by impactPointTSCP(), and trajectoryStateClosestToPoint().

double reco::GsfTransientTrack::dtErrorExt_
private

Definition at line 107 of file GsfTransientTrack.h.

Referenced by dtErrorExt().

bool reco::GsfTransientTrack::hasTime
private

Definition at line 106 of file GsfTransientTrack.h.

Referenced by dtErrorExt(), and timeExt().

FreeTrajectoryState reco::GsfTransientTrack::initialFTS
private
TrajectoryStateClosestToPoint reco::GsfTransientTrack::initialTSCP
mutableprivate

Definition at line 113 of file GsfTransientTrack.h.

Referenced by GsfTransientTrack(), and impactPointTSCP().

bool reco::GsfTransientTrack::initialTSCPAvailable
mutableprivate

Definition at line 111 of file GsfTransientTrack.h.

Referenced by GsfTransientTrack(), and impactPointTSCP().

TrajectoryStateOnSurface reco::GsfTransientTrack::initialTSOS
mutableprivate

Definition at line 112 of file GsfTransientTrack.h.

Referenced by calculateTSOSAtVertex(), GsfTransientTrack(), and impactPointState().

bool reco::GsfTransientTrack::initialTSOSAvailable
mutableprivate
reco::BeamSpot reco::GsfTransientTrack::theBeamSpot
private

Definition at line 116 of file GsfTransientTrack.h.

Referenced by setBeamSpot(), and stateAtBeamLine().

const MagneticField* reco::GsfTransientTrack::theField
private
TransverseImpactPointExtrapolator reco::GsfTransientTrack::theTIPExtrapolator
private

Definition at line 119 of file GsfTransientTrack.h.

Referenced by stateOnSurface().

edm::ESHandle<GlobalTrackingGeometry> reco::GsfTransientTrack::theTrackingGeometry
private
double reco::GsfTransientTrack::timeExt_
private

Definition at line 107 of file GsfTransientTrack.h.

Referenced by timeExt().

GsfTrackRef reco::GsfTransientTrack::tkr_
private

Definition at line 105 of file GsfTransientTrack.h.

Referenced by persistentTrackRef(), and trackBaseRef().

TrajectoryStateClosestToBeamLine reco::GsfTransientTrack::trajectoryStateClosestToBeamLine
mutableprivate

Definition at line 117 of file GsfTransientTrack.h.

Referenced by stateAtBeamLine().