Belle II Software  release-05-01-25
TrackQualityFilterFactory.cc
1 /**************************************************************************
2  * BASF2 (Belle Analysis Framework 2) *
3  * Copyright(C) 2019 - Belle II Collaboration *
4  * *
5  * Author: The Belle II Collaboration *
6  * Contributors: Michael Eliachevitch *
7  * *
8  * This software is provided "as is" without any warranty. *
9  **************************************************************************/
10 #include <tracking/trackFindingCDC/filters/track/TrackQualityFilterFactory.h>
11 
12 #include <tracking/trackFindingCDC/filters/track/BestMatchedTruthVarSet.h>
13 #include <tracking/trackFindingCDC/filters/track/BasicTrackVarSet.h>
14 
15 #include <tracking/trackFindingCDC/filters/base/MVAFilter.icc.h>
16 
17 #include <tracking/trackFindingCDC/filters/base/RecordingFilter.icc.h>
18 #include <tracking/trackFindingCDC/filters/base/TruthVarFilter.icc.h>
19 #include <tracking/trackFindingCDC/filters/base/AllFilter.icc.h>
20 #include <tracking/trackFindingCDC/filters/base/NoneFilter.icc.h>
21 
22 #include <tracking/trackFindingCDC/filters/base/FilterFactory.icc.h>
23 #include <tracking/trackFindingCDC/filters/base/FilterVarSet.icc.h>
24 
25 #include <tracking/trackFindingCDC/varsets/VariadicUnionVarSet.h>
26 
27 using namespace Belle2;
28 using namespace TrackFindingCDC;
29 
30 // these types are the only difference to TrackFilterFactory, since here BestMatchedTruthVarSet is
31 // used whereas the base class uses TruthTrackVarSet
32 namespace {
33  using AllTrackFilter = AllFilter<BaseTrackFilter>;
34  using NoneTrackFilter = NoneFilter<BaseTrackFilter>;
35  using MCTrackFilter = TruthVarFilter<BestMatchedTruthVarSet>;
36  using RecordingTrackFilter =
37  RecordingFilter<VariadicUnionVarSet<BestMatchedTruthVarSet, BasicTrackVarSet>>;
38  using RecordingDataTrackFilter =
39  RecordingFilter<BasicTrackVarSet>;
40  using MVATrackFilter = MVAFilter<BasicTrackVarSet>;
41 } // namespace
42 
44 
46 {
47  return "Track filter for getting the quality indicator for CDC tracks. It should "
48  "distinguish correct PR tracks from fake and if wanted also clone tracks. ";
49 }
50 
51 std::unique_ptr<BaseTrackFilter> TrackQualityFilterFactory::create(
52  const std::string& filterName) const
53 {
54  if (filterName == "none") {
55  return std::make_unique<NoneTrackFilter>();
56  } else if (filterName == "all") {
57  return std::make_unique<AllTrackFilter>();
58  } else if (filterName == "truth") {
59  return std::make_unique<MCTrackFilter>();
60  } else if (filterName == "recording") {
61  return std::make_unique<RecordingTrackFilter>("TrackQualityFilter.root");
62  } else if (filterName == "recording_data") {
63  return std::make_unique<RecordingDataTrackFilter>("TrackQualityFilter.root");
64  } else if (filterName == "eval") {
65  auto recordedVarSets = std::make_unique<UnionVarSet<CDCTrack>>();
66  using TrackFilterVarSet = FilterVarSet<BaseTrackFilter>;
67  recordedVarSets->push_back(std::make_unique<TrackFilterVarSet>("mva", create("mva")));
68  recordedVarSets->push_back(std::make_unique<TrackFilterVarSet>("truth", create("truth")));
69  return std::make_unique<Recording<BaseTrackFilter>>(std::move(recordedVarSets),
70  "TrackQualityFilter_eval.root");
71  } else if (filterName == "mva") {
72  return std::make_unique<MVATrackFilter>("trackfindingcdc_TrackQualityIndicator", 0.10);
73  } else {
74  return Super::create(filterName);
75  }
76 }
Belle2::TrackFindingCDC::FilterFactory< BaseTrackFilter >
Belle2::TrackFindingCDC::TrackQualityFilterFactory::getFilterPurpose
std::string getFilterPurpose() const override
Getter for a descriptive purpose of the constructed filters.
Definition: TrackQualityFilterFactory.cc:45
Belle2::TrackFindingCDC::TrackFilterFactory::create
std::unique_ptr< BaseTrackFilter > create(const std::string &filterName) const override
Create a filter with the given name.
Definition: TrackFilterFactory.cc:71
Belle2
Abstract base class for different kinds of events.
Definition: MillepedeAlgorithm.h:19
Belle2::TrackFindingCDC::FilterVarSet
Class to compute floating point variables from a filter response which can be recorded as a flat TNtu...
Definition: FilterVarSet.dcl.h:57
Belle2::TrackFindingCDC::TrackQualityFilterFactory::create
std::unique_ptr< BaseTrackFilter > create(const std::string &filterName) const override
Create a filter with the given name.
Definition: TrackQualityFilterFactory.cc:51