CMS 3D CMS Logo

List of all members | Public Member Functions | Protected Member Functions
VertexDistance Class Referenceabstract

#include <VertexDistance.h>

Inheritance diagram for VertexDistance:
VertexDistance3D VertexDistanceXY

Public Member Functions

virtual VertexDistanceclone () const =0
 
virtual float compatibility (const reco::Vertex &, const reco::Vertex &) const
 
virtual float compatibility (const VertexState &, const VertexState &) const
 
virtual float compatibility (const reco::Vertex &, const VertexState &) const
 
virtual float compatibility (const VertexState &, const reco::Vertex &) const
 
Measurement1D distance (const reco::Vertex &, const reco::Vertex &) const
 
Measurement1D distance (const VertexState &, const VertexState &) const
 
Measurement1D distance (const reco::Vertex &, const VertexState &) const
 
Measurement1D distance (const VertexState &, const reco::Vertex &) const
 
virtual Measurement1D signedDistance (const reco::Vertex &primVtx, const reco::Vertex &secVtx, const GlobalVector &momentum) const =0
 
virtual ~VertexDistance ()
 

Protected Member Functions

virtual float compatibility (const GlobalPoint &vtx1Position, const GlobalError &vtx1PositionError, const GlobalPoint &vtx2Position, const GlobalError &vtx2PositionError) const =0
 
virtual Measurement1D distance (const GlobalPoint &vtx1Position, const GlobalError &vtx1PositionError, const GlobalPoint &vtx2Position, const GlobalError &vtx2PositionError) const =0
 

Detailed Description

Abstact class which defines a distance and compatibility between vertices.

Definition at line 16 of file VertexDistance.h.

Constructor & Destructor Documentation

virtual VertexDistance::~VertexDistance ( )
inlinevirtual

Definition at line 18 of file VertexDistance.h.

References clone(), compatibility(), distance(), and signedDistance().

18 {}

Member Function Documentation

virtual VertexDistance* VertexDistance::clone ( ) const
pure virtual

Implemented in VertexDistance3D, and VertexDistanceXY.

Referenced by ~VertexDistance().

float VertexDistance::compatibility ( const reco::Vertex vtx1,
const reco::Vertex vtx2 
) const
virtual

Definition at line 51 of file VertexDistance.cc.

References reco::Vertex::covariance(), and reco::Vertex::position().

Referenced by VertexDistanceXY::clone(), and ~VertexDistance().

51  {
53  GlobalError(vtx1.covariance()),
55  GlobalError(vtx2.covariance()));
56 }
Global3DPoint GlobalPoint
Definition: GlobalPoint.h:10
GlobalErrorBase< double, ErrorMatrixTag > GlobalError
Definition: GlobalError.h:13
double covariance(int i, int j) const
(i, j)-th element of error matrix, i, j = 0, ... 2
Definition: Vertex.h:134
virtual float compatibility(const reco::Vertex &, const reco::Vertex &) const
const Point & position() const
position
Definition: Vertex.h:113
float VertexDistance::compatibility ( const VertexState vtx1,
const VertexState vtx2 
) const
virtual

Definition at line 33 of file VertexDistance.cc.

References VertexState::error(), and VertexState::position().

33  {
34  return compatibility(vtx1.position(), vtx1.error(), vtx2.position(), vtx2.error());
35 }
GlobalPoint position() const
Definition: VertexState.h:62
virtual float compatibility(const reco::Vertex &, const reco::Vertex &) const
GlobalError error() const
Definition: VertexState.h:64
float VertexDistance::compatibility ( const reco::Vertex vtx1,
const VertexState vtx2 
) const
virtual

Definition at line 37 of file VertexDistance.cc.

References reco::Vertex::covariance(), VertexState::error(), VertexState::position(), and reco::Vertex::position().

37  {
39  GlobalError(vtx1.covariance()),
40  vtx2.position(),
41  vtx2.error());
42 }
Global3DPoint GlobalPoint
Definition: GlobalPoint.h:10
GlobalErrorBase< double, ErrorMatrixTag > GlobalError
Definition: GlobalError.h:13
double covariance(int i, int j) const
(i, j)-th element of error matrix, i, j = 0, ... 2
Definition: Vertex.h:134
GlobalPoint position() const
Definition: VertexState.h:62
virtual float compatibility(const reco::Vertex &, const reco::Vertex &) const
const Point & position() const
position
Definition: Vertex.h:113
GlobalError error() const
Definition: VertexState.h:64
float VertexDistance::compatibility ( const VertexState vtx1,
const reco::Vertex vtx2 
) const
virtual

Definition at line 44 of file VertexDistance.cc.

References reco::Vertex::covariance(), VertexState::error(), VertexState::position(), and reco::Vertex::position().

