10 #include <tracking/trackFindingCDC/filters/facetRelation/FacetRelationFilterFactory.h>
12 #include <tracking/trackFindingCDC/filters/facetRelation/BaseFacetRelationFilter.h>
13 #include <tracking/trackFindingCDC/filters/facetRelation/AllFacetRelationFilter.h>
14 #include <tracking/trackFindingCDC/filters/facetRelation/MCFacetRelationFilter.h>
15 #include <tracking/trackFindingCDC/filters/facetRelation/SimpleFacetRelationFilter.h>
16 #include <tracking/trackFindingCDC/filters/facetRelation/Chi2FacetRelationFilter.h>
17 #include <tracking/trackFindingCDC/filters/facetRelation/UnionRecordingFacetRelationFilter.h>
18 #include <tracking/trackFindingCDC/filters/facetRelation/MVAFacetRelationFilter.h>
20 #include <tracking/trackFindingCDC/filters/base/NoneFilter.icc.h>
22 #include <tracking/trackFindingCDC/filters/base/FilterFactory.icc.h>
26 using namespace TrackFindingCDC;
31 :
Super(defaultFilterName)
37 return "FacetRelation";
42 return "Facet relation filter to construct of a facet network";
45 std::map<std::string, std::string>
49 {
"none",
"no facet relation is valid, stop at facet creation."},
50 {
"all",
"all facet relations are valid"},
51 {
"truth",
"facet relations from monte carlo truth"},
52 {
"simple",
"mc free with simple criteria"},
53 {
"chi2",
"mc free based on chi2 fitting"},
54 {
"chi2_old",
"old based on chi2 fitting with single cut regardless of superlayer"},
55 {
"unionrecording",
"record multiple choosable variable sets"},
56 {
"mva",
"filter facets with a mva method"},
60 std::unique_ptr<BaseFacetRelationFilter >
63 if (filterName ==
"none") {
64 return std::make_unique<NoneFilter<BaseFacetRelationFilter>>();
65 }
else if (filterName ==
"all") {
66 return std::make_unique<AllFacetRelationFilter>();
67 }
else if (filterName ==
"truth") {
68 return std::make_unique<MCFacetRelationFilter>();
69 }
else if (filterName ==
"simple") {
70 return std::make_unique<SimpleFacetRelationFilter>();
71 }
else if (filterName ==
"chi2") {
72 return std::make_unique<Chi2FacetRelationFilter>();
73 }
else if (filterName ==
"chi2_old") {
74 return std::make_unique<Chi2FacetRelationFilter>(130.0, 200.0);
75 }
else if (filterName ==
"unionrecording") {
76 return std::make_unique<UnionRecordingFacetRelationFilter>();
77 }
else if (filterName ==
"mva") {
78 return std::make_unique<MVAFacetRelationFilter>();