Belle II Software  release-05-01-25
UnionRecordingAxialSegmentPairFilter.cc
1 /**************************************************************************
2  * BASF2 (Belle Analysis Framework 2) *
3  * Copyright(C) 2015 - Belle II Collaboration *
4  * *
5  * Author: The Belle II Collaboration *
6  * Contributors: Oliver Frost *
7  * *
8  * This software is provided "as is" without any warranty. *
9  **************************************************************************/
10 #include <tracking/trackFindingCDC/filters/axialSegmentPair/UnionRecordingAxialSegmentPairFilter.h>
11 
12 #include <tracking/trackFindingCDC/filters/axialSegmentPair/BasicAxialSegmentPairVarSet.h>
13 #include <tracking/trackFindingCDC/filters/axialSegmentPair/HitGapAxialSegmentPairVarSet.h>
14 #include <tracking/trackFindingCDC/filters/axialSegmentPair/FitlessAxialSegmentPairVarSet.h>
15 #include <tracking/trackFindingCDC/filters/axialSegmentPair/FitAxialSegmentPairVarSet.h>
16 
17 #include <tracking/trackFindingCDC/filters/axialSegmentPair/MVAFeasibleAxialSegmentPairFilter.h>
18 #include <tracking/trackFindingCDC/filters/axialSegmentPair/MVARealisticAxialSegmentPairFilter.h>
19 
20 #include <tracking/trackFindingCDC/filters/base/UnionRecordingFilter.icc.h>
21 
22 #include <tracking/trackFindingCDC/varsets/BaseVarSet.h>
23 
24 using namespace Belle2;
25 using namespace TrackFindingCDC;
26 
28 
29 std::vector<std::string>
31 {
32  std::vector<std::string> varSetNames = Super::getValidVarSetNames();
33  varSetNames.insert(varSetNames.end(), {"basic", "hit_gap", "feasible", "fitless", "fit", "realistic"});
34  return varSetNames;
35 }
36 
37 std::unique_ptr<BaseVarSet<CDCAxialSegmentPair> >
39 {
40  if (name == "basic") {
41  return std::make_unique<BasicAxialSegmentPairVarSet>();
42  } else if (name == "hit_gap") {
43  return std::make_unique<HitGapAxialSegmentPairVarSet>();
44  } else if (name == "feasible") {
46  return std::move(filter).releaseVarSet();
47  } else if (name == "fitless") {
48  return std::make_unique<FitlessAxialSegmentPairVarSet>();
49  } else if (name == "fit") {
50  return std::make_unique<FitAxialSegmentPairVarSet>();
51  } else if (name == "realistic") {
53  return std::move(filter).releaseVarSet();
54  } else {
55  return Super::createVarSet(name);
56  }
57 }
Belle2::TrackFindingCDC::UnionRecording< AxialSegmentPairFilterFactory ::CreatedFilter >::getValidVarSetNames
virtual std::vector< std::string > getValidVarSetNames() const
Getter for the list of valid names of concret variable sets.
Definition: UnionRecordingFilter.icc.h:101
Belle2::TrackFindingCDC::MVARealisticAxialSegmentPairFilter
Final filter for the constuction of segment pairs.
Definition: MVARealisticAxialSegmentPairFilter.h:40
Belle2::TrackFindingCDC::UnionRecordingFilter< AxialSegmentPairFilterFactory >
Belle2::TrackFindingCDC::MVAFeasibleAxialSegmentPairFilter
Filter for the constuction of segment pairs based on simple criteria without the common fit.
Definition: MVAFeasibleAxialSegmentPairFilter.h:39
Belle2::filter
std::map< ExpRun, std::pair< double, double > > filter(const std::map< ExpRun, std::pair< double, double >> &runs, double cut, std::map< ExpRun, std::pair< double, double >> &runsRemoved)
filter events to remove runs shorter than cut, it stores removed runs in runsRemoved
Definition: Splitter.cc:43
Belle2
Abstract base class for different kinds of events.
Definition: MillepedeAlgorithm.h:19
Belle2::TrackFindingCDC::UnionRecording< AxialSegmentPairFilterFactory ::CreatedFilter >::createVarSet
virtual std::unique_ptr< AVarSet > createVarSet(const std::string &name) const
Create a variable set for the given name.
Definition: UnionRecordingFilter.icc.h:131
Belle2::TrackFindingCDC::UnionRecordingAxialSegmentPairFilter::getValidVarSetNames
std::vector< std::string > getValidVarSetNames() const final
Get the valid names of variable sets for axial segment pairs.
Definition: UnionRecordingAxialSegmentPairFilter.cc:30
Belle2::TrackFindingCDC::UnionRecordingAxialSegmentPairFilter::createVarSet
std::unique_ptr< BaseVarSet< CDCAxialSegmentPair > > createVarSet(const std::string &name) const final
Create a concrete variables set for axial segment pairs from a name.
Definition: UnionRecordingAxialSegmentPairFilter.cc:38