Belle II Software  release-05-01-25
MCSymmetricFilter.icc.h
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 #pragma once
11 
12 #include <tracking/trackFindingCDC/filters/base/MCSymmetricFilter.dcl.h>
13 
14 #include <tracking/trackFindingCDC/mclookup/CDCMCManager.h>
15 
16 #include <framework/core/ModuleParamList.templateDetails.h>
17 #include <tracking/trackFindingCDC/utilities/StringManipulation.h>
18 
19 #include <string>
20 
21 namespace Belle2 {
27  namespace TrackFindingCDC {
28 
29  template <class AFilter>
30  MCSymmetric<AFilter>::MCSymmetric(bool allowReverse)
31  : Super()
32  , m_param_allowReverse(allowReverse)
33  {
34  }
35 
36  template <class AFilter>
37  MCSymmetric<AFilter>::~MCSymmetric() = default;
38 
39  template <class AFilter>
40  void MCSymmetric<AFilter>::exposeParameters(ModuleParamList* moduleParamList, const std::string& prefix)
41  {
42  Super::exposeParameters(moduleParamList, prefix);
43  moduleParamList->addParameter(prefixed(prefix, "allowReverse"),
44  m_param_allowReverse,
45  "Indication whether the reverse to the truth is accepted"
46  "preserving the progagation reversal symmetry.",
47  m_param_allowReverse);
48  }
49 
50  template <class AFilter>
52  {
53  CDCMCManager::getInstance().requireTruthInformation();
54  Super::initialize();
55  }
56 
57  template <class AFilter>
58  void MCSymmetric<AFilter>::beginEvent()
59  {
60  CDCMCManager::getInstance().fill();
61  Super::beginEvent();
62  }
63 
64  template <class AFilter>
66  {
67  return true;
68  }
69 
70  template <class AFilter>
71  void MCSymmetric<AFilter>::setAllowReverse(bool allowReverse)
72  {
73  m_param_allowReverse = allowReverse;
74  }
75 
76  template <class AFilter>
78  {
79  return m_param_allowReverse;
80  }
81  }
83 }
Belle2::TrackFindingCDC::MCSymmetric::MCSymmetric
MCSymmetric(bool allowReverse=true)
Constructor.
Definition: MCSymmetricFilter.icc.h:38
Belle2::TrackFindingCDC::MCSymmetric
Mixin for filters that use Monte Carlo information.
Definition: MCSymmetricFilter.dcl.h:33
Belle2::ModuleParamList::addParameter
void addParameter(const std::string &name, T &paramVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module list.
Definition: ModuleParamList.templateDetails.h:38
Belle2
Abstract base class for different kinds of events.
Definition: MillepedeAlgorithm.h:19
Belle2::ModuleParamList
The Module parameter list class.
Definition: ModuleParamList.h:46