Belle II Software development
UnionRecordingSegmentPairRelationFilter.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/segmentPairRelation/UnionRecordingSegmentPairRelationFilter.h>
9
10#include <tracking/trackFindingCDC/filters/segmentPairRelation/BasicSegmentPairRelationVarSet.h>
11#include <tracking/trackFindingCDC/filters/segmentPairRelation/FitSegmentPairRelationVarSet.h>
12#include <tracking/trackFindingCDC/filters/segmentPairRelation/TruthSegmentPairRelationVarSet.h>
13
14#include <tracking/trackFindingCDC/filters/segmentPairRelation/MVARealisticSegmentPairRelationFilter.h>
15
16#include <tracking/trackingUtilities/filters/base/UnionRecordingFilter.icc.h>
17
18
19using namespace Belle2;
20using namespace TrackFindingCDC;
21using namespace TrackingUtilities;
22
24
25std::vector<std::string>
27{
28 std::vector<std::string> varSetNames = Super::getValidVarSetNames();
29 varSetNames.insert(varSetNames.end(), {"basic", "fit", "realistic", "truth"});
30 return varSetNames;
31}
32
33std::unique_ptr<BaseVarSet<Relation<const CDCSegmentPair> > >
35{
36 if (name == "basic") {
37 return std::make_unique<BasicSegmentPairRelationVarSet>();
38 } else if (name == "fit") {
39 return std::make_unique<FitSegmentPairRelationVarSet>();
40 } else if (name == "realistic") {
42 return std::move(filter).releaseVarSet();
43 } else if (name == "truth") {
44 return std::make_unique<TruthSegmentPairRelationVarSet>();
45 }
46 return Super::createVarSet(name);
47}
std::vector< std::string > getValidVarSetNames() const final
Get the valid names of variable sets for segment pair relations.
std::unique_ptr< TrackingUtilities::BaseVarSet< TrackingUtilities::Relation< const TrackingUtilities::CDCSegmentPair > > > createVarSet(const std::string &name) const final
Create a concrete variables set for segment pair relations from a name.
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.