CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
CandKinResolution.h
Go to the documentation of this file.
1 #ifndef DataFormats_PatCandidates_CandKinResolution_h
2 #define DataFormats_PatCandidates_CandKinResolution_h
3 #include <vector>
8 
9 namespace pat {
31  public:
33  typedef float Scalar;
34 
36  // 4D = 0xN4
37  Cart = 0x04,
38  ECart = 0x14,
39  Spher = 0x24,
40  ESpher = 0x34,
41  MomDev = 0x44,
42  EMomDev = 0x54,
43  // 3D =0xN3
44  MCCart = 0x03,
45  MCSpher = 0x13,
46  MCPInvSpher = 0x23,
47  EtEtaPhi = 0x33,
48  EtThetaPhi = 0x43,
49  MCMomDev = 0x53,
51  };
53 
62  CandKinResolution(Parametrization parametrization, const std::vector<Scalar> &covariances,
63  const std::vector<Scalar> &constraints = std::vector<Scalar>()) ;
64 
67  const std::vector<Scalar> &constraints = std::vector<Scalar>()) ;
69 
72 
74  uint32_t dimension() const {
75  return (static_cast<uint32_t>(parametrization_) & 0x0F);
76  }
77 
79  const AlgebraicSymMatrix44 & covariance() const {
80  if (!hasMatrix_) { fillMatrix(); hasMatrix_ = true; }
81  return covmatrix_;
82  }
83 
85  const std::vector<Scalar> & constraints() const { return constraints_; }
86 
88  double resolEta(const LorentzVector &p4) const ;
89 
91  double resolTheta(const LorentzVector &p4) const ;
92 
94  double resolPhi(const LorentzVector &p4) const ;
95 
97  double resolE(const LorentzVector &p4) const ;
98 
100  double resolEt(const LorentzVector &p4) const ;
101 
104  double resolM(const LorentzVector &p4) const ;
105 
107  double resolP(const LorentzVector &p4) const ;
108 
110  double resolPt(const LorentzVector &p4) const ;
111 
113  double resolPInv(const LorentzVector &p4) const ;
114 
116  double resolPx(const LorentzVector &p4) const ;
117 
119  double resolPy(const LorentzVector &p4) const ;
120 
122  double resolPz(const LorentzVector &p4) const ;
123 
124  private:
125  // persistent
129  std::vector<Scalar> covariances_;
131  std::vector<Scalar> constraints_;
132 
133  // transient
134 
136  mutable bool hasMatrix_;
137 
140 
141  //methods
142 
144  void fillMatrix() const ; // const: the matrix is mutable
145 
147  void fillVector() ;
148  };
149 
150  typedef std::vector<CandKinResolution> CandKinResolutionCollection;
152 }
153 
154 #endif
bool hasMatrix_
Did we make the Matrix from the vector?
double resolPhi(const LorentzVector &p4) const
Resolution on phi, given the 4-momentum of the associated Candidate.
std::vector< Scalar > constraints_
Constraints.
uint32_t dimension() const
Returns the number of free parameters in this parametrization.
math::XYZTLorentzVector LorentzVector
const AlgebraicSymMatrix44 & covariance() const
Returns the full covariance matrix.
Parametrization parametrization_
Parametrization code.
void fillMatrix() const
Fill matrix from vector.
XYZTLorentzVectorD XYZTLorentzVector
Lorentz vector with cylindrical internal representation using pseudorapidity.
Definition: LorentzVector.h:30
double resolPz(const LorentzVector &p4) const
Resolution on pz, given the 4-momentum of the associated Candidate.
ROOT::Math::SMatrix< double, 4, 4, ROOT::Math::MatRepSym< double, 4 > > AlgebraicSymMatrix44
Parametrization parametrization() const
Return the code of the parametrization used in this object.
std::vector< Scalar > covariances_
Matrix, streamed as a vector.
double resolP(const LorentzVector &p4) const
Resolution on p, given the 4-momentum of the associated Candidate.
void fillVector()
Fill vectoor from matrix.
double resolPy(const LorentzVector &p4) const
Resolution on py, given the 4-momentum of the associated Candidate.
double p4[4]
Definition: TauolaWrapper.h:92
double resolEta(const LorentzVector &p4) const
Resolution on eta, given the 4-momentum of the associated Candidate.
const std::vector< Scalar > & constraints() const
The constraints associated with this parametrization.
edm::ValueMap< CandKinResolution > CandKinResolutionValueMap
double resolM(const LorentzVector &p4) const
double resolPInv(const LorentzVector &p4) const
Resolution on 1/p, given the 4-momentum of the associated Candidate.
double resolPx(const LorentzVector &p4) const
Resolution on px, given the 4-momentum of the associated Candidate.
math::XYZTLorentzVector LorentzVector
double resolE(const LorentzVector &p4) const
Resolution on energy, given the 4-momentum of the associated Candidate.
double resolEt(const LorentzVector &p4) const
Resolution on et, given the 4-momentum of the associated Candidate.
double resolPt(const LorentzVector &p4) const
Resolution on pt, given the 4-momentum of the associated Candidate.
AlgebraicSymMatrix44 covmatrix_
Transient copy of the full 4x4 covariance matrix.
std::vector< CandKinResolution > CandKinResolutionCollection
double resolTheta(const LorentzVector &p4) const
Resolution on theta, given the 4-momentum of the associated Candidate.