8#include <tracking/trackFindingCDC/filters/segmentTrack/SegmentTrackFilterFactory.h>
10#include <tracking/trackFindingCDC/filters/segmentTrack/SegmentTrackTruthVarSet.h>
11#include <tracking/trackFindingCDC/filters/segmentTrack/SegmentTrackVarSet.h>
13#include <tracking/trackingUtilities/filters/base/MVAFilter.icc.h>
14#include <tracking/trackingUtilities/filters/base/AllFilter.icc.h>
15#include <tracking/trackingUtilities/filters/base/NoneFilter.icc.h>
16#include <tracking/trackingUtilities/filters/base/TruthVarFilter.icc.h>
17#include <tracking/trackingUtilities/filters/base/RecordingFilter.icc.h>
19#include <tracking/trackingUtilities/filters/base/FilterVarSet.icc.h>
21#include <tracking/trackingUtilities/filters/base/FilterFactory.icc.h>
23#include <tracking/trackingUtilities/varsets/VariadicUnionVarSet.h>
26using namespace TrackFindingCDC;
27using namespace TrackingUtilities;
40 :
Super(defaultFilterName)
44std::map<std::string, std::string>
48 {
"none",
"no segment track combination is valid"},
49 {
"truth",
"monte carlo truth"},
50 {
"mva",
"test with a mva method"},
51 {
"recording",
"record variables to a TTree"},
55std::unique_ptr<BaseSegmentTrackFilter>
58 if (filterName ==
"none") {
59 return std::make_unique<NoneSegmentTrackFilter>();
60 }
else if (filterName ==
"truth") {
61 return std::make_unique<MCSegmentTrackFilter>();
62 }
else if (filterName ==
"mva") {
63 return std::make_unique<MVASegmentTrackFilter>(
"trackfindingcdc_SegmentTrackFilter", 0.74);
64 }
else if (filterName ==
"eval") {
65 auto recordedVarSets = std::make_unique<UnionVarSet<BaseSegmentTrackFilter::Object>>();
67 recordedVarSets->push_back(std::make_unique<TrackFilterVarSet>(
"mva",
create(
"mva")));
68 recordedVarSets->push_back(std::make_unique<TrackFilterVarSet>(
"truth",
create(
"truth")));
69 return std::make_unique<Recording<BaseSegmentTrackFilter>>(std::move(recordedVarSets),
"SegmentTrackFilter_eval.root");
70 }
else if (filterName ==
"recording") {
71 return std::make_unique<RecordingSegmentTrackFilter>(
"SegmentTrackFilter.root");
79 return "Segment track chooser to be used during the combination of segment track pairs";
84 return "SegmentTrackFilter";
TrackingUtilities::FilterFactory< BaseSegmentTrackFilter > Super
Type of the base class.
std::map< std::string, std::string > getValidFilterNamesAndDescriptions() const override
Getter for valid filter names and a description for each.
SegmentTrackFilterFactory(const std::string &defaultFilterName="mva")
Constructor forwarding the default filter name.
std::string getIdentifier() const override
Getter for a short identifier for the factory.
std::unique_ptr< BaseSegmentTrackFilter > create(const std::string &filterName) const override
Create a filter with the given name.
std::string getFilterPurpose() const override
Getter for a descriptive purpose of the constructed filters.
Filter adapter type that accepts all items (just for reference).
Factory that can create appropriate filter instances from a name.
virtual std::unique_ptr< BaseSegmentTrackFilter > create(const std::string &filterName) const
Class to compute floating point variables from a filter response which can be recorded as a flat TNtu...
Convenience template to create a mva filter for a set of variables.
Filter adapter type that rejects all items.
Convenience template to create a recording filter for a set of variables.
MC Filter Type using a VarSet and the truth variable in it.
Abstract base class for different kinds of events.