44  {
45  return compatibility(vtx1.position(),
46  vtx1.error(),
48  GlobalError(vtx2.covariance()));
49 }
Global3DPoint GlobalPoint
Definition: GlobalPoint.h:10
GlobalErrorBase< double, ErrorMatrixTag > GlobalError
Definition: GlobalError.h:13
double covariance(int i, int j) const
(i, j)-th element of error matrix, i, j = 0, ... 2
Definition: Vertex.h:134
GlobalPoint position() const
Definition: VertexState.h:62
virtual float compatibility(const reco::Vertex &, const reco::Vertex &) const
const Point & position() const
position
Definition: Vertex.h:113
GlobalError error() const
Definition: VertexState.h:64
virtual float VertexDistance::compatibility ( const GlobalPoint vtx1Position,
const GlobalError vtx1PositionError,
const GlobalPoint vtx2Position,
const GlobalError vtx2PositionError 
) const
protectedpure virtual

Implemented in VertexDistance3D, and VertexDistanceXY.

Measurement1D VertexDistance::distance ( const reco::Vertex vtx1,
const reco::Vertex vtx2 
) const

Definition at line 26 of file VertexDistance.cc.

References reco::Vertex::covariance(), HLT_2018_cff::distance, and reco::Vertex::position().

Referenced by IPTools::absoluteImpactParameter(), VertexDistanceXY::clone(), VertexDistance3D::clone(), VertexCompatibleWithBeam::distanceToBeam(), VertexCompatibleWithBeam::operator()(), and ~VertexDistance().

26  {
28  GlobalError(vtx1.covariance()),
30  GlobalError(vtx2.covariance()));
31 }
Global3DPoint GlobalPoint
Definition: GlobalPoint.h:10
GlobalErrorBase< double, ErrorMatrixTag > GlobalError
Definition: GlobalError.h:13
double covariance(int i, int j) const
(i, j)-th element of error matrix, i, j = 0, ... 2
Definition: Vertex.h:134
const Point & position() const
position
Definition: Vertex.h:113
Measurement1D distance(const reco::Vertex &, const reco::Vertex &) const
Measurement1D VertexDistance::distance ( const VertexState vtx1,
const VertexState vtx2 
) const

Definition at line 8 of file VertexDistance.cc.

References HLT_2018_cff::distance, VertexState::error(), and VertexState::position().

8  {
9  return distance(vtx1.position(), vtx1.error(), vtx2.position(), vtx2.error());
10 }
GlobalPoint position() const
Definition: VertexState.h:62
Measurement1D distance(const reco::Vertex &, const reco::Vertex &) const
GlobalError error() const
Definition: VertexState.h:64
Measurement1D VertexDistance::distance ( const reco::Vertex vtx1,
const VertexState vtx2 
) const

Definition at line 12 of file VertexDistance.cc.

References reco::Vertex::covariance(), HLT_2018_cff::distance, VertexState::error(), VertexState::position(), and reco::Vertex::position().

12  {
14  GlobalError(vtx1.covariance()),
15  vtx2.position(),
16  vtx2.error());
17 }
Global3DPoint GlobalPoint
Definition: GlobalPoint.h:10
GlobalErrorBase< double, ErrorMatrixTag > GlobalError
Definition: GlobalError.h:13
double covariance(int i, int j) const
(i, j)-th element of error matrix, i, j = 0, ... 2
Definition: Vertex.h:134
GlobalPoint position() const
Definition: VertexState.h:62
const Point & position() const
position
Definition: Vertex.h:113
Measurement1D distance(const reco::Vertex &, const reco::Vertex &) const
GlobalError error() const
Definition: VertexState.h:64
Measurement1D VertexDistance::distance ( const VertexState vtx1,
const reco::Vertex vtx2 
) const

Definition at line 19 of file VertexDistance.cc.

References reco::Vertex::covariance(), HLT_2018_cff::distance, VertexState::error(), VertexState::position(), and reco::Vertex::position().

19  {
20  return distance(vtx1.position(),
21  vtx1.error(),
23  GlobalError(vtx2.covariance()));
24 }
Global3DPoint GlobalPoint
Definition: GlobalPoint.h:10
GlobalErrorBase< double, ErrorMatrixTag > GlobalError
Definition: GlobalError.h:13
double covariance(int i, int j) const
(i, j)-th element of error matrix, i, j = 0, ... 2
Definition: Vertex.h:134
GlobalPoint position() const
Definition: VertexState.h:62
const Point & position() const
position
Definition: Vertex.h:113
Measurement1D distance(const reco::Vertex &, const reco::Vertex &) const
GlobalError error() const
Definition: VertexState.h:64
virtual Measurement1D VertexDistance::distance ( const GlobalPoint vtx1Position,
const GlobalError vtx1PositionError,
const GlobalPoint vtx2Position,
const GlobalError vtx2PositionError 
) const
protectedpure virtual

Implemented in VertexDistance3D, and VertexDistanceXY.

virtual Measurement1D VertexDistance::signedDistance ( const reco::Vertex primVtx,
const reco::Vertex secVtx,
const GlobalVector momentum 
) const
pure virtual

The signed distance is computed using a vector from the primary to the secondary vertex and a given reference vector. for the 2D case: The sign is determined by the scalar product of the x,y component of the vector connecting the vertices and the reference vector: if the scalar product is greater than zero, the sign is +1, else -1

for the 3D case: Follows same approach, using all three components of the two vectors

Implemented in VertexDistance3D, and VertexDistanceXY.

Referenced by ~VertexDistance().