Belle II Software prerelease-11-00-00a
CDCCKFStateFilter.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/findlets/base/Findlet.h>
11#include <tracking/trackingUtilities/geometry/Vector2D.h>
12#include <tracking/trackingUtilities/eventdata/trajectories/CDCTrajectory3D.h>
13#include <tracking/trackingUtilities/eventdata/trajectories/CDCTrajectory2D.h>
14#include <tracking/trackingUtilities/eventdata/trajectories/CDCTrajectorySZ.h>
15
16#include <tracking/trackingUtilities/utilities/Algorithms.h>
17#include <tracking/trackingUtilities/utilities/Functional.h>
18#include <tracking/trackingUtilities/numerics/WeightComperator.h>
19
20#include <tracking/ckf/cdc/entities/CDCCKFState.h>
21#include <tracking/ckf/cdc/entities/CDCCKFPath.h>
22#include <tracking/ckf/cdc/filters/states/CDCStateFilterFactory.h>
23
24#include <tracking/trackingUtilities/filters/base/ChooseableFilter.dcl.h>
25
26#include <tracking/trackingUtilities/utilities/StringManipulation.h>
27#include <framework/core/ModuleParamList.h>
28
29namespace Belle2 {
35 class CDCCKFStateFilter : public TrackingUtilities::Findlet<const CDCCKFState, CDCCKFState> {
36 public:
45
46
48 void exposeParameters(ModuleParamList* moduleParamList, const std::string& prefix) override
49 {
50 moduleParamList->addParameter(TrackingUtilities::prefixed(prefix, "maximalHitCandidates"),
51 m_maximalHitCandidates, "Maximal hit candidates to test",
53 m_preFilter.exposeParameters(moduleParamList, TrackingUtilities::prefixed(prefix, "pre"));
54 m_basicFilter.exposeParameters(moduleParamList, TrackingUtilities::prefixed(prefix, "basic"));
55 m_extrapolationFilter.exposeParameters(moduleParamList, TrackingUtilities::prefixed(prefix, "extrapolation"));
56 m_finalSelection.exposeParameters(moduleParamList, TrackingUtilities::prefixed(prefix, "final"));
57 }
58
63 void setMaximalHitCandidates(size_t maximalHitCandidates) { m_maximalHitCandidates = maximalHitCandidates; }
64
66 void apply(const CDCCKFPath& path, std::vector<CDCCKFState>& nextStates) override
67 {
68 const CDCCKFState& lastState = path.back();
69 const TrackingUtilities::CDCTrajectory3D& trajectory = lastState.getTrajectory();
70
71 TrackingUtilities::Weight weight;
72
73 B2DEBUG(29, "On layer: " << (lastState.isSeed() ? -1 : lastState.getWireHit()->getWire().getICLayer()));
74
75 for (CDCCKFState& nextState : nextStates) {
76 B2DEBUG(29, "Checking layer: " << nextState.getWireHit()->getWire().getICLayer());
77
78 weight = m_preFilter({&path, &nextState});
79 nextState.setWeight(weight);
80 if (std::isnan(weight)) {
81 B2DEBUG(29, "Fails PreFilter");
82 continue;
83 }
84
85 // Do a reconstruction based on the helix extrapolation from the last hit
86 reconstruct(nextState, trajectory, lastState.getArcLength());
87
88 weight = m_basicFilter({&path, &nextState});
89 nextState.setWeight(weight);
90 if (std::isnan(weight)) {
91 B2DEBUG(29, "Fails BasicFilter");
92 continue;
93 }
94
95 // Extrapolate and update
96 weight = m_extrapolationFilter({&path, &nextState});
97 nextState.setWeight(weight);
98 if (std::isnan(weight)) {
99 B2DEBUG(29, "Fails ExtrapolationFilter");
100 continue;
101 }
102
103 // Do a final hit selection based on the new state
104 const TrackingUtilities::CDCTrajectory3D& thisTrajectory = nextState.getTrajectory();
105 reconstruct(nextState, thisTrajectory, nextState.getArcLength());
106
107 weight = m_finalSelection({&path, &nextState});
108 nextState.setWeight(weight);
109 if (std::isnan(weight)) {
110 B2DEBUG(29, "Fails FinalFilter");
111 continue;
112 }
113 }
114
115 B2DEBUG(29, "Starting with " << nextStates.size() << " possible hits");
116
117 TrackingUtilities::erase_remove_if(nextStates,
119
120 B2DEBUG(29, "Now have " << nextStates.size());
121
122 std::sort(nextStates.begin(), nextStates.end(), TrackingUtilities::GreaterWeight());
123
124 TrackingUtilities::only_best_N(nextStates, m_maximalHitCandidates);
125 }
126
127 private:
138
140 void reconstruct(CDCCKFState& state, const TrackingUtilities::CDCTrajectory3D& trajectory, const double lastArcLength) const
141 {
142 // TODO: actually we do not need to do any trajectory creation here. We could save some computing time!
143 const TrackingUtilities::CDCTrajectory2D& trajectory2D = trajectory.getTrajectory2D();
144 const TrackingUtilities::CDCTrajectorySZ& trajectorySZ = trajectory.getTrajectorySZ();
145
146 const TrackingUtilities::CDCWireHit* wireHit = state.getWireHit();
147
149 if (wireHit->isAxial()) {
150 recoPos2D = wireHit->reconstruct2D(trajectory2D);
151 } else {
152 const CDC::CDCWire& wire = wireHit->getWire();
153 const TrackingUtilities::Vector2D& posOnXYPlane = wireHit->reconstruct2D(trajectory2D);
154
155 const double arcLength = trajectory2D.calcArcLength2D(posOnXYPlane);
156 const double z = trajectorySZ.mapSToZ(arcLength);
157
158 const TrackingUtilities::Vector2D& wirePos2DAtZ = wire.getWirePos2DAtZ(z);
159
160 const TrackingUtilities::Vector2D& recoPosOnTrajectory = trajectory2D.getClosest(wirePos2DAtZ);
161 const double driftLength = wireHit->getRefDriftLength();
162 TrackingUtilities::Vector2D disp2D = recoPosOnTrajectory - wirePos2DAtZ;
163 disp2D.normalizeTo(driftLength);
164 recoPos2D = wirePos2DAtZ + disp2D;
165 }
166
167 const double arcLength = trajectory2D.calcArcLength2D(recoPos2D);
168 const double z = trajectorySZ.mapSToZ(arcLength);
169 const double distanceToHit = trajectory2D.getDist2D(recoPos2D);
170
171 state.setArcLength(lastArcLength + arcLength);
172 state.setHitDistance(distanceToHit);
173 state.setReconstructedZ(z);
174 }
175 };
176
177}
TrackingUtilities::ChooseableFilter< CDCStateFilterFactory > m_preFilter
Pre Filter.
size_t m_maximalHitCandidates
Parameter: max number of candidates.
void reconstruct(CDCCKFState &state, const TrackingUtilities::CDCTrajectory3D &trajectory, const double lastArcLength) const
Helper function to reconstruct the arc length and the hit distance of a state according to the trajec...
TrackingUtilities::ChooseableFilter< CDCStateFilterFactory > m_extrapolationFilter
Extrapolation Filter (after Kalman extrapolation)
void setMaximalHitCandidates(size_t maximalHitCandidates)
Set maximal hit candidates for state filtering.
TrackingUtilities::ChooseableFilter< CDCStateFilterFactory > m_basicFilter
Basic Filter (uses helix extrapolation)
void apply(const CDCCKFPath &path, std::vector< CDCCKFState > &nextStates) override
Apply the findlet and do the state selection.
TrackingUtilities::ChooseableFilter< CDCStateFilterFactory > m_finalSelection
Final Selection Filter (after Kalman update)
void exposeParameters(ModuleParamList *moduleParamList, const std::string &prefix) override
Expose the parameters of the sub findlets.
CDCCKFStateFilter()
Add all sub findlets.
Define states for CKF algorithm, which can be seed track or CDC wire hit.
Definition CDCCKFState.h:25
void setHitDistance(double hitDistance)
Set hit distance to the trajectory.
double getArcLength() const
Return the arc-length along the tracjectory to the hit.
Definition CDCCKFState.h:94
void setReconstructedZ(double reconstructedZ)
Set state Z information.
void setArcLength(double arcLength)
Set the arc-length along the tracjectory to the hit.
Definition CDCCKFState.h:88
const TrackingUtilities::CDCWireHit * getWireHit() const
Get CDCWireHit corresponding to the state.
Definition CDCCKFState.h:35
TrackingUtilities::CDCTrajectory3D getTrajectory() const
Helper method to get trajectory from the trackState.
bool isSeed() const
Returns true if the state corresponds to the seed track.
Definition CDCCKFState.h:56
Class representing a sense wire in the central drift chamber.
Definition CDCWire.h:50
ROOT::Math::XYVector getWirePos2DAtZ(const double z) const
Gives the xy projected position of the wire at the given z coordinate.
Definition CDCWire.h:184
The Module parameter list class.
Particle trajectory as it is seen in xy projection represented as a circle.
double calcArcLength2D(const Vector2D &point) const
Calculate the travel distance from the start position of the trajectory.
Vector2D getClosest(const Vector2D &point) const
Calculates the closest approach on the trajectory to the given point.
double getDist2D(const Vector2D &point) const
Calculates the distance from the point to the trajectory as seen from the xy projection.
Particle full three dimensional trajectory.
CDCTrajectory2D getTrajectory2D() const
Getter for the two dimensional trajectory.
CDCTrajectorySZ getTrajectorySZ() const
Getter for the sz trajectory.
double mapSToZ(const double s=0) const
Translates the travel distance to the z coordinate.
Class representing a hit wire in the central drift chamber.
Definition CDCWireHit.h:58
Convenvience wrapper to setup a Chooseable filter from a specific factory object.
Interface for a minimal algorithm part that wants to expose some parameters to a module.
Definition Findlet.h:26
A two dimensional vector which is equipped with functions for correct handling of orientation relate...
Definition Vector2D.h:36
double normalizeTo(const double toLength)
Normalizes the vector to the given length.
Definition Vector2D.h:340
void addParameter(const std::string &name, T &paramVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module list.
std::vector< CDCCKFState > CDCCKFPath
Shortcut for the collection of CDC CKF-algorithm states.
Definition CDCCKFPath.h:19
Abstract base class for different kinds of events.
Functor factory from the functional composition of two functors.
Definition Functional.h:87