Belle II Software development
HitGapSegmentPairVarSet.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 {
19 class CDCSegmentPair;
20 }
21 namespace TrackFindingCDC {
22
24 constexpr
25 static char const* const hitGapSegmentPairVarNames[] = {
26 "delta_hit_pos_phi",
27 "delta_hit_mom_phi",
28 "delta_hit_alpha",
29
30 "hit_distance",
31 "hit_long_distance",
32 "delta_hit_distance",
33
34 "from_hit_forward",
35 "to_hit_forward",
36 "hit_forward",
37
38 "hit_reco_z",
39 "hit_z_bound_factor",
40 "hit_arclength_gap",
41 };
42
44 struct HitGapSegmentPairVarNames : public TrackingUtilities::VarNames<TrackingUtilities::CDCSegmentPair> {
45
47 // we shouldn't use public member variables but we do want to rewrite all related code using setters/getters
48 // at least tell cppcheck that everything is fine
49 // cppcheck-suppress duplInheritedMember
50 static const size_t nVars = TrackingUtilities::size(hitGapSegmentPairVarNames);
51
53 static constexpr char const* getName(int iName)
54 {
55 return hitGapSegmentPairVarNames[iName];
56 }
57 };
58
63 class HitGapSegmentPairVarSet : public TrackingUtilities::VarSet<HitGapSegmentPairVarNames> {
64
65 public:
67 bool extract(const TrackingUtilities::CDCSegmentPair* ptrSegmentPair) override;
68 };
69 }
71}
Class to compute floating point variables from an axial stereo segment pair which can be recorded as ...
bool extract(const TrackingUtilities::CDCSegmentPair *ptrSegmentPair) override
Generate and assign the contained variables.
Class representing a pair of one reconstructed axial segment and one stereo segment in adjacent super...
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.