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