10 #include <tracking/trackFindingCDC/filters/axialSegmentPair/AxialSegmentPairFilterFactory.h>
12 #include <tracking/trackFindingCDC/filters/axialSegmentPair/BaseAxialSegmentPairFilter.h>
13 #include <tracking/trackFindingCDC/filters/axialSegmentPair/AllAxialSegmentPairFilter.h>
14 #include <tracking/trackFindingCDC/filters/axialSegmentPair/MCAxialSegmentPairFilter.h>
15 #include <tracking/trackFindingCDC/filters/axialSegmentPair/SimpleAxialSegmentPairFilter.h>
16 #include <tracking/trackFindingCDC/filters/axialSegmentPair/UnionRecordingAxialSegmentPairFilter.h>
18 #include <tracking/trackFindingCDC/filters/axialSegmentPair/MVAFeasibleAxialSegmentPairFilter.h>
19 #include <tracking/trackFindingCDC/filters/axialSegmentPair/MVARealisticAxialSegmentPairFilter.h>
21 #include <tracking/trackFindingCDC/filters/base/NoneFilter.icc.h>
23 #include <tracking/trackFindingCDC/filters/base/FilterFactory.icc.h>
26 using namespace TrackFindingCDC;
31 :
Super(defaultFilterName)
37 return "AxialSegmentPair";
42 return "AxialSegment pair filter to construct of a axialSegment pair network";
45 std::map<std::string, std::string>
49 {
"none",
"no axialSegment pair is valid"},
50 {
"all",
"all axialSegment pairs are valid"},
51 {
"truth",
"monte carlo truth"},
52 {
"unionrecording",
"record many multiple choosable variable set"},
53 {
"feasible",
"check if the segment relation is feasible"},
54 {
"realistic",
"check if the segment relation is a good combination"},
55 {
"simple",
"mc free with simple criteria"},
59 std::unique_ptr<Filter<CDCAxialSegmentPair> >
62 if (filterName ==
"none") {
63 return std::make_unique<NoneFilter<BaseAxialSegmentPairFilter> >();
64 }
else if (filterName ==
"all") {
65 return std::make_unique<AllAxialSegmentPairFilter>();
66 }
else if (filterName ==
"truth") {
67 return std::make_unique<MCAxialSegmentPairFilter>();
68 }
else if (filterName ==
"unionrecording") {
69 return std::make_unique<UnionRecordingAxialSegmentPairFilter>();
70 }
else if (filterName ==
"simple") {
71 return std::make_unique<SimpleAxialSegmentPairFilter>();
72 }
else if (filterName ==
"feasible") {
73 return std::make_unique<MVAFeasibleAxialSegmentPairFilter>();
74 }
else if (filterName ==
"realistic") {
75 return std::make_unique<MVARealisticAxialSegmentPairFilter>();