Belle II Software development
SegmentFilterFactory Class Reference

Factory that can create appropriate segment filters for new tracks from associated names. More...

#include <SegmentFilterFactory.h>

Inheritance diagram for SegmentFilterFactory:
FilterFactory< BaseSegmentFilter >

Public Types

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

Public Member Functions

 SegmentFilterFactory (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< BaseSegmentFiltercreate (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< BaseSegmentFilter >
 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 filters for new tracks from associated names.

Definition at line 24 of file SegmentFilterFactory.h.

Member Typedef Documentation

◆ CreatedFilter

using CreatedFilter = BaseSegmentFilter
inherited

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 SegmentFilterFactory.h.

Constructor & Destructor Documentation

◆ SegmentFilterFactory()

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

Constructor forwarding the default filter name.

Definition at line 39 of file SegmentFilterFactory.cc.

40 : Super(defaultFilterName)
41{
42}
FilterFactory< BaseSegmentFilter > Super
Type of the base class.

Member Function Documentation

◆ create()

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

Create a filter with the given name.

Reimplemented from FilterFactory< BaseSegmentFilter >.

Definition at line 67 of file SegmentFilterFactory.cc.

68{
69 if (filterName == "none") {
70 return std::make_unique<NoneSegmentFilter>();
71 // cppcheck-suppress knownConditionTrueFalse
72 } else if (filterName == "all") {
73 return std::make_unique<AllSegmentFilter>();
74 // cppcheck-suppress knownConditionTrueFalse
75 } else if (filterName == "bkg_truth") {
76 return std::make_unique<BkgMCSegmentFilter>();
77 // cppcheck-suppress knownConditionTrueFalse
78 } else if (filterName == "bkg_recording") {
79 return std::make_unique<BkgRecordingSegmentFilter>("BackgroundSegmentFilter.root");
80 // cppcheck-suppress knownConditionTrueFalse
81 } else if (filterName == "bkg_mva") {
82 return std::make_unique<BkgMVASegmentFilter>("trackfindingcdc_BackgroundSegmentFilter");
83 } else {
84 return Super::create(filterName);
85 }
86}
virtual std::unique_ptr< BaseSegmentFilter > 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< BaseSegmentFilter >.

Definition at line 49 of file SegmentFilterFactory.cc.

50{
51 return "Segment filter to reject fakes";
52}

◆ getIdentifier()

std::string getIdentifier ( ) const
overridevirtual

Getter for a short identifier for the factory.

Implements FilterFactory< BaseSegmentFilter >.

Definition at line 44 of file SegmentFilterFactory.cc.

45{
46 return "Segment";
47}

◆ getValidFilterNamesAndDescriptions()

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

Getter for valid filter names and a description for each.

Implements FilterFactory< BaseSegmentFilter >.

Definition at line 55 of file SegmentFilterFactory.cc.

56{
57 return {
58 {"none", "no segment track combination is valid"},
59 {"all", "filter out all segments as background"},
60 {"bkg_truth", "monte carlo truth"},
61 {"bkg_recording", "record variables to a TTree"},
62 {"bkg_mva", "test with a mva method"}
63 };
64}

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: