File indexing completed on 2023-03-17 11:23:23
0001 #ifndef VertexKinematicConstraint_H
0002 #define VertexKinematicConstraint_H
0003
0004 #include "RecoVertex/KinematicFitPrimitives/interface/MultiTrackKinematicConstraint.h"
0005 #include "DataFormats/CLHEP/interface/AlgebraicObjects.h"
0006
0007
0008
0009
0010
0011
0012
0013
0014 class VertexKinematicConstraint : public MultiTrackKinematicConstraint {
0015 public:
0016 VertexKinematicConstraint();
0017
0018 ~VertexKinematicConstraint() override;
0019
0020
0021
0022
0023
0024
0025 AlgebraicVector value(const std::vector<KinematicState>& states, const GlobalPoint& point) const override;
0026
0027
0028
0029
0030
0031
0032 AlgebraicMatrix parametersDerivative(const std::vector<KinematicState>& states,
0033 const GlobalPoint& point) const override;
0034
0035
0036
0037
0038
0039
0040 AlgebraicMatrix positionDerivative(const std::vector<KinematicState>& states,
0041 const GlobalPoint& point) const override;
0042
0043
0044
0045 int numberOfEquations() const override;
0046
0047 VertexKinematicConstraint* clone() const override { return new VertexKinematicConstraint(*this); }
0048
0049 private:
0050 };
0051 #endif