Belle II Software  release-05-02-19
SegmentTripleFilterFactory.cc
1 /**************************************************************************
2  * BASF2 (Belle Analysis Framework 2) *
3  * Copyright(C) 2015 - Belle II Collaboration *
4  * *
5  * Author: The Belle II Collaboration *
6  * Contributors: Oliver Frost *
7  * *
8  * This software is provided "as is" without any warranty. *
9  **************************************************************************/
10 #include <tracking/trackFindingCDC/filters/segmentTriple/SegmentTripleFilterFactory.h>
11 
12 #include <tracking/trackFindingCDC/filters/segmentTriple/BaseSegmentTripleFilter.h>
13 #include <tracking/trackFindingCDC/filters/segmentTriple/AllSegmentTripleFilter.h>
14 #include <tracking/trackFindingCDC/filters/segmentTriple/MCSegmentTripleFilter.h>
15 #include <tracking/trackFindingCDC/filters/segmentTriple/SimpleSegmentTripleFilter.h>
16 
17 #include <tracking/trackFindingCDC/filters/base/NoneFilter.icc.h>
18 #include <tracking/trackFindingCDC/filters/base/FilterFactory.icc.h>
19 
20 
21 using namespace Belle2;
22 using namespace TrackFindingCDC;
23 
25 
26 SegmentTripleFilterFactory::SegmentTripleFilterFactory(const std::string& defaultFilterName)
27  : Super(defaultFilterName)
28 {
29 }
30 
32 {
33  return "SegmentTriple";
34 }
35 
37 {
38  return "Segment triple filter to construct of a segment triple network";
39 }
40 
41 std::map<std::string, std::string>
43 {
44  return {
45  {"none", "no segment triple is valid"},
46  {"all", "all segment triples are valid"},
47  {"truth", "monte carlo truth"},
48  {"simple", "mc free with simple criteria"},
49  };
50 }
51 
52 std::unique_ptr<Filter<CDCSegmentTriple> >
53 SegmentTripleFilterFactory::create(const std::string& filterName) const
54 {
55  if (filterName == "none") {
56  return std::make_unique<NoneFilter<BaseSegmentTripleFilter>>();
57  } else if (filterName == "all") {
58  return std::make_unique<AllSegmentTripleFilter>();
59  } else if (filterName == "truth") {
60  return std::make_unique<MCSegmentTripleFilter>();
61  } else if (filterName == "simple") {
62  return std::make_unique<SimpleSegmentTripleFilter>();
63  } else {
64  return Super::create(filterName);
65  }
66 }
Belle2::TrackFindingCDC::FilterFactory< BaseSegmentTripleFilter >
Belle2::TrackFindingCDC::FilterFactory< BaseSegmentTripleFilter >::create
virtual std::unique_ptr< BaseSegmentTripleFilter > create(const std::string &filterName) const
Create a filter with the given name, does not set filter specific parameters.
Definition: FilterFactory.icc.h:54
Belle2::TrackFindingCDC::SegmentTripleFilterFactory::getValidFilterNamesAndDescriptions
std::map< std::string, std::string > getValidFilterNamesAndDescriptions() const override
Getter for valid filter names and a description for each.
Definition: SegmentTripleFilterFactory.cc:42
Belle2::TrackFindingCDC::SegmentTripleFilterFactory::getIdentifier
std::string getIdentifier() const override
Getter for a short identifier for the factory.
Definition: SegmentTripleFilterFactory.cc:31
Belle2::TrackFindingCDC::SegmentTripleFilterFactory::SegmentTripleFilterFactory
SegmentTripleFilterFactory(const std::string &defaultFilterName="simple")
Constructor forwarding the default filter name.
Definition: SegmentTripleFilterFactory.cc:26
Belle2
Abstract base class for different kinds of events.
Definition: MillepedeAlgorithm.h:19
Belle2::TrackFindingCDC::SegmentTripleFilterFactory::create
std::unique_ptr< BaseSegmentTripleFilter > create(const std::string &filterName) const override
Create a filter with the given name.
Definition: SegmentTripleFilterFactory.cc:53
Belle2::TrackFindingCDC::SegmentTripleFilterFactory::getFilterPurpose
std::string getFilterPurpose() const override
Getter for a descriptive purpose of the constructed filters.
Definition: SegmentTripleFilterFactory.cc:36