10#include <tracking/trackingUtilities/findlets/base/Findlet.h>
12#include <tracking/trackFindingCDC/filters/axialSegmentPair/ChooseableAxialSegmentPairFilter.h>
14#include <cdc/topology/ISuperLayer.h>
26 namespace TrackingUtilities {
30 namespace TrackFindingCDC {
51 void apply(const
std::
vector<TrackingUtilities::CDCSegment2D>& inputSegments,
52 std::
vector<TrackingUtilities::CDCAxialSegmentPair>& axialSegmentPairs) final;
56 void create(const
std::
vector<const TrackingUtilities::CDCSegment2D*>& startSegments,
57 const
std::
vector<const TrackingUtilities::CDCSegment2D*>& endSegments,
58 std::
vector<TrackingUtilities::CDCAxialSegmentPair>& axialSegmentPairs);
The Module parameter list class.
void apply(const std::vector< TrackingUtilities::CDCSegment2D > &inputSegments, std::vector< TrackingUtilities::CDCAxialSegmentPair > &axialSegmentPairs) final
Main method constructing pairs in adjacent super layers.
TrackingUtilities::Findlet< const TrackingUtilities::CDCSegment2D, TrackingUtilities::CDCAxialSegmentPair > Super
Type of the base class.
AxialSegmentPairCreator()
Constructor adding the filter as a subordinary processing signal listener.
std::string getDescription() final
Short description of the findlet.
std::array< std::vector< const TrackingUtilities::CDCSegment2D * >, CDC::ISuperLayerUtil::c_N > m_segmentsBySuperLayer
Structure for the segments grouped by super layer id.
void exposeParameters(ModuleParamList *moduleParamList, const std::string &prefix) final
Expose the parameters to a module.
void create(const std::vector< const TrackingUtilities::CDCSegment2D * > &startSegments, const std::vector< const TrackingUtilities::CDCSegment2D * > &endSegments, std::vector< TrackingUtilities::CDCAxialSegmentPair > &axialSegmentPairs)
Creates segment pairs from a combination of start segments and end segments.
ChooseableAxialSegmentPairFilter m_axialSegmentPairFilter
The filter to be used for the segment pair generation.
Class representing a pair of reconstructed axial segments in adjacent superlayer.
A reconstructed sequence of two dimensional hits in one super layer.
Interface for a minimal algorithm part that wants to expose some parameters to a module.
Abstract base class for different kinds of events.
This is a utility class for the free ISuperLayer type.