Belle II Software development
SegmentPairFilterFactory.cc
1/**************************************************************************
2 * basf2 (Belle II Analysis Software Framework) *
3 * Author: The Belle II Collaboration *
4 * *
5 * See git log for contributors and copyright holders. *
6 * This file is licensed under LGPL-3.0, see LICENSE.md. *
7 **************************************************************************/
8#include <tracking/trackFindingCDC/filters/segmentPair/SegmentPairFilterFactory.h>
9
10#include <tracking/trackFindingCDC/filters/segmentPair/BaseSegmentPairFilter.h>
11#include <tracking/trackFindingCDC/filters/segmentPair/AllSegmentPairFilter.h>
12#include <tracking/trackFindingCDC/filters/segmentPair/MCSegmentPairFilter.h>
13#include <tracking/trackFindingCDC/filters/segmentPair/FitlessSegmentPairFilter.h>
14#include <tracking/trackFindingCDC/filters/segmentPair/SimpleSegmentPairFilter.h>
15#include <tracking/trackFindingCDC/filters/segmentPair/UnionRecordingSegmentPairFilter.h>
16#include <tracking/trackFindingCDC/filters/segmentPair/MVAFeasibleSegmentPairFilter.h>
17#include <tracking/trackFindingCDC/filters/segmentPair/MVARealisticSegmentPairFilter.h>
18
19#include <tracking/trackingUtilities/filters/base/NoneFilter.icc.h>
20#include <tracking/trackingUtilities/filters/base/FilterFactory.icc.h>
21
22
23using namespace Belle2;
24using namespace TrackFindingCDC;
25using namespace TrackingUtilities;
26
28
29SegmentPairFilterFactory::SegmentPairFilterFactory(const std::string& defaultFilterName)
30 : Super(defaultFilterName)
31{
32}
33
35{
36 return "SegmentPair";
37}
38
40{
41 return "Segment pair filter to construct of a segment pair network";
42}
43
44std::map<std::string, std::string>
46{
47 return {
48 {"none", "no segment pair is valid"},
49 {"all", "all segment pairs are valid"},
50 {"truth", "monte carlo truth"},
51 {"fitless", "mc free with simple criteria without the common fit"},
52 {"simple", "mc free with simple criteria"},
53 {"unionrecording", "record many multiple choosable variable set"},
54 {"feasible", "multivariat method based on variables of the first and last hit in each segment meant as precut"},
55 {"realistic", "realistic filter using a common fit and combination of all information with an mva"},
56 };
57}
58
59std::unique_ptr<Filter<CDCSegmentPair> >
60SegmentPairFilterFactory::create(const std::string& filterName) const
61{
62 if (filterName == "none") {
63 return std::make_unique<NoneFilter<BaseSegmentPairFilter>>();
64 // cppcheck-suppress knownConditionTrueFalse
65 } else if (filterName == "all") {
66 return std::make_unique<AllSegmentPairFilter>();
67 // cppcheck-suppress knownConditionTrueFalse
68 } else if (filterName == "truth") {
69 return std::make_unique<MCSegmentPairFilter>();
70 // cppcheck-suppress knownConditionTrueFalse
71 } else if (filterName == "fitless") {
72 return std::make_unique<FitlessSegmentPairFilter>();
73 // cppcheck-suppress knownConditionTrueFalse
74 } else if (filterName == "simple") {
75 return std::make_unique<SimpleSegmentPairFilter>();
76 // cppcheck-suppress knownConditionTrueFalse
77 } else if (filterName == "unionrecording") {
78 return std::make_unique<UnionRecordingSegmentPairFilter>();
79 // cppcheck-suppress knownConditionTrueFalse
80 } else if (filterName == "feasible") {
81 return std::make_unique<MVAFeasibleSegmentPairFilter>();
82 // cppcheck-suppress knownConditionTrueFalse
83 } else if (filterName == "realistic") {
84 return std::make_unique<MVARealisticSegmentPairFilter>();
85 } else {
86 return Super::create(filterName);
87 }
88}
TrackingUtilities::FilterFactory< BaseSegmentPairFilter > Super
Type of the base class.
std::unique_ptr< BaseSegmentPairFilter > create(const std::string &filterName) const final
Create a filter with the given name.
std::map< std::string, std::string > getValidFilterNamesAndDescriptions() const final
Getter for valid filter names and a description for each.
std::string getFilterPurpose() const final
Getter for a descriptive purpose of the constructed filters.
SegmentPairFilterFactory(const std::string &defaultFilterName="realistic")
Constructor forwarding the default filter name.
std::string getIdentifier() const final
Getter for a short identifier for the factory.
Factory that can create appropriate filter instances from a name.
virtual std::unique_ptr< BaseSegmentPairFilter > create(const std::string &filterName) const
Abstract base class for different kinds of events.