Belle II Software development
StereoHitFilterFactory Class Reference

Factory that can create appropriate stereo hit to track combination filters from associated names. More...

#include <StereoHitFilterFactory.h>

Inheritance diagram for StereoHitFilterFactory:
FilterFactory< BaseStereoHitFilter >

Public Types

using CreatedFilter = BaseStereoHitFilter
 Type of the filter that this factory creates.
 

Public Member Functions

 StereoHitFilterFactory (const std::string &defaultFilterName="all")
 Constructor forwarding the default filter 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.
 
std::map< std::string, std::string > getValidFilterNamesAndDescriptions () const override
 Getter for valid filter names and a description for each.
 
std::unique_ptr< BaseStereoHitFiltercreate (const std::string &filterName) const override
 Create a filter with the given name.
 
virtual std::string createFiltersNameDescription () const
 Create a string with a description mentioning the names of the chooseable filter.
 
virtual std::string createFiltersParametersDescription () const
 Create a string with a description mentioning the parameters of the chooseable filter.
 
const std::string & getDefaultFilterName () const
 Legacy - Return the default filter suggested by the factory.
 

Private Types

using Super = FilterFactory< BaseStereoHitFilter >
 Type of the base class.
 

Private Attributes

std::string m_defaultFilterName
 Legacy - Default filter name suggested by this factory.
 

Detailed Description

Factory that can create appropriate stereo hit to track combination filters from associated names.

Definition at line 24 of file StereoHitFilterFactory.h.

Member Typedef Documentation

◆ CreatedFilter

Type of the filter that this factory creates.

Definition at line 29 of file FilterFactory.dcl.h.

◆ Super

Type of the base class.

Definition at line 28 of file StereoHitFilterFactory.h.

Constructor & Destructor Documentation

◆ StereoHitFilterFactory()

StereoHitFilterFactory ( const std::string &  defaultFilterName = "all")
explicit

Constructor forwarding the default filter name.

Definition at line 42 of file StereoHitFilterFactory.cc.

43 : Super(defaultFilterName)
44{
45}
FilterFactory< BaseStereoHitFilter > Super
Type of the base class.

Member Function Documentation

◆ create()

std::unique_ptr< BaseStereoHitFilter > create ( const std::string &  filterName) const
overridevirtual

Create a filter with the given name.

Reimplemented from FilterFactory< BaseStereoHitFilter >.

Definition at line 72 of file StereoHitFilterFactory.cc.

73{
74 if (filterName == "none") {
75 return std::make_unique<NoneStereoHitFilter>();
76 // cppcheck-suppress knownConditionTrueFalse
77 } else if (filterName == "all") {
78 return std::make_unique<AllStereoHitFilter>();
79 // cppcheck-suppress knownConditionTrueFalse
80 } else if (filterName == "random") {
81 return std::make_unique<RandomStereoHitFilter>();
82 // cppcheck-suppress knownConditionTrueFalse
83 } else if (filterName == "simple") {
84 return std::make_unique<SimpleStereoHitFilter>();
85 // cppcheck-suppress knownConditionTrueFalse
86 } else if (filterName == "truth") {
87 return std::make_unique<MCStereoHitFilter>();
88 // cppcheck-suppress knownConditionTrueFalse
89 } else if (filterName == "recording") {
90 return std::make_unique<RecordingStereoHitFilter>("StereoHitFilter.root");
91 // cppcheck-suppress knownConditionTrueFalse
92 } else if (filterName == "mva") {
93 return std::make_unique<MVAStereoHitFilter>("trackfindingcdc_StereoHitFilter");
94 } else {
95 return Super::create(filterName);
96 }
97}
virtual std::unique_ptr< BaseStereoHitFilter > create(const std::string &filterName) const
Create a filter with the given name, does not set filter specific parameters.

◆ createFiltersNameDescription()

std::string createFiltersNameDescription
virtualinherited

Create a string with a description mentioning the names of the chooseable filter.

Definition at line 56 of file FilterFactory.icc.h.

87 {
88 // Compose description for the filter names
89 std::ostringstream oss;
90 oss << this->getFilterPurpose();
91 oss << "Allowed values are: ";
92 std::vector<std::string> filterNameAndDescriptions;
93 for (const auto& filterNameAndDescription : this->getValidFilterNamesAndDescriptions()) {
94 const std::string& filterName = filterNameAndDescription.first;
95 const std::string& filterDescription = filterNameAndDescription.second;
96 filterNameAndDescriptions.push_back(quoted(filterName) + " " + bracketed(filterDescription));
97 }
98 oss << join(", ", filterNameAndDescriptions);
99 return oss.str();
100 }
virtual std::map< std::string, std::string > getValidFilterNamesAndDescriptions() const=0
Getter for the valid filter names and a description for each.
virtual std::string getFilterPurpose() const=0
Getter for a descriptive purpose of the filter.

◆ createFiltersParametersDescription()

std::string createFiltersParametersDescription
virtualinherited

Create a string with a description mentioning the parameters of the chooseable filter.

Definition at line 59 of file FilterFactory.icc.h.

104 {
105 // Compose description for the filter parameters
106 std::ostringstream oss;
107 oss << "Key -- value pairs depending on the filter." << std::endl;
108 for (const auto& filterNameAndDescription : this->getValidFilterNamesAndDescriptions()) {
109
110 const std::string& filterName = filterNameAndDescription.first;
111 // const std::string& filterDescription = filterNameAndDescription.second;
112
113 std::unique_ptr<AFilter> filter = this->create(filterName);
114 if (not filter) {
115 B2WARNING("Could not create a filter for name " << filterName);
116 continue;
117 }
118
119 ModuleParamList moduleParamList;
120 const std::string prefix = "";
121 filter->exposeParameters(&moduleParamList, prefix);
122
123 std::map<std::string, std::string> filterParameters;
124 for (auto && name : moduleParamList.getParameterNames()) {
125 filterParameters[name] = moduleParamList.getParameterDescription(name);
126 }
127
128 oss << quoted(filterName) << " :\n";
129 if (filterParameters.empty()) {
130 oss << "(no parameters)";
131 } else {
132 std::vector<std::string> parameterDescriptions;
133 for (const auto& parameterNameAndDescription : filterParameters) {
134 const std::string& parameterName = parameterNameAndDescription.first;
135 const std::string& parameterDescription = parameterNameAndDescription.second;
136 parameterDescriptions.push_back(parameterName + " -- " + parameterDescription);
137 }
138 oss << join(",\n", parameterDescriptions);
139 }
140 oss << ";\n";
141 }
142 return oss.str();
143 }

◆ getDefaultFilterName()

const std::string & getDefaultFilterName
inherited

Legacy - Return the default filter suggested by the factory.

Definition at line 63 of file FilterFactory.icc.h.

147 {
148 return m_defaultFilterName;
149 }
std::string m_defaultFilterName
Legacy - Default filter name suggested by this factory.

◆ getFilterPurpose()

std::string getFilterPurpose ( ) const
overridevirtual

Getter for a descriptive purpose of the constructed filters.

Implements FilterFactory< BaseStereoHitFilter >.

Definition at line 52 of file StereoHitFilterFactory.cc.

53{
54 return "Stereo hit to track combination filter for adding the hit.";
55}

◆ getIdentifier()

std::string getIdentifier ( ) const
overridevirtual

Getter for a short identifier for the factory.

Implements FilterFactory< BaseStereoHitFilter >.

Definition at line 47 of file StereoHitFilterFactory.cc.

48{
49 return "StereoHit";
50}

◆ getValidFilterNamesAndDescriptions()

std::map< std::string, std::string > getValidFilterNamesAndDescriptions ( ) const
overridevirtual

Getter for valid filter names and a description for each.

Implements FilterFactory< BaseStereoHitFilter >.

Definition at line 58 of file StereoHitFilterFactory.cc.

59{
60 return {
61 {"none", "no hit track combination is valid."},
62 {"all", "set all hits as good."},
63 {"random", "returns a random weight (for testing)."},
64 {"truth", "monte carlo truth."},
65 {"simple", "give back a weight based on very simple variables you can give as a parameter."},
66 {"recording", "record variables to a TTree."},
67 {"mva", "use the trained BDT."},
68 };
69}

Member Data Documentation

◆ m_defaultFilterName

std::string m_defaultFilterName
privateinherited

Legacy - Default filter name suggested by this factory.

Definition at line 67 of file FilterFactory.dcl.h.


The documentation for this class was generated from the following files: