8#include <tracking/trackFindingCDC/filters/segmentTriple/AllSegmentTripleFilter.h>
10#include <tracking/trackingUtilities/eventdata/tracks/CDCSegmentTriple.h>
11#include <tracking/trackingUtilities/eventdata/segments/CDCSegment2D.h>
14using namespace TrackFindingCDC;
15using namespace TrackingUtilities;
19 const CDCAxialSegment2D* ptrStartSegment = segmentTriple.
getStartSegment();
20 const CDCStereoSegment2D* ptrMiddleSegment = segmentTriple.
getMiddleSegment();
21 const CDCAxialSegment2D* ptrEndSegment = segmentTriple.
getEndSegment();
23 assert(ptrStartSegment);
24 assert(ptrMiddleSegment);
25 assert(ptrEndSegment);
27 const CDCAxialSegment2D& startSegment = *ptrStartSegment;
28 const CDCAxialSegment2D& middleSegment = *ptrMiddleSegment;
29 const CDCAxialSegment2D& endSegment = *ptrEndSegment;
31 Weight result = startSegment.size() + middleSegment.size() + endSegment.size();
TrackingUtilities::Weight operator()(const TrackingUtilities::CDCSegmentTriple &segmentTriple) final
All implementation returns the size of the segment triples accepting all.
Class representing a triple of reconstructed segments in adjacent superlayer.
const CDCStereoSegment2D * getMiddleSegment() const
Getter for the middle stereo segment.
const CDCAxialSegment2D * getEndSegment() const
Getter for the end axial segment.
const CDCAxialSegment2D * getStartSegment() const
Getter for the start axial segment.
Abstract base class for different kinds of events.