8#include <tracking/trackFindingCDC/filters/stereoHits/StereoHitFilterFactory.h>
10#include <tracking/trackFindingCDC/filters/stereoHits/StereoHitTruthVarSet.h>
11#include <tracking/trackFindingCDC/filters/stereoHits/StereoHitVarSet.h>
13#include <tracking/trackingUtilities/filters/base/MVAFilter.icc.h>
15#include <tracking/trackingUtilities/filters/base/AllFilter.icc.h>
16#include <tracking/trackingUtilities/filters/base/NoneFilter.icc.h>
17#include <tracking/trackingUtilities/filters/base/RandomFilter.icc.h>
18#include <tracking/trackingUtilities/filters/base/ChoosableFromVarSetFilter.icc.h>
19#include <tracking/trackingUtilities/filters/base/TruthVarFilter.icc.h>
20#include <tracking/trackingUtilities/filters/base/RecordingFilter.icc.h>
22#include <tracking/trackingUtilities/filters/base/FilterFactory.icc.h>
24#include <tracking/trackingUtilities/varsets/VariadicUnionVarSet.h>
27using namespace TrackFindingCDC;
28using namespace TrackingUtilities;
36 using RecordingStereoHitFilter =
44 :
Super(defaultFilterName)
55 return "Stereo hit to track combination filter for adding the hit.";
58std::map<std::string, std::string>
62 {
"none",
"no hit track combination is valid."},
63 {
"all",
"set all hits as good."},
64 {
"random",
"returns a random weight (for testing)."},
65 {
"truth",
"monte carlo truth."},
66 {
"simple",
"give back a weight based on very simple variables you can give as a parameter."},
67 {
"recording",
"record variables to a TTree."},
68 {
"mva",
"use the trained BDT."},
72std::unique_ptr<BaseStereoHitFilter>
75 if (filterName ==
"none") {
76 return std::make_unique<NoneStereoHitFilter>();
78 }
else if (filterName ==
"all") {
79 return std::make_unique<AllStereoHitFilter>();
81 }
else if (filterName ==
"random") {
82 return std::make_unique<RandomStereoHitFilter>();
84 }
else if (filterName ==
"simple") {
85 return std::make_unique<SimpleStereoHitFilter>();
87 }
else if (filterName ==
"truth") {
88 return std::make_unique<MCStereoHitFilter>();
90 }
else if (filterName ==
"recording") {
91 return std::make_unique<RecordingStereoHitFilter>(
"StereoHitFilter.root");
93 }
else if (filterName ==
"mva") {
94 return std::make_unique<MVAStereoHitFilter>(
"trackfindingcdc_StereoHitFilter");
TrackingUtilities::FilterFactory< BaseStereoHitFilter > Super
Type of the base class.
StereoHitFilterFactory(const std::string &defaultFilterName="all")
Constructor forwarding the default filter name.
std::map< std::string, std::string > getValidFilterNamesAndDescriptions() const override
Getter for valid filter names and a description for each.
std::unique_ptr< BaseStereoHitFilter > create(const std::string &filterName) const override
Create a filter with the given name.
std::string getIdentifier() const override
Getter for a short identifier for the factory.
std::string getFilterPurpose() const override
Getter for a descriptive purpose of the constructed filters.
Filter adapter type that accepts all items (just for reference).
Convince template to create a filter returning on variable from a set of variables.
Factory that can create appropriate filter instances from a name.
virtual std::unique_ptr< BaseStereoHitFilter > create(const std::string &filterName) const
Convenience template to create a mva filter for a set of variables.
Filter adapter type that rejects all items.
Random filter resulting in a random weight between 0 and 1.
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.