8 #include <tracking/trackFindingCDC/findlets/minimal/AxialTrackMerger.h>
10 #include <tracking/trackFindingCDC/processing/AxialTrackUtil.h>
12 #include <tracking/trackFindingCDC/fitting/CDCKarimakiFitter.h>
14 #include <tracking/trackFindingCDC/eventdata/tracks/CDCTrack.h>
15 #include <tracking/trackFindingCDC/eventdata/hits/CDCWireHit.h>
16 #include <tracking/trackFindingCDC/eventdata/trajectories/CDCTrajectory2D.h>
18 #include <tracking/trackFindingCDC/numerics/WeightComperator.h>
20 #include <tracking/trackFindingCDC/utilities/StringManipulation.h>
22 #include <framework/core/ModuleParamList.templateDetails.h>
25 using namespace TrackFindingCDC;
29 return "Merges axial tracks found in the legendre search";
34 moduleParamList->
addParameter(prefixed(prefix,
"minFitProb"),
36 "Minimal fit probability of the common fit "
37 "of two tracks to be eligible for merging",
42 const std::vector<const CDCWireHit*>& allAxialWireHits)
46 for (
CDCTrack& track : axialTracks) {
47 if (track.size() < 5)
continue;
53 for (
CDCTrack& track : axialTracks) {
69 const std::vector<const CDCWireHit*>& allAxialWireHits)
72 for (
auto itTrack = axialTracks.begin(); itTrack != axialTracks.end(); ++itTrack) {
74 auto followingTracks = asRange(std::next(itTrack), axialTracks.end());
88 template <
class ACDCTracks>
91 std::vector<WithWeight<CDCTrack*>> weightedTracks;
93 if (&track == &track2)
continue;
94 if (track2.size() < 3)
continue;
97 if (std::isnan(fitProb))
continue;
99 weightedTracks.emplace_back(&track2, fitProb);
102 auto bestMatch = std::max_element(weightedTracks.begin(), weightedTracks.end(),
LessWeight());
103 if (bestMatch == weightedTracks.end())
return {
nullptr, 0};
104 else return *bestMatch;
122 if (not isValid(fbInfo))
continue;
128 if (not isValid(fbInfo))
continue;
132 if (not trajectory3D1.
isCurler() and fbVote12 < 0)
return NAN;
133 if (not trajectory3D2.
isCurler() and fbVote21 < 0)
return NAN;
138 std::vector<const CDCWireHit*> combinedWireHits;
139 combinedWireHits.reserve(track1.size() + track2.size());
141 combinedWireHits.push_back(&(hit.getWireHit()));
144 combinedWireHits.push_back(&(hit.getWireHit()));
151 std::sort(combinedWireHits.begin(), combinedWireHits.end());
152 erase_unique(combinedWireHits);
159 commonTrajectory2D = fitter.fit(combinedWireHits);
161 commonTrajectory2D = fitter.fit(combinedWireHits);
163 commonTrajectory2D = fitter.fit(combinedWireHits);
165 commonTrajectory2D = fitter.fit(combinedWireHits);
167 commonTrajectory2D = fitter.fit(combinedWireHits);
171 if (combinedWireHits.size() <= std::max(track1.size(), track2.size())
172 or combinedWireHits.size() < 15) {
180 std::vector<const CDCWireHit*>& wireHits,
183 auto farFromTrajectory = [&trajectory2D, &factor](
const CDCWireHit * wireHit) {
184 Vector2D pos2D = wireHit->getRefPos2D();
185 double driftLength = wireHit->getRefDriftLength();
186 double dist = std::fabs(trajectory2D.
getDist2D(pos2D)) - driftLength;
187 return std::fabs(dist) > driftLength * factor;
189 erase_remove_if(wireHits, farFromTrajectory);
194 const std::vector<const CDCWireHit*>& allAxialWireHits)
196 if (&track1 == &track2)
return;
198 CDCTrajectory2D trajectory2D = track1.getStartTrajectory3D().getTrajectory2D();
201 track1.push_back(std::move(recoHit3D));
212 recoHit3D.setRecoPos3D({recoHit3D.getRefPos2D(), 0});
213 recoHit3D.setRLInfo(ERightLeft::c_Unknown);
220 recoHit3D.getWireHit()->setTakenFlag(
false);
The Module parameter list class.
static WithWeight< MayBePtr< CDCTrack > > calculateBestTrackToMerge(CDCTrack &track, ACDCTracks &tracks)
Searches for the best candidate to merge this track to.
void apply(std::vector< CDCTrack > &axialTracks, const std::vector< const CDCWireHit * > &axialWireHits) final
Merge tracks together. Allows for axial hits to be added as it may see fit.
static void removeStrangeHits(double factor, std::vector< const CDCWireHit * > &wireHits, CDCTrajectory2D &trajectory)
Remove all hits that are further than factor * driftlength away from the trajectory.
static void mergeTracks(CDCTrack &track1, CDCTrack &track2, const std::vector< const CDCWireHit * > &allAxialWireHits)
Function to merge two track candidates.
std::string getDescription() final
Short description of the findlet.
static double doTracksFitTogether(CDCTrack &track1, CDCTrack &track2)
Fits the hit content of both tracks in a common fit repeated with an annealing schedule removing far ...
void exposeParameters(ModuleParamList *moduleParamList, const std::string &prefix) final
Expose the parameters to a module.
void doTracksMerging(std::vector< CDCTrack > &axialTracks, const std::vector< const CDCWireHit * > &allAxialWireHits)
The track finding often finds two curling tracks, originating from the same particle.
double m_param_minFitProb
Parameter : Minimal fit probability of the common fit of two tracks to be eligible for merging.
Class implementing the fitter using Karimakis method.
static const CDCKarimakiFitter & getNoDriftVarianceFitter()
Static getter for a general fitter that does not use the drift length variances.
Class representing a three dimensional reconstructed hit.
static CDCRecoHit3D reconstruct(const CDCRecoHit2D &recoHit2D, const CDCTrajectory2D &trajectory2D)
Reconstructs the three dimensional hit from the two dimensional and the two dimensional trajectory.
Class representing a sequence of three dimensional reconstructed hits.
Particle trajectory as it is seen in xy projection represented as a circle.
double getPValue() const
Getter for p-value.
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.
bool isCurler(double factor=1) const
Checks if the trajectory leaves the outer radius of the CDC times the given tolerance factor.
Vector3D getFlightDirection3DAtSupport() const
Get the unit momentum at the start point of the trajectory.
Class representing a hit wire in the central drift chamber.
A two dimensional vector which is equipped with functions for correct handeling of orientation relat...
EForwardBackward isForwardOrBackwardOf(const Vector2D &rhs) const
Indicates if the given vector is more coaligned or reverse if you looked in the direction of this vec...
const Vector2D & xy() const
Getter for the xy projected vector ( reference ! )
A mixin class to attach a weight to an object.
Weight getWeight() const
Getter for the weight.
void addParameter(const std::string &name, T ¶mVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module list.
EForwardBackward
Enumeration to represent the distinct possibilities of the right left passage information.
Abstract base class for different kinds of events.
static void deleteShortTracks(std::vector< CDCTrack > &axialTracks, double minimal_size=5)
Remove tracks that are shorter than the given number of hits.
static void normalizeTrack(CDCTrack &track)
Refit and resort the track. Unmask all hits.
static void removeHitsAfterSuperLayerBreak(CDCTrack &track)
Searches for a break in the super layer chain and remove all hits that come after that.
static bool postprocessTrack(CDCTrack &track, const std::vector< const CDCWireHit * > &allAxialWireHits)
Perform all track postprocessing - return whether the track is considered good after the postprocessi...
static std::vector< CDCRecoHit3D > splitBack2BackTrack(CDCTrack &track)
Tries to split back-to-back tracks into two different tracks.
static void deleteTracksWithLowFitProbability(std::vector< CDCTrack > &axialTracks, double minimal_probability_for_good_fit=0.4)
Check an (improper) p-values of the tracks. If they are below the given value, delete the track from ...
Functor factory turning a binary functor and two functors into a new functor which executes the binar...