Belle II Software  release-05-01-25
AndFilter.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/AndFilter.dcl.h>
13 
14 #include <tracking/trackFindingCDC/numerics/Weight.h>
15 
16 #include <cmath>
17 
18 namespace Belle2 {
23  namespace TrackFindingCDC {
24 
25  template <class AFilter>
26  AndFilter<AFilter>::AndFilter(std::unique_ptr<AFilter> lhsFilter,
27  std::unique_ptr<AFilter> rhsFilter)
28  : m_lhsFilter(std::move(lhsFilter))
29  , m_rhsFilter(std::move(rhsFilter))
30  {
31  this->addProcessingSignalListener(m_lhsFilter.get());
32  this->addProcessingSignalListener(m_rhsFilter.get());
33  }
34 
35  template <class AFilter>
37 
38  template <class AFilter>
40  const std::string& prefix)
41  {
42  if (m_lhsFilter) m_lhsFilter->exposeParameters(moduleParamList, prefix);
43  if (m_rhsFilter) m_rhsFilter->exposeParameters(moduleParamList, prefix);
44  }
45 
46  template<class AFilter>
47  Weight AndFilter<AFilter>::operator()(const typename AFilter::Object& obj)
48  {
49  Weight lhsResult = (*m_lhsFilter)(obj);
50 
51  if (std::isnan(lhsResult)) {
52  return NAN;
53  } else {
54  Weight rhsResult = (*m_rhsFilter)(obj);
55  return rhsResult;
56  }
57  }
58  }
60 }
Belle2::TrackFindingCDC::AndFilter::m_lhsFilter
std::unique_ptr< AFilter > m_lhsFilter
Left hand side filter.
Definition: AndFilter.dcl.h:55
Belle2::TrackFindingCDC::AndFilter::exposeParameters
void exposeParameters(ModuleParamList *moduleParamList, const std::string &prefix) final
Expose the parameters to a module.
Definition: AndFilter.icc.h:47
Belle2::TrackFindingCDC::AndFilter::~AndFilter
~AndFilter()
Default destructor.
Belle2::TrackFindingCDC::AndFilter::operator()
Weight operator()(const typename AFilter::Object &obj) final
Return result of right hand side filter if left hand side filter acknowledges.
Definition: AndFilter.icc.h:55
Belle2::TrackFindingCDC::AndFilter::m_rhsFilter
std::unique_ptr< AFilter > m_rhsFilter
Right hand side filter.
Definition: AndFilter.dcl.h:58
Belle2::TrackFindingCDC::AndFilter::AndFilter
AndFilter(std::unique_ptr< AFilter > lhsFilter, std::unique_ptr< AFilter > rhsFilter)
Constructor from two filters to be joined.
Definition: AndFilter.icc.h:34
Belle2
Abstract base class for different kinds of events.
Definition: MillepedeAlgorithm.h:19
Belle2::ModuleParamList
The Module parameter list class.
Definition: ModuleParamList.h:46