File indexing completed on 2024-04-06 12:29:10
0001 #ifndef FourMomentumKinematicConstraint_H
0002 #define FourMomentumKinematicConstraint_H
0003
0004 #include "RecoVertex/KinematicFitPrimitives/interface/KinematicConstraint.h"
0005 #include "RecoVertex/KinematicFitPrimitives/interface/ParticleMass.h"
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017 class FourMomentumKinematicConstraint : public KinematicConstraint {
0018 public:
0019
0020
0021
0022
0023
0024 FourMomentumKinematicConstraint(const AlgebraicVector& momentum, const AlgebraicVector& deviation);
0025
0026
0027
0028
0029
0030 std::pair<AlgebraicVector, AlgebraicVector> value(const AlgebraicVector& exPoint) const override;
0031
0032 std::pair<AlgebraicMatrix, AlgebraicVector> derivative(const AlgebraicVector& exPoint) const override;
0033
0034
0035
0036
0037
0038 std::pair<AlgebraicMatrix, AlgebraicVector> derivative(
0039 const std::vector<RefCountedKinematicParticle>& par) const override;
0040
0041 std::pair<AlgebraicVector, AlgebraicVector> value(const std::vector<RefCountedKinematicParticle>& par) const override;
0042
0043
0044
0045
0046
0047 int numberOfEquations() const override;
0048
0049 AlgebraicVector deviations(int nStates) const override;
0050
0051 FourMomentumKinematicConstraint* clone() const override { return new FourMomentumKinematicConstraint(*this); }
0052
0053 private:
0054 AlgebraicVector mm;
0055 AlgebraicVector dd;
0056 };
0057 #endif