7#ifndef TRKVKALVRTFITTER_IVERTEXCASCADEFITTER_H
8#define TRKVKALVRTFITTER_IVERTEXCASCADEFITTER_H
40 virtual std::unique_ptr<IVKalState>
makeState(
const EventContext& ctx)
const = 0;
45 virtual std::unique_ptr<IVKalState>
makeState()
const
47 return makeState(Gaudi::Hive::currentContext());
51 std::span<const double> particleMass,
53 double massConstraint = 0.)
const = 0;
56 std::span<const double> particleMass,
58 double massConstraint = 0.)
const = 0;
61 std::span<const double> particleMass,
62 const std::vector<VertexID> &precedingVertices,
64 double massConstraint = 0.)
const = 0;
67 const Vertex * primVertex = 0,
bool FirstDecayAtPV =
false )
const = 0;
70 const std::vector<const xAOD::TrackParticle*> & tracksInConstraint,
71 const std::vector<VertexID> &verticesInConstraint,
73 double massConstraint )
const = 0;
Base class for VKal state object.
virtual std::unique_ptr< IVKalState > makeState(const EventContext &ctx) const =0
virtual VertexID nextVertex(const std::vector< const xAOD::TrackParticle * > &list, std::span< const double > particleMass, IVKalState &istate, double massConstraint=0.) const =0
virtual VertexID nextVertex(const std::vector< const xAOD::TrackParticle * > &list, std::span< const double > particleMass, const std::vector< VertexID > &precedingVertices, IVKalState &istate, double massConstraint=0.) const =0
static const InterfaceID & interfaceID()
virtual std::unique_ptr< IVKalState > makeState() const
virtual VxCascadeInfo * fitCascade(IVKalState &istate, const Vertex *primVertex=0, bool FirstDecayAtPV=false) const =0
virtual VertexID startVertex(const std::vector< const xAOD::TrackParticle * > &list, std::span< const double > particleMass, IVKalState &istate, double massConstraint=0.) const =0
virtual StatusCode addMassConstraint(VertexID Vertex, const std::vector< const xAOD::TrackParticle * > &tracksInConstraint, const std::vector< VertexID > &verticesInConstraint, IVKalState &istate, double massConstraint) const =0
This class is a simplest representation of a vertex candidate.
Ensure that the ATLAS eigen extensions are properly loaded.
static const InterfaceID IID_IVertexCascadeFitter("IVertexCascadeFitter", 1, 0)