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