Belle II Software development
SegmentPairRelationFilterFactory Class Reference

Factory that can create appropriate segment pair relation filters from associated names. More...

#include <SegmentPairRelationFilterFactory.h>

Inheritance diagram for SegmentPairRelationFilterFactory:
FilterFactory< BaseSegmentPairRelationFilter >

Public Types

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

Public Member Functions

 SegmentPairRelationFilterFactory (const std::string &defaultFilterName="realistic")
 Constructor forwarding the default filter name.
 
std::string getIdentifier () const final
 Getter for a short identifier for the factory.
 
std::string getFilterPurpose () const final
 Getter for a descriptive purpose of the constructed filters.
 
std::map< std::string, std::string > getValidFilterNamesAndDescriptions () const final
 Getter for valid filter names and a description for each.
 
std::unique_ptr< BaseSegmentPairRelationFiltercreate (const std::string &filterName) const final
 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< BaseSegmentPairRelationFilter >
 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 segment pair relation filters from associated names.

Definition at line 24 of file SegmentPairRelationFilterFactory.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 SegmentPairRelationFilterFactory.h.

Constructor & Destructor Documentation

◆ SegmentPairRelationFilterFactory()

SegmentPairRelationFilterFactory ( const std::string &  defaultFilterName = "realistic")
explicit

Constructor forwarding the default filter name.

Definition at line 27 of file SegmentPairRelationFilterFactory.cc.

28 : Super(defaultFilterName)
29{
30}
FilterFactory< BaseSegmentPairRelationFilter > Super
Type of the base class.

Member Function Documentation

◆ create()

std::unique_ptr< BaseSegmentPairRelationFilter > create ( const std::string &  filterName) const
finalvirtual

Create a filter with the given name.

Reimplemented from FilterFactory< BaseSegmentPairRelationFilter >.

Definition at line 56 of file SegmentPairRelationFilterFactory.cc.

57{
58 if (filterName == "none") {
59 return std::make_unique<NoneFilter<BaseSegmentPairRelationFilter>>();
60 // cppcheck-suppress knownConditionTrueFalse
61 } else if (filterName == "all") {
62 return std::make_unique<AllSegmentPairRelationFilter>();
63 // cppcheck-suppress knownConditionTrueFalse
64 } else if (filterName == "truth") {
65 return std::make_unique<MCSegmentPairRelationFilter>();
66 // cppcheck-suppress knownConditionTrueFalse
67 } else if (filterName == "simple") {
68 return std::make_unique<SimpleSegmentPairRelationFilter>();
69 // cppcheck-suppress knownConditionTrueFalse
70 } else if (filterName == "unionrecording") {
71 return std::make_unique<UnionRecordingSegmentPairRelationFilter>();
72 // cppcheck-suppress knownConditionTrueFalse
73 } else if (filterName == "realistic") {
74 return std::make_unique<MVARealisticSegmentPairRelationFilter>();
75 } else {
76 return Super::create(filterName);
77 }
78}
virtual std::unique_ptr< BaseSegmentPairRelationFilter > 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
finalvirtual

Getter for a descriptive purpose of the constructed filters.

Implements FilterFactory< BaseSegmentPairRelationFilter >.

Definition at line 37 of file SegmentPairRelationFilterFactory.cc.

38{
39 return "Segment pair relation filter to construct of a segment pair network";
40}

◆ getIdentifier()

std::string getIdentifier ( ) const
finalvirtual

Getter for a short identifier for the factory.

Implements FilterFactory< BaseSegmentPairRelationFilter >.

Definition at line 32 of file SegmentPairRelationFilterFactory.cc.

33{
34 return "SegmentPairRelation";
35}

◆ getValidFilterNamesAndDescriptions()

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

Getter for valid filter names and a description for each.

Implements FilterFactory< BaseSegmentPairRelationFilter >.

Definition at line 43 of file SegmentPairRelationFilterFactory.cc.

44{
45 return {
46 {"none", "no segment pair relation is valid, stop at segment pair creation"},
47 {"all", "all segment pair relations are valid"},
48 {"truth", "segment pair relations from monte carlo truth"},
49 {"simple", "mc free with simple criteria"},
50 {"unionrecording", "record multiple choosable variable set"},
51 {"realistic", "mc free using a mva method"},
52 };
53}

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: