Belle II Software development
BkgTruthClusterVarSet.h
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#pragma once
9
10#include <tracking/trackingUtilities/varsets/VarSet.h>
11#include <tracking/trackingUtilities/varsets/VarNames.h>
12
13namespace Belle2 {
18 namespace TrackingUtilities {
20 }
21 namespace TrackFindingCDC {
22
24 constexpr
25 static char const* const bkgTruthClusterNames[] = {
26 "n_background_hits_truth",
27 "background_fraction_truth",
28 "weight",
29 "truth",
30 };
31
33 struct BkgTruthClusterVarNames : public TrackingUtilities::VarNames<TrackingUtilities::CDCWireHitCluster> {
34
36 // we shouldn't use public member variables but we do want to rewrite all related code using setters/getters
37 // at least tell cppcheck that everything is fine
38 // cppcheck-suppress duplInheritedMember
39 static const size_t nVars = TrackingUtilities::size(bkgTruthClusterNames);
40
42 static constexpr char const* getName(int iName)
43 {
44 return bkgTruthClusterNames[iName];
45 }
46 };
47
52 class BkgTruthClusterVarSet : public TrackingUtilities::VarSet<BkgTruthClusterVarNames> {
53
54 private:
57
58 public:
60 void initialize() override;
61
63 void beginEvent() override;
64
66 bool extract(const TrackingUtilities::CDCWireHitCluster* ptrCluster) final;
67 };
68 }
70}
Class to compute floating point variables from a wire hit cluster which can be recorded as a flat TNt...
void initialize() override
Signal the initialisation of the event processing - requires the Monte Carlo information.
void beginEvent() override
Signal the beginning of a new event - loads the Monte Carlo information.
bool extract(const TrackingUtilities::CDCWireHitCluster *ptrCluster) final
Generate and assign the contained variables.
TrackingUtilities::VarSet< BkgTruthClusterVarNames > Super
Type of the base class.
Class that specifies the names of the variables.
Definition VarNames.h:21
Generic class that generates some named float values from a given object.
Definition VarSet.h:36
Abstract base class for different kinds of events.
Vehicle class to transport the variable names.
static const size_t nVars
Number of variables to be generated.
static constexpr char const * getName(int iName)
Getter for the name at the given index.