10 #include <tracking/trackFindingCDC/filters/segmentRelation/SegmentRelationFilterFactory.h>
12 #include <tracking/trackFindingCDC/filters/segmentRelation/BaseSegmentRelationFilter.h>
13 #include <tracking/trackFindingCDC/filters/segmentRelation/MCSegmentRelationFilter.h>
14 #include <tracking/trackFindingCDC/filters/segmentRelation/UnionRecordingSegmentRelationFilter.h>
15 #include <tracking/trackFindingCDC/filters/segmentRelation/MVAFeasibleSegmentRelationFilter.h>
16 #include <tracking/trackFindingCDC/filters/segmentRelation/MVARealisticSegmentRelationFilter.h>
18 #include <tracking/trackFindingCDC/filters/base/NoneFilter.icc.h>
20 #include <tracking/trackFindingCDC/filters/base/AndFilter.icc.h>
21 #include <tracking/trackFindingCDC/filters/base/NotFilter.icc.h>
23 #include <tracking/trackFindingCDC/filters/base/FilterFactory.icc.h>
27 using namespace TrackFindingCDC;
32 :
Super(defaultFilterName)
38 return "SegmentRelation";
43 return "Segment relation filter to construct a segment network for in super cluster merging";
46 std::map<std::string, std::string>
50 {
"none",
"no segment relation is valid, stop at segment creation."},
51 {
"truth",
"segment relations from 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 {
"false_positive",
"accepts the instances that are really false but are accepted by the default filter"},
56 {
"false_negative",
"accepts the instances that are really true but are rejected by the default filter"},
60 std::unique_ptr<BaseSegmentRelationFilter >
63 if (filterName ==
"none") {
64 return std::make_unique<NoneFilter<BaseSegmentRelationFilter>>();
65 }
else if (filterName ==
"truth") {
66 return std::make_unique<MCSegmentRelationFilter>();
67 }
else if (filterName ==
"unionrecording") {
68 return std::make_unique<UnionRecordingSegmentRelationFilter>();
69 }
else if (filterName ==
"feasible") {
70 return std::make_unique<MVAFeasibleSegmentRelationFilter>();
71 }
else if (filterName ==
"realistic") {
72 return std::make_unique<MVARealisticSegmentRelationFilter>();
73 }
else if (filterName ==
"false_positive") {
75 auto defaultFilter = this->
create(defaultFilterName);
76 std::string truthFilterName =
"truth";
77 auto truthFilter = this->
create(truthFilterName);
78 auto notTruthFilter = std::make_unique<NotFilter<BaseSegmentRelationFilter>>(std::move(truthFilter));
79 return std::make_unique<AndFilter<BaseSegmentRelationFilter>>(std::move(notTruthFilter),
80 std::move(defaultFilter));
81 }
else if (filterName ==
"false_negative") {
83 auto defaultFilter = this->
create(defaultFilterName);
84 std::string truthFilterName =
"truth";
85 auto truthFilter = this->
create(truthFilterName);
86 auto notDefaultFilter = std::make_unique<NotFilter<BaseSegmentRelationFilter>>(std::move(defaultFilter));
87 return std::make_unique<AndFilter<BaseSegmentRelationFilter>>(std::move(notDefaultFilter),
88 std::move(truthFilter));