Belle II Software development
TrackRelationFilterFactory.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/trackRelation/TrackRelationFilterFactory.h>
9
10#include <tracking/trackingUtilities/filters/base/FilterFactory.icc.h>
11
12#include <tracking/trackFindingCDC/filters/trackRelation/BaseTrackRelationFilter.h>
13#include <tracking/trackFindingCDC/filters/trackRelation/AllTrackRelationFilter.h>
14#include <tracking/trackFindingCDC/filters/trackRelation/MCTrackRelationFilter.h>
15#include <tracking/trackFindingCDC/filters/trackRelation/UnionRecordingTrackRelationFilter.h>
16#include <tracking/trackFindingCDC/filters/trackRelation/MVAFeasibleTrackRelationFilter.h>
17#include <tracking/trackFindingCDC/filters/trackRelation/MVARealisticTrackRelationFilter.h>
18#include <tracking/trackFindingCDC/filters/trackRelation/PhiTrackRelationFilter.h>
19
20#include <tracking/trackingUtilities/filters/base/NoneFilter.icc.h>
21
22
23using namespace Belle2;
24using namespace TrackFindingCDC;
25using namespace TrackingUtilities;
26
28
29TrackRelationFilterFactory::TrackRelationFilterFactory(const std::string& defaultFilterName)
30 : Super(defaultFilterName)
31{
32}
33
35{
36 return "TrackRelation";
37}
38
40{
41 return "Track relation filter to construct a track network for merging";
42}
43
44std::map<std::string, std::string>
46{
47 return {
48 {"none", "accepts nothing"},
49 {"all", "accepts everything"},
50 {"truth", "accepts based on monte carlo information"},
51 {"unionrecording", "record multiple choosable variable set"},
52 {"phi", "filter just based on the phi distance"},
53 {"feasible", "a rough efficient compatibility check"},
54 {"realistic", "an expensive pure compatibility check"},
55 };
56}
57
58std::unique_ptr<BaseTrackRelationFilter>
59TrackRelationFilterFactory::create(const std::string& filterName) const
60{
61 if (filterName == "none") {
62 return std::make_unique<NoneFilter<BaseTrackRelationFilter>>();
63 // cppcheck-suppress knownConditionTrueFalse
64 } else if (filterName == "all") {
65 return std::make_unique<AllTrackRelationFilter>();
66 // cppcheck-suppress knownConditionTrueFalse
67 } else if (filterName == "truth") {
68 return std::make_unique<MCTrackRelationFilter>();
69 // cppcheck-suppress knownConditionTrueFalse
70 } else if (filterName == "unionrecording") {
71 return std::make_unique< UnionRecordingTrackRelationFilter>();
72 // cppcheck-suppress knownConditionTrueFalse
73 } else if (filterName == "feasible") {
74 return std::make_unique<MVAFeasibleTrackRelationFilter>();
75 // cppcheck-suppress knownConditionTrueFalse
76 } else if (filterName == "realistic") {
77 return std::make_unique<MVARealisticTrackRelationFilter>();
78 // cppcheck-suppress knownConditionTrueFalse
79 } else if (filterName == "phi") {
80 return std::make_unique<PhiTrackRelationFilter>();
81 } else {
82 return Super::create(filterName);
83 }
84}
std::map< std::string, std::string > getValidFilterNamesAndDescriptions() const final
Getter for valid filter names and a description for each.
std::unique_ptr< BaseTrackRelationFilter > create(const std::string &filterName) const final
Create a filter with the given name.
TrackingUtilities::FilterFactory< BaseTrackRelationFilter > Super
Type of the base class.
std::string getFilterPurpose() const final
Getter for a descriptive purpose of the constructed filters.
std::string getIdentifier() const final
Getter for a short identifier for the factory.
TrackRelationFilterFactory(const std::string &defaultFilterName="realistic")
Constructor forwarding the default filter name.
Factory that can create appropriate filter instances from a name.
virtual std::unique_ptr< BaseTrackRelationFilter > create(const std::string &filterName) const
Abstract base class for different kinds of events.