Belle II Software  release-08-01-10
SegmentFitter.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/findlets/minimal/SegmentFitter.h>
9 
10 #include <tracking/trackFindingCDC/fitting/CDCObservations2D.h>
11 
12 #include <tracking/trackFindingCDC/eventdata/segments/CDCSegment2D.h>
13 
14 #include <tracking/trackFindingCDC/utilities/StringManipulation.h>
15 
16 #include <framework/core/ModuleParamList.templateDetails.h>
17 #include <framework/logging/Logger.h>
18 
19 using namespace Belle2;
20 using namespace TrackFindingCDC;
21 
23 {
24  return "Fits each segment with a selectable method";
25 }
26 
27 void SegmentFitter::exposeParameters(ModuleParamList* moduleParamList, const std::string& prefix)
28 {
29  moduleParamList->addParameter(prefixed(prefix, "karimakiFit"),
31  "Switch to select Karimaki method for fitting instead of Riemann fit",
33 
34  moduleParamList->addParameter(prefixed(prefix, "fitPos"),
36  "Positional information of the hits to be used in the fit. "
37  "Options are 'recoPos', 'rlDriftCircle', 'wirePos'.",
39 
40  moduleParamList->addParameter(prefixed(prefix, "fitVariance"),
42  "Positional information of the hits to be used in the fit. "
43  "Options are 'unit', 'driftLength', 'pseudo', 'proper'.",
45 
46  moduleParamList->addParameter(prefixed(prefix, "updateDriftLength"),
48  "Switch to reestimate the drift length",
50 
51  moduleParamList->addParameter(prefixed(prefix, "updateRecoPos"),
53  "Switch to reestimate the position and right left passage information",
55 
56  m_driftLengthEstimator.exposeParameters(moduleParamList, prefix);
57 }
58 
59 
61 {
63  if (m_param_fitPosString != std::string("")) {
64  try {
65  m_fitPos = getFitPos(m_param_fitPosString);
66  } catch (std::invalid_argument& e) {
67  B2ERROR("Unexpected fitPos parameter : '" << m_param_fitPosString);
68  }
69  }
70 
71  if (m_param_fitVarianceString != std::string("")) {
72  try {
73  m_fitVariance = getFitVariance(m_param_fitVarianceString);
74  } catch (std::invalid_argument& e) {
75  B2ERROR("Unexpected fitVariance parameter : '" << m_param_fitVarianceString);
76  }
77  }
78 
79  if (m_param_karimakiFit) {
80  if (m_fitPos != EFitPos::c_RecoPos) {
81  B2WARNING("Karimaki fitter only works with the reconstructed position as input.");
82  }
83  m_fitPos = EFitPos::c_RecoPos;
84  }
85 }
86 
87 void SegmentFitter::apply(std::vector<CDCSegment2D>& outputSegments)
88 {
89  // Update the drift length
91  for (CDCSegment2D& segment : outputSegments) {
93  }
94  }
95 
96  for (const CDCSegment2D& segment : outputSegments) {
97  CDCObservations2D observations2D(m_fitPos, m_fitVariance);
98  observations2D.appendRange(segment);
99 
100  if (m_param_karimakiFit or observations2D.size() < 4) {
101  // Karimaki only works with the reconstructed position
102  if (m_fitPos != EFitPos::c_RecoPos) {
103  observations2D.clear();
104  observations2D.setFitPos(EFitPos::c_RecoPos);
105  observations2D.appendRange(segment);
106  }
107  CDCTrajectory2D trajectory2D = m_karimakiFitter.fit(observations2D);
108  segment.setTrajectory2D(trajectory2D);
109  } else {
110 
111  CDCTrajectory2D trajectory2D = m_riemannFitter.fit(observations2D);
112  segment.setTrajectory2D(trajectory2D);
113  }
114  }
115 
116  if (m_param_updateRecoPos) {
117  for (CDCSegment2D& segment : outputSegments) {
118  const CDCTrajectory2D& trajectory2D = segment.getTrajectory2D();
119  if (not trajectory2D.isFitted()) continue;
120  int nRLChanges = 0;
121  for (CDCRecoHit2D& recoHit2D : segment) {
122  ERightLeft rlInfo = trajectory2D.isRightOrLeft(recoHit2D.getRefPos2D());
123  if (rlInfo != recoHit2D.getRLInfo()) ++nRLChanges;
124  recoHit2D.setRLInfo(rlInfo);
125  const CDCRLWireHit& rlWireHit = recoHit2D.getRLWireHit();
126  Vector2D recoPos2D = rlWireHit.reconstruct2D(trajectory2D);
127  recoHit2D.setRecoPos2D(recoPos2D);
128  }
129  if (nRLChanges > 0) B2DEBUG(25, "RL changes " << nRLChanges);
130  }
131  }
132 }
The Module parameter list class.
CDCTrajectory2D fit(const CDCObservations2D &observations2D) const
Fits a collection of observation drift circles.
Class serving as a storage of observed drift circles to present to the Riemann fitter.
std::size_t appendRange(const CDCSegment2D &segment2D)
Appends all reconstructed hits from the two dimensional segment.
void clear()
Removes all observations stored.
std::size_t size() const
Returns the number of observations stored.
void setFitPos(EFitPos fitPos)
Setter for the indicator that the reconstructed position should be favoured.
Class representing an oriented hit wire including a hypotheses whether the causing track passes left ...
Definition: CDCRLWireHit.h:41
Vector2D reconstruct2D(const CDCTrajectory2D &trajectory2D) const
Reconstructs a position of primary ionisation on the drift circle.
Class representing a two dimensional reconstructed hit in the central drift chamber.
Definition: CDCRecoHit2D.h:47
A reconstructed sequence of two dimensional hits in one super layer.
Definition: CDCSegment2D.h:39
Particle trajectory as it is seen in xy projection represented as a circle.
bool isFitted() const
Checks if the circle is already set to a valid value.
ERightLeft isRightOrLeft(const Vector2D &point) const
Checks if the given point is to the right or to the left of the trajectory.
void initialize() override
Receive and dispatch signal before the start of the event processing.
EFitPos m_fitPos
Option which positional information from the hits should be used.
Definition: SegmentFitter.h:72
DriftLengthEstimator m_driftLengthEstimator
Instance of the drift length estimator to be used.
Definition: SegmentFitter.h:84
void initialize() override
Signals the beginning of the event processing.
bool m_param_karimakiFit
Parameter : Switch to use Karimaki fit.
Definition: SegmentFitter.h:57
std::string getDescription() override
Short description of the findlet.
CDCKarimakiFitter m_karimakiFitter
Instance of the karimaki fitter to be used.
Definition: SegmentFitter.h:81
bool m_param_updateDriftLength
Parameter : Switch to reestimate the drift length before the fit.
Definition: SegmentFitter.h:66
CDCRiemannFitter m_riemannFitter
Instance of the riemann fitter to be used.
Definition: SegmentFitter.h:78
void apply(std::vector< CDCSegment2D > &outputSegments) override
Main algorithm applying the fit to each segment.
void exposeParameters(ModuleParamList *moduleParamList, const std::string &prefix) override
Expose the parameters to a module.
EFitVariance m_fitVariance
Option which variance information from the hits should be used.
Definition: SegmentFitter.h:75
std::string m_param_fitVarianceString
Parameter : Option string which variance information from the hits should be used.
Definition: SegmentFitter.h:63
bool m_param_updateRecoPos
Parameter : Switch to reevaluate the position and right left passage information based in the fit.
Definition: SegmentFitter.h:69
std::string m_param_fitPosString
Parameter : Option string which positional information from the hits should be used.
Definition: SegmentFitter.h:60
A two dimensional vector which is equipped with functions for correct handeling of orientation relat...
Definition: Vector2D.h:35
void addParameter(const std::string &name, T &paramVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module list.
ERightLeft
Enumeration to represent the distinct possibilities of the right left passage.
Definition: ERightLeft.h:25
Abstract base class for different kinds of events.
void exposeParameters(ModuleParamList *moduleParamList, const std::string &prefix)
Add the parameters of the estimator to the module.
double updateDriftLength(CDCRecoHit2D &recoHit2D)
Update the drift length of the reconstructed hit in place.