8#include <tracking/ckf/pxd/filters/states/PXDStateFilterFactory.h>
10#include <tracking/trackFindingCDC/filters/base/FilterFactory.icc.h>
11#include <tracking/trackFindingCDC/filters/base/AllFilter.icc.h>
12#include <tracking/trackFindingCDC/filters/base/NoneFilter.icc.h>
13#include <tracking/trackFindingCDC/filters/base/AndFilter.icc.h>
14#include <tracking/trackFindingCDC/filters/base/NegativeFilter.icc.h>
15#include <tracking/trackFindingCDC/filters/base/ChoosableFromVarSetFilter.icc.h>
16#include <tracking/trackFindingCDC/filters/base/RecordingFilter.icc.h>
17#include <tracking/trackFindingCDC/filters/base/MVAFilter.icc.h>
18#include <tracking/trackFindingCDC/filters/base/SloppyFilter.icc.h>
19#include <tracking/trackFindingCDC/filters/base/TruthVarFilter.icc.h>
21#include <tracking/trackFindingCDC/varsets/VariadicUnionVarSet.h>
23#include <tracking/ckf/general/filters/AdvanceFilter.h>
24#include <tracking/ckf/general/filters/KalmanFilter.h>
25#include <tracking/ckf/pxd/utilities/PXDAdvancer.h>
26#include <tracking/ckf/pxd/utilities/PXDKalmanStepper.h>
28#include <tracking/ckf/pxd/filters/states/PXDStateBasicVarSet.h>
29#include <tracking/ckf/pxd/filters/states/PXDStateTruthVarSet.h>
30#include <tracking/ckf/pxd/filters/states/SimplePXDStateFilter.h>
31#include <tracking/ckf/pxd/filters/states/AllPXDStateFilter.h>
32#include <tracking/ckf/pxd/filters/states/NonIPCrossingPXDStateFilter.h>
35using namespace TrackFindingCDC;
57 class SloppyRecordingPXDStateFilter :
public RecordingPXDStateFilter {
59 explicit SloppyRecordingPXDStateFilter(
const std::string& defaultRootFileName) : RecordingPXDStateFilter(defaultRootFileName)
61 setSkimFilter(std::make_unique<SloppyMCPXDStateFilter>());
68 :
Super(defaultFilterName)
81 return "Reject PXD CKF states. ";
87 {
"none",
"no track combination is valid"},
88 {
"all",
"set all track combinations as good"},
89 {
"advance",
"extrapolate the states"},
90 {
"fit",
"update the mSoP using a Kalman Filter"},
91 {
"truth",
"monte carlo truth"},
92 {
"ordering_truth",
"monte carlo truth ordering"},
93 {
"sloppy_truth",
"sloppy monte carlo truth"},
94 {
"simple",
"simple filter to be used in pxd"},
95 {
"recording",
"record variables to a TTree"},
98 {
"recording_with_direction_check",
"record variables to a TTree with direction check"},
99 {
"mva_with_direction_check",
"MVA filter with direction check"},
100 {
"mva",
"MVA filter"},
101 {
"sloppy_recording",
"record variables to a TTree"},
105std::unique_ptr<BasePXDStateFilter>
108 if (filterName ==
"none") {
109 return std::make_unique<TrackFindingCDC::NoneFilter<BasePXDStateFilter>>();
110 }
else if (filterName ==
"all") {
111 return std::make_unique<AllPXDStateFilter>();
112 }
else if (filterName ==
"advance") {
113 return std::make_unique<AdvanceFilter<CKFToPXDState, PXDAdvancer>>();
114 }
else if (filterName ==
"fit") {
115 return std::make_unique<KalmanFilter<CKFToPXDState, PXDKalmanStepper>>();
116 }
else if (filterName ==
"simple") {
117 return std::make_unique<SimplePXDStateFilter>();
118 }
else if (filterName ==
"truth") {
119 return std::make_unique<MCPXDStateFilter>();
120 }
else if (filterName ==
"ordering_truth") {
121 return std::make_unique<MCOrderingPXDStateFilter>(
"truth_inverted");
122 }
else if (filterName ==
"sloppy_truth") {
123 return std::make_unique<SloppyMCPXDStateFilter>();
124 }
else if (filterName ==
"recording") {
125 return std::make_unique<RecordingPXDStateFilter>(
"PXDStateFilter.root");
134 }
else if (filterName ==
"recording_with_direction_check") {
135 return std::make_unique<AndPXDStateFilter>(
136 std::make_unique<NonIPCrossingPXDStateFilter>(),
137 std::make_unique<RecordingPXDStateFilter>(
"PXDStateFilter.root"));
138 }
else if (filterName ==
"mva_with_direction_check") {
139 return std::make_unique<AndPXDStateFilter>(
140 std::make_unique<NonIPCrossingPXDStateFilter>(),
141 std::make_unique<MVAPXDStateFilter>(
"ckf_CDCPXDStateFilter_1"));
142 }
else if (filterName ==
"mva") {
143 return std::make_unique<AndPXDStateFilter>(
144 std::make_unique<MVAPXDStateFilter>(
"ckf_CDCPXDStateFilter_1"),
145 std::make_unique<NonIPCrossingPXDStateFilter>());
146 }
else if (filterName ==
"sloppy_recording") {
147 return std::make_unique<SloppyRecordingPXDStateFilter>(
"PXDStateFilter.root");
std::map< std::string, std::string > getValidFilterNamesAndDescriptions() const override
Getter for valid filter names and a description for each.
PXDStateFilterFactory(const std::string &defaultFilterName="all")
Constructor forwarding the default filter name.
std::unique_ptr< BasePXDStateFilter > create(const std::string &filterName) const override
Create a filter with the given name.
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.
~PXDStateFilterFactory()
Default destructor.
Filter adapter type that joins two filter results in an and like fashion.
Convince template to create a filter returning on variable from a set of variables.
virtual std::unique_ptr< BasePXDStateFilter > create(const std::string &filterName) const
Create a filter with the given name, does not set filter specific parameters.
Filter adapter type that negates the acceptance criterion for cross checks.
Convenience template to create a recording filter for a set of variables.
A filter that accepts every "sloppinessFactor"th candidate on average (random selection)
MC Filter Type using a VarSet and the truth variable in it.
Abstract base class for different kinds of events.