8#include <tracking/trackFindingCDC/filters/trackRelation/UnionRecordingTrackRelationFilter.h>
10#include <tracking/trackFindingCDC/filters/trackRelation/MVAFeasibleTrackRelationFilter.h>
11#include <tracking/trackFindingCDC/filters/trackRelation/MVARealisticTrackRelationFilter.h>
13#include <tracking/trackFindingCDC/filters/trackRelation/BasicTrackRelationVarSet.h>
14#include <tracking/trackFindingCDC/filters/trackRelation/HitGapTrackRelationVarSet.h>
15#include <tracking/trackFindingCDC/filters/trackRelation/FitTrackRelationVarSet.h>
17#include <tracking/trackingUtilities/filters/base/UnionRecordingFilter.icc.h>
21using namespace TrackFindingCDC;
22using namespace TrackingUtilities;
26std::vector<std::string>
30 varSetNames.insert(varSetNames.end(), {
"basic",
"hit_gap",
"feasible",
"fit",
"realistic"});
34std::unique_ptr<BaseVarSet<Relation<const CDCTrack> > >
37 if (name ==
"basic") {
38 return std::make_unique<BasicTrackRelationVarSet>();
39 }
else if (name ==
"hit_gap") {
40 return std::make_unique<HitGapTrackRelationVarSet>();
41 }
else if (name ==
"feasible") {
43 return std::move(
filter).releaseVarSet();
44 }
else if (name ==
"fit") {
45 return std::make_unique<FitTrackRelationVarSet>();
46 }
else if (name ==
"realistic") {
48 return std::move(
filter).releaseVarSet();
Filter for the construction of track pairs based on simple criteria without the common fit.
Final filter for the construction of segment pairs.
std::vector< std::string > getValidVarSetNames() const final
Get the valid names of variable sets for track relations.
std::unique_ptr< TrackingUtilities::BaseVarSet< TrackingUtilities::Relation< const TrackingUtilities::CDCTrack > > > createVarSet(const std::string &name) const final
Create a concrete variables set for track relations from a name.
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.