Belle II Software development
UnionRecordingAxialSegmentPairFilter.cc
1/**************************************************************************
2 * basf2 (Belle II Analysis Software Framework) *
3 * Author: The Belle II Collaboration *
4 * *
5 * See git log for contributors and copyright holders. *
6 * This file is licensed under LGPL-3.0, see LICENSE.md. *
7 **************************************************************************/
8#include <tracking/trackFindingCDC/filters/axialSegmentPair/UnionRecordingAxialSegmentPairFilter.h>
9
10#include <tracking/trackFindingCDC/filters/axialSegmentPair/BasicAxialSegmentPairVarSet.h>
11#include <tracking/trackFindingCDC/filters/axialSegmentPair/HitGapAxialSegmentPairVarSet.h>
12#include <tracking/trackFindingCDC/filters/axialSegmentPair/FitlessAxialSegmentPairVarSet.h>
13#include <tracking/trackFindingCDC/filters/axialSegmentPair/FitAxialSegmentPairVarSet.h>
14
15#include <tracking/trackFindingCDC/filters/axialSegmentPair/MVAFeasibleAxialSegmentPairFilter.h>
16#include <tracking/trackFindingCDC/filters/axialSegmentPair/MVARealisticAxialSegmentPairFilter.h>
17
18#include <tracking/trackingUtilities/filters/base/UnionRecordingFilter.icc.h>
19
20#include <tracking/trackingUtilities/varsets/BaseVarSet.h>
21
22using namespace Belle2;
23using namespace TrackFindingCDC;
24using namespace TrackingUtilities;
25
27
28std::vector<std::string>
30{
31 std::vector<std::string> varSetNames = Super::getValidVarSetNames();
32 varSetNames.insert(varSetNames.end(), {"basic", "hit_gap", "feasible", "fitless", "fit", "realistic"});
33 return varSetNames;
34}
35
36std::unique_ptr<BaseVarSet<CDCAxialSegmentPair> >
38{
39 if (name == "basic") {
40 return std::make_unique<BasicAxialSegmentPairVarSet>();
41 } else if (name == "hit_gap") {
42 return std::make_unique<HitGapAxialSegmentPairVarSet>();
43 } else if (name == "feasible") {
45 return std::move(filter).releaseVarSet();
46 } else if (name == "fitless") {
47 return std::make_unique<FitlessAxialSegmentPairVarSet>();
48 } else if (name == "fit") {
49 return std::make_unique<FitAxialSegmentPairVarSet>();
50 } else if (name == "realistic") {
52 return std::move(filter).releaseVarSet();
53 } else {
54 return Super::createVarSet(name);
55 }
56}
Filter for the construction of segment pairs based on simple criteria without the common fit.
std::unique_ptr< TrackingUtilities::BaseVarSet< TrackingUtilities::CDCAxialSegmentPair > > createVarSet(const std::string &name) const final
Create a concrete variables set for axial segment pairs from a name.
std::vector< std::string > getValidVarSetNames() const final
Get the valid names of variable sets for axial segment pairs.
Convenience template to create a recording filter for a filter factory.
virtual std::unique_ptr< AVarSet > createVarSet(const std::string &name) const
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:38
Abstract base class for different kinds of events.