Belle II Software  release-05-01-25
CDCPathFilterFactory.cc
1 /**************************************************************************
2  * BASF2 (Belle Analysis Framework 2) *
3  * Copyright(C) 2017 - Belle II Collaboration *
4  * *
5  * Author: The Belle II Collaboration *
6  * Contributors: Nils Braun *
7  * *
8  * This software is provided "as is" without any warranty. *
9  **************************************************************************/
10 #include <tracking/ckf/cdc/filters/paths/CDCPathFilterFactory.h>
11 
12 #include <tracking/trackFindingCDC/filters/base/FilterFactory.icc.h>
13 
14 #include <tracking/ckf/cdc/filters/paths/SizeCDCPathFilter.h>
15 #include <tracking/trackFindingCDC/filters/base/AllFilter.icc.h>
16 #include <tracking/trackFindingCDC/filters/base/AndFilter.icc.h>
17 #include <tracking/trackFindingCDC/filters/base/NoneFilter.icc.h>
18 #include <tracking/trackFindingCDC/filters/base/RecordingFilter.icc.h>
19 
20 #include <tracking/trackFindingCDC/varsets/VariadicUnionVarSet.h>
21 
22 #include <tracking/ckf/cdc/filters/paths/CDCPathBasicVarSet.h>
23 #include <tracking/ckf/cdc/filters/paths/CDCPathTruthVarSet.h>
24 #include <tracking/ckf/cdc/filters/paths/CDCfromEclPathTruthVarSet.h>
25 
26 #include <tracking/ckf/cdc/filters/paths/SeedChargeCDCPathFilter.h>
27 
28 using namespace Belle2;
29 using namespace TrackFindingCDC;
30 
31 namespace {
33  using RecordingCDCPathFilter = RecordingFilter<VariadicUnionVarSet<CDCPathBasicVarSet, CDCPathTruthVarSet>>;
35  using RecordingCDCfromEclPathFilter = RecordingFilter<VariadicUnionVarSet<CDCPathBasicVarSet, CDCfromEclPathTruthVarSet>>;
37  using AndCDCPathFilter = AndFilter<BaseCDCPathFilter>;
38 }
39 
40 CDCPathFilterFactory::CDCPathFilterFactory(const std::string& defaultFilterName)
41  : Super(defaultFilterName)
42 {
43 }
44 
46 
48 {
49  return "CDCCKFPath";
50 }
51 
53 {
54  return "Reject cdc ckf paths";
55 }
56 
57 std::map<std::string, std::string> CDCPathFilterFactory::getValidFilterNamesAndDescriptions() const
58 {
59  return {
60  {"none", "no track combination is valid"},
61  {"size", "very rough filtering"},
62  {"recording", "record variables to a TTree"},
63  {"size_and_recording", "record variables to a TTree"},
64  {"recording_fromEcl", "record variables to a TTree"},
65  {"size_and_recording_fromEcl", "record variables to a TTree"},
66  {"seedCharge", "charge of path corresponds to charge of seed"},
67  {"seedCharge_and_recording_fromEcl", "record variables to a TTree"}
68  //{"mc_truth", "Extrapolation and update"},
69  };
70 }
71 
72 std::unique_ptr<BaseCDCPathFilter>
73 CDCPathFilterFactory::create(const std::string& filterName) const
74 {
75  if (filterName == "none") {
76  return std::make_unique<TrackFindingCDC::NoneFilter<BaseCDCPathFilter>>();
77  } else if (filterName == "all") {
78  return std::make_unique<TrackFindingCDC::AllFilter<BaseCDCPathFilter>>();
79  } else if (filterName == "size") {
80  return std::make_unique<SizeCDCPathFilter>();
81  //} else if (filterName == "mc_truth") {
82  // return std::make_unique<MCTruthCDCPathFilter>();
83  } else if (filterName == "recording") {
84  return std::make_unique<RecordingCDCPathFilter>("CDCPathFilter.root");
85  } else if (filterName == "size_and_recording") {
86  return std::make_unique<AndCDCPathFilter>(
87  std::make_unique<RecordingCDCPathFilter>("CDCPathFilter.root"),
88  std::make_unique<SizeCDCPathFilter>()
89  );
90  } else if (filterName == "recording_fromEcl") {
91  return std::make_unique<RecordingCDCfromEclPathFilter>("CDCfromEclPathFilter.root");
92  } else if (filterName == "size_and_recording_fromEcl") {
93  return std::make_unique<AndCDCPathFilter>(
94  std::make_unique<RecordingCDCfromEclPathFilter>("CDCfromEclPathFilter.root"),
95  std::make_unique<SizeCDCPathFilter>()
96  );
97  } else if (filterName == "seedCharge") {
98  return std::make_unique<SeedChargeCDCPathFilter>();
99  } else if (filterName == "seedCharge_and_recording_fromEcl") {
100  return std::make_unique<AndCDCPathFilter>(
101  std::make_unique<RecordingCDCfromEclPathFilter>("CDCfromEclPathFilter.root"),
102  std::make_unique<SeedChargeCDCPathFilter>()
103  );
104 
105  } else {
106  return Super::create(filterName);
107  }
108 }
Belle2::TrackFindingCDC::FilterFactory< BaseCDCPathFilter >
Belle2::CDCPathFilterFactory::getIdentifier
std::string getIdentifier() const override
Getter for a short identifier for the factory.
Definition: CDCPathFilterFactory.cc:47
Belle2::TrackFindingCDC::FilterFactory< BaseCDCPathFilter >::create
virtual std::unique_ptr< BaseCDCPathFilter > create(const std::string &filterName) const
Create a filter with the given name, does not set filter specific parameters.
Definition: FilterFactory.icc.h:54
Belle2::CDCPathFilterFactory::CDCPathFilterFactory
CDCPathFilterFactory(const std::string &defaultFilterName="size")
Constructor forwarding the default filter name.
Definition: CDCPathFilterFactory.cc:40
Belle2::CDCPathFilterFactory::~CDCPathFilterFactory
~CDCPathFilterFactory()
Default destructor.
Belle2::CDCPathFilterFactory::getValidFilterNamesAndDescriptions
std::map< std::string, std::string > getValidFilterNamesAndDescriptions() const override
Getter for valid filter names and a description for each.
Definition: CDCPathFilterFactory.cc:57
Belle2
Abstract base class for different kinds of events.
Definition: MillepedeAlgorithm.h:19
Belle2::CDCPathFilterFactory::getFilterPurpose
std::string getFilterPurpose() const override
Getter for a descriptive purpose of the constructed filters.
Definition: CDCPathFilterFactory.cc:52
Belle2::CDCPathFilterFactory::create
std::unique_ptr< BaseCDCPathFilter > create(const std::string &filterName) const override
Create a filter with the given name.
Definition: CDCPathFilterFactory.cc:73