8#include <tracking/trackFindingCDC/filters/segmentPair/UnionRecordingSegmentPairFilter.h>
10#include <tracking/trackFindingCDC/filters/segmentPair/BasicSegmentPairVarSet.h>
12#include <tracking/trackFindingCDC/filters/segmentPair/HitGapSegmentPairVarSet.h>
13#include <tracking/trackFindingCDC/filters/segmentPair/SkimmedHitGapSegmentPairVarSet.h>
14#include <tracking/trackFindingCDC/filters/segmentPair/FitlessSegmentPairVarSet.h>
15#include <tracking/trackFindingCDC/filters/segmentPair/FitSegmentPairVarSet.h>
16#include <tracking/trackFindingCDC/filters/segmentPair/TruthSegmentPairVarSet.h>
17#include <tracking/trackFindingCDC/filters/segmentPair/TrailSegmentPairVarSet.h>
19#include <tracking/trackFindingCDC/filters/segmentPair/MVAFeasibleSegmentPairFilter.h>
20#include <tracking/trackFindingCDC/filters/segmentPair/MVARealisticSegmentPairFilter.h>
22#include <tracking/trackingUtilities/filters/base/UnionRecordingFilter.icc.h>
25using namespace TrackFindingCDC;
26using namespace TrackingUtilities;
30std::vector<std::string>
34 varSetNames.insert(varSetNames.end(), {
50std::unique_ptr<BaseVarSet<CDCSegmentPair> >
53 if (name ==
"basic") {
54 return std::make_unique<BasicSegmentPairVarSet>();
55 }
else if (name ==
"hit_gap") {
56 return std::make_unique<HitGapSegmentPairVarSet>();
57 }
else if (name ==
"skimmed_hit_gap") {
58 return std::make_unique<SkimmedHitGapSegmentPairVarSet>();
59 }
else if (name ==
"fitless") {
60 return std::make_unique<FitlessSegmentPairVarSet>();
61 }
else if (name ==
"feasible") {
63 return std::move(
filter).releaseVarSet();
64 }
else if (name ==
"pre_fit") {
65 const bool preliminaryFit =
true;
66 return std::make_unique<FitSegmentPairVarSet>(preliminaryFit);
67 }
else if (name ==
"fit") {
68 return std::make_unique<FitSegmentPairVarSet>(
false);
69 }
else if (name ==
"realistic") {
71 return std::move(
filter).releaseVarSet();
72 }
else if (name ==
"truth") {
73 return std::make_unique<TruthSegmentPairVarSet>();
74 }
else if (name ==
"trail") {
75 return std::make_unique<TrailSegmentPairVarSet>();
Filter for the construction of segment pairs based on simple criteria without the common fit.
Final filter for the construction of segment pairs.
std::unique_ptr< TrackingUtilities::BaseVarSet< TrackingUtilities::CDCSegmentPair > > createVarSet(const std::string &name) const final
Create a concrete variables set for segment pairs from a name.
std::vector< std::string > getValidVarSetNames() const final
Get the valid names of variable sets for segment pairs.
Convenience template to create a recording filter for a filter factory.
virtual std::unique_ptr< AVarSet > createVarSet(const std::string &name) const
virtual std::vector< std::string > getValidVarSetNames() const
std::map< ExpRun, std::pair< double, double > > filter(const std::map< ExpRun, std::pair< double, double > > &runs, double cut, std::map< ExpRun, std::pair< double, double > > &runsRemoved)
filter events to remove runs shorter than cut, it stores removed runs in runsRemoved
Abstract base class for different kinds of events.