Belle II Software development
SegmentTripleFilterFactory.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/segmentTriple/SegmentTripleFilterFactory.h>
9
10#include <tracking/trackFindingCDC/filters/segmentTriple/BaseSegmentTripleFilter.h>
11#include <tracking/trackFindingCDC/filters/segmentTriple/AllSegmentTripleFilter.h>
12#include <tracking/trackFindingCDC/filters/segmentTriple/MCSegmentTripleFilter.h>
13#include <tracking/trackFindingCDC/filters/segmentTriple/SimpleSegmentTripleFilter.h>
14
15#include <tracking/trackingUtilities/filters/base/NoneFilter.icc.h>
16#include <tracking/trackingUtilities/filters/base/FilterFactory.icc.h>
17
18
19using namespace Belle2;
20using namespace TrackFindingCDC;
21using namespace TrackingUtilities;
22
24
25SegmentTripleFilterFactory::SegmentTripleFilterFactory(const std::string& defaultFilterName)
26 : Super(defaultFilterName)
27{
28}
29
31{
32 return "SegmentTriple";
33}
34
36{
37 return "Segment triple filter to construct of a segment triple network";
38}
39
40std::map<std::string, std::string>
42{
43 return {
44 {"none", "no segment triple is valid"},
45 {"all", "all segment triples are valid"},
46 {"truth", "monte carlo truth"},
47 {"simple", "mc free with simple criteria"},
48 };
49}
50
51std::unique_ptr<Filter<CDCSegmentTriple> >
52SegmentTripleFilterFactory::create(const std::string& filterName) const
53{
54 if (filterName == "none") {
55 return std::make_unique<NoneFilter<BaseSegmentTripleFilter>>();
56 // cppcheck-suppress knownConditionTrueFalse
57 } else if (filterName == "all") {
58 return std::make_unique<AllSegmentTripleFilter>();
59 // cppcheck-suppress knownConditionTrueFalse
60 } else if (filterName == "truth") {
61 return std::make_unique<MCSegmentTripleFilter>();
62 // cppcheck-suppress knownConditionTrueFalse
63 } else if (filterName == "simple") {
64 return std::make_unique<SimpleSegmentTripleFilter>();
65 } else {
66 return Super::create(filterName);
67 }
68}
std::unique_ptr< BaseSegmentTripleFilter > create(const std::string &filterName) const override
Create a filter with the given name.
TrackingUtilities::FilterFactory< BaseSegmentTripleFilter > Super
Type of the base class.
std::map< std::string, std::string > getValidFilterNamesAndDescriptions() const override
Getter for valid filter names and a description for each.
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.
SegmentTripleFilterFactory(const std::string &defaultFilterName="simple")
Constructor forwarding the default filter name.
Factory that can create appropriate filter instances from a name.
virtual std::unique_ptr< BaseSegmentTripleFilter > create(const std::string &filterName) const
Abstract base class for different kinds of events.