Belle II Software development
AxialTrackMerger Class Referenceabstract

Findlet implementing the merging of axial tracks found in the legendre tree search. More...

#include <AxialTrackMerger.h>

Inheritance diagram for AxialTrackMerger:
Findlet< AIOTypes > CompositeProcessingSignalListener ProcessingSignalListener

Public Types

using IOTypes = std::tuple<AIOTypes...>
 Types that should be served to apply on invocation.
 
using IOVectors = std::tuple< std::vector<AIOTypes>... >
 Vector types that should be served to apply on invocation.
 

Public Member Functions

std::string getDescription () final
 Short description of the findlet.
 
void exposeParameters (ModuleParamList *moduleParamList, const std::string &prefix) final
 Expose the parameters to a module.
 
void apply (std::vector< TrackingUtilities::CDCTrack > &axialTracks, const std::vector< const TrackingUtilities::CDCWireHit * > &axialWireHits) final
 Merge tracks together. Allows for axial hits to be added as it may see fit.
 
template<class ACDCTracks>
WithWeight< MayBePtr< CDCTrack > > calculateBestTrackToMerge (CDCTrack &track, ACDCTracks &tracks)
 Determine the best track for merging with the candidate track.
 
virtual void apply (ToVector< AIOTypes > &... ioVectors)=0
 Main function executing the algorithm.
 
void initialize () override
 Receive and dispatch signal before the start of the event processing.
 
void beginRun () override
 Receive and dispatch signal for the beginning of a new run.
 
void beginEvent () override
 Receive and dispatch signal for the start of a new event.
 
void endRun () override
 Receive and dispatch signal for the end of the run.
 
void terminate () override
 Receive and dispatch Signal for termination of the event processing.
 

Protected Types

template<class T>
using ToVector = typename ToVectorImpl<T>::Type
 Short hand for ToRangeImpl.
 

Protected Member Functions

void addProcessingSignalListener (ProcessingSignalListener *psl)
 Register a processing signal listener to be notified.
 
int getNProcessingSignalListener ()
 Get the number of currently registered listeners.
 

Private Types

using Super = TrackingUtilities::Findlet<TrackingUtilities::CDCTrack&, const TrackingUtilities::CDCWireHit* const>
 Type of the base class.
 

Private Member Functions

void doTracksMerging (std::vector< TrackingUtilities::CDCTrack > &axialTracks, const std::vector< const TrackingUtilities::CDCWireHit * > &allAxialWireHits)
 The track finding often finds two curling tracks, originating from the same particle.
 

Static Private Member Functions

template<class ACDCTracks>
static TrackingUtilities::WithWeight< TrackingUtilities::MayBePtr< TrackingUtilities::CDCTrack > > calculateBestTrackToMerge (TrackingUtilities::CDCTrack &track, ACDCTracks &tracks)
 Searches for the best candidate to merge this track to.
 
static double doTracksFitTogether (TrackingUtilities::CDCTrack &track1, TrackingUtilities::CDCTrack &track2)
 Fits the hit content of both tracks in a common fit repeated with an annealing schedule removing far away hits.
 
static void removeStrangeHits (double factor, std::vector< const TrackingUtilities::CDCWireHit * > &wireHits, TrackingUtilities::CDCTrajectory2D &trajectory)
 Remove all hits that are further than factor * driftlength away from the trajectory.
 
static void mergeTracks (TrackingUtilities::CDCTrack &track1, TrackingUtilities::CDCTrack &track2, const std::vector< const TrackingUtilities::CDCWireHit * > &allAxialWireHits)
 Function to merge two track candidates.
 

Private Attributes

double m_param_minFitProb = 0.85
 Parameter : Minimal fit probability of the common fit of two tracks to be eligible for merging.
 
std::vector< ProcessingSignalListener * > m_subordinaryProcessingSignalListeners
 References to subordinary signal processing listener contained in this findlet.
 
bool m_initialized = false
 Flag to keep track whether initialization happened before.
 
bool m_terminated = false
 Flag to keep track whether termination happened before.
 
std::string m_initializedAs
 Name of the type during initialisation.
 

Detailed Description

Findlet implementing the merging of axial tracks found in the legendre tree search.

Definition at line 33 of file AxialTrackMerger.h.

Member Typedef Documentation

◆ IOTypes

template<class ... AIOTypes>
using IOTypes = std::tuple<AIOTypes...>
inherited

Types that should be served to apply on invocation.

Definition at line 30 of file Findlet.h.

◆ IOVectors

template<class ... AIOTypes>
using IOVectors = std::tuple< std::vector<AIOTypes>... >
inherited

Vector types that should be served to apply on invocation.

Definition at line 53 of file Findlet.h.

◆ Super

Type of the base class.

Definition at line 38 of file AxialTrackMerger.h.

◆ ToVector

template<class ... AIOTypes>
template<class T>
using ToVector = typename ToVectorImpl<T>::Type
protectedinherited

Short hand for ToRangeImpl.

Definition at line 49 of file Findlet.h.

Member Function Documentation

◆ addProcessingSignalListener()

void addProcessingSignalListener ( ProcessingSignalListener * psl)
protectedinherited

Register a processing signal listener to be notified.

Definition at line 55 of file CompositeProcessingSignalListener.cc.

56{
58}
std::vector< ProcessingSignalListener * > m_subordinaryProcessingSignalListeners
References to subordinary signal processing listener contained in this findlet.

◆ apply()

void apply ( std::vector< TrackingUtilities::CDCTrack > & axialTracks,
const std::vector< const TrackingUtilities::CDCWireHit * > & axialWireHits )
final

Merge tracks together. Allows for axial hits to be added as it may see fit.

Definition at line 44 of file AxialTrackMerger.cc.

46{
47 // Check quality of the track basing on holes on the trajectory;
48 // if holes exist then track is split
49 for (CDCTrack& track : axialTracks) {
50 if (track.size() < 5) continue;
53 }
54
55 // Update tracks before storing to DataStore
56 for (CDCTrack& track : axialTracks) {
58 }
59
60 // Remove bad tracks
63
64 // Perform tracks merging
65 this->doTracksMerging(axialTracks, allAxialWireHits);
66
67 // Remove the consumed, now empty tracks.
69}
void doTracksMerging(std::vector< TrackingUtilities::CDCTrack > &axialTracks, const std::vector< const TrackingUtilities::CDCWireHit * > &allAxialWireHits)
The track finding often finds two curling tracks, originating from the same particle.
static void normalizeTrack(TrackingUtilities::CDCTrack &track)
Refit and resort the track. Unmask all hits.
static void deleteShortTracks(std::vector< TrackingUtilities::CDCTrack > &axialTracks, double minimal_size=5)
Remove tracks that are shorter than the given number of hits.
static void deleteTracksWithLowFitProbability(std::vector< TrackingUtilities::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 ...
static void removeHitsAfterSuperLayerBreak(TrackingUtilities::CDCTrack &track)
Searches for a break in the super layer chain and remove all hits that come after that.

◆ beginEvent()

void beginEvent ( )
overridevirtualinherited

Receive and dispatch signal for the start of a new event.

Reimplemented from ProcessingSignalListener.

Reimplemented in DATCONFPGAFindlet, SpacePointTagger< AResult, ACluster >, SpacePointTagger< Belle2::CKFToPXDResult, Belle2::PXDCluster >, SpacePointTagger< Belle2::CKFToSVDResult, Belle2::SVDCluster >, MCSymmetric< BaseAxialSegmentPairFilter >, MCSymmetric< BaseAxialSegmentPairFilter >, MCSymmetric< BaseFacetFilter >, MCSymmetric< BaseFacetFilter >, MCSymmetric< BaseFacetRelationFilter >, MCSymmetric< BaseFacetRelationFilter >, MCSymmetric< BaseSegmentPairFilter >, MCSymmetric< BaseSegmentPairFilter >, MCSymmetric< BaseSegmentPairRelationFilter >, MCSymmetric< BaseSegmentPairRelationFilter >, MCSymmetric< BaseSegmentRelationFilter >, MCSymmetric< BaseSegmentRelationFilter >, MCSymmetric< BaseSegmentTripleFilter >, MCSymmetric< BaseSegmentTripleFilter >, MCSymmetric< BaseSegmentTripleRelationFilter >, MCSymmetric< BaseSegmentTripleRelationFilter >, MCSymmetric< BaseTrackRelationFilter >, MCSymmetric< BaseTrackRelationFilter >, MonopoleStereoHitFinder, MonopoleStereoHitFinderQuadratic, SegmentCreatorMCTruth, SegmentFinderFacetAutomaton, SegmentTrackCombiner, SegmentTrackTruthVarSet, StereoHitFinder, StereoHitTruthVarSet, TrackFinderAutomaton, TrackFinderSegmentPairAutomaton, TrackFinderSegmentTripleAutomaton, TruthAxialSegmentPairVarSet, TruthSegmentVarSet, TruthTrackVarSet, WireHitMCMultiLoopBlocker, FindletStoreArrayInput< TWrappedFindlet >, SharingHitsMatcher< ACollectorItem, ACollectionItem >, SharingHitsMatcher< Belle2::TrackingUtilities::CDCTrack, Belle2::TrackingUtilities::CDCSegment2D >, StoreVectorSwapper< IOType, a_alwaysWrite >, StoreVectorSwapper< Belle2::TrackingUtilities::CDCFacet >, StoreVectorSwapper< Belle2::TrackingUtilities::CDCSegment2D >, StoreVectorSwapper< Belle2::TrackingUtilities::CDCSegmentPair >, StoreVectorSwapper< Belle2::TrackingUtilities::CDCSegmentTriple >, StoreVectorSwapper< Belle2::TrackingUtilities::CDCTrack >, StoreVectorSwapper< Belle2::TrackingUtilities::CDCWireHit, true >, RecoTrackStorer, ROIFinder, and SVDHoughTracking.

Definition at line 31 of file CompositeProcessingSignalListener.cc.

32{
35 psl->beginEvent();
36 }
37}
virtual void beginEvent()
Receive signal for the start of a new event.
ProcessingSignalListener()
Allow default construction.

◆ beginRun()

void beginRun ( )
overridevirtualinherited

Receive and dispatch signal for the beginning of a new run.

Reimplemented from ProcessingSignalListener.

Reimplemented in DATCONSVDClusterizer, LayerPXDRelationFilter< AFilter, APrefilter >, LayerPXDRelationFilter< TrackingUtilities::ChooseableFilter< PXDPairFilterFactory > >, LayerPXDRelationFilter< TrackingUtilities::ChooseableFilter< PXDPairFilterFactory > >, LayerSVDRelationFilter< AFilter, APrefilter >, LayerSVDRelationFilter< TrackingUtilities::ChooseableFilter< SVDPairFilterFactory > >, LayerSVDRelationFilter< TrackingUtilities::ChooseableFilter< SVDPairFilterFactory > >, SectorMapBasedSVDPairFilter, SimplePXDStateFilter, SimpleSVDStateFilter, CutsFromDBWireHitFilter, WireHitCreator, MVA< Filter< AVarSet::Object > >, MVA< Filter< Belle2::TrackFindingCDC::CDCWireHitVarSet::Object > >, MVA< Filter< typename AVarSet::Object > >, MVA< Filter< typename AVarSet::Object > >, FourHitFilter, LayerRelationFilter< AFilter >, LayerRelationFilter< TrackingUtilities::ChooseableFilter< RelationFilterFactory > >, LayerRelationFilter< TrackingUtilities::ChooseableFilter< RelationFilterFactory > >, QualityIndicatorFilter, RawTrackCandCleaner< AHit >, RawTrackCandCleaner< Belle2::vxdHoughTracking::VXDHoughState >, RecoTrackStorer, ROIFinder, SpacePointLoaderAndPreparer, ThreeHitFilter, TrackCandidateOverlapResolver, TrackCandidateResultRefiner, TwoHitVirtualIPFilter, and TwoHitVirtualIPQIFilter.

Definition at line 23 of file CompositeProcessingSignalListener.cc.

24{
27 psl->beginRun();
28 }
29}
virtual void beginRun()
Receive signal for the beginning of a new run.

◆ calculateBestTrackToMerge() [1/2]

template<class ACDCTracks>
WithWeight< MayBePtr< CDCTrack > > calculateBestTrackToMerge ( CDCTrack & track,
ACDCTracks & tracks )

Determine the best track for merging with the candidate track.

Definition at line 92 of file AxialTrackMerger.cc.

93{
94 std::vector<WithWeight<CDCTrack*>> weightedTracks;
95 for (CDCTrack& track2 : tracks) {
96 if (&track == &track2) continue;
97 if (track2.size() < 3) continue;
98
99 double fitProb = doTracksFitTogether(track, track2);
100 if (std::isnan(fitProb)) continue;
101
102 weightedTracks.emplace_back(&track2, fitProb);
103 }
104
105 auto bestMatch = std::max_element(weightedTracks.begin(), weightedTracks.end(), LessWeight());
106 if (bestMatch == weightedTracks.end()) return {nullptr, 0};
107 else return *bestMatch;
108}
static double doTracksFitTogether(TrackingUtilities::CDCTrack &track1, TrackingUtilities::CDCTrack &track2)
Fits the hit content of both tracks in a common fit repeated with an annealing schedule removing far ...

◆ calculateBestTrackToMerge() [2/2]

template<class ACDCTracks>
static TrackingUtilities::WithWeight< TrackingUtilities::MayBePtr< TrackingUtilities::CDCTrack > > calculateBestTrackToMerge ( TrackingUtilities::CDCTrack & track,
ACDCTracks & tracks )
staticprivate

Searches for the best candidate to merge this track to.

Parameters
tracktrack for which we try to find merging partner
trackssearch range of tracks
Returns
a pointer to the best fit candidate including a fit probability
Return values
{nullptr,0}in case no match was found

◆ doTracksFitTogether()

double doTracksFitTogether ( TrackingUtilities::CDCTrack & track1,
TrackingUtilities::CDCTrack & track2 )
staticprivate

Fits the hit content of both tracks in a common fit repeated with an annealing schedule removing far away hits.

Returns
Some measure of fit probability

Definition at line 110 of file AxialTrackMerger.cc.

111{
112 // First check whether most of the hits from the tracks lie in the backward direction
113 // even if though track is not curling -> tracks should not be merged
114 const CDCTrajectory3D& trajectory3D1 = track1.getStartTrajectory3D();
115 const CDCTrajectory3D& trajectory3D2 = track2.getStartTrajectory3D();
116
117 int fbVote12 = 0;
118 int fbVote21 = 0;
119
120 for (const CDCRecoHit3D& recoHit3D : track1) {
121 EForwardBackward fbInfo = VectorUtil::isForwardOrBackwardOf(VectorUtil::getXYVector(trajectory3D2.getFlightDirection3DAtSupport()),
122 recoHit3D.getRecoPos2D());
123 if (not isValid(fbInfo)) continue;
124 fbVote12 += fbInfo;
125 }
126
127 for (const CDCRecoHit3D& recoHit3D : track2) {
128 EForwardBackward fbInfo = VectorUtil::isForwardOrBackwardOf(VectorUtil::getXYVector(trajectory3D1.getFlightDirection3DAtSupport()),
129 recoHit3D.getRecoPos2D());
130 if (not isValid(fbInfo)) continue;
131 fbVote21 += fbInfo;
132 }
133
134 if (not trajectory3D1.isCurler() and fbVote12 < 0) return NAN;
135 if (not trajectory3D2.isCurler() and fbVote21 < 0) return NAN;
136
137 // Build common hit list by copying the wire hits into one large list
138 // We use the wire hits here as we do not want them to bring
139 // their "old" reconstructed position when fitting.
140 std::vector<const CDCWireHit*> combinedWireHits;
141 combinedWireHits.reserve(track1.size() + track2.size());
142 for (const CDCRecoHit3D& hit : track1) {
143 combinedWireHits.push_back(&(hit.getWireHit()));
144 }
145 for (const CDCRecoHit3D& hit : track2) {
146 combinedWireHits.push_back(&(hit.getWireHit()));
147 }
148
149 // Sorting is done via pointer addresses (!!).
150 // This is not very stable and also not very meaningful (in terms of ordering in the track),
151 // but it does the job for unique.
152 // (the ordering is still outwards though since the wire hits are ordered like that in continuous memory)
153 std::sort(combinedWireHits.begin(), combinedWireHits.end());
154 erase_unique(combinedWireHits);
155
156 // Calculate track parameters
157 CDCTrajectory2D commonTrajectory2D;
158 const CDCKarimakiFitter& fitter = CDCKarimakiFitter::getNoDriftVarianceFitter();
159
160 // Approach the best fit
161 commonTrajectory2D = fitter.fit(combinedWireHits);
162 removeStrangeHits(5, combinedWireHits, commonTrajectory2D);
163 commonTrajectory2D = fitter.fit(combinedWireHits);
164 removeStrangeHits(3, combinedWireHits, commonTrajectory2D);
165 commonTrajectory2D = fitter.fit(combinedWireHits);
166 removeStrangeHits(1, combinedWireHits, commonTrajectory2D);
167 commonTrajectory2D = fitter.fit(combinedWireHits);
168 removeStrangeHits(1, combinedWireHits, commonTrajectory2D);
169 commonTrajectory2D = fitter.fit(combinedWireHits);
170
171 // Dismiss this possibility if the hit list size after all the removing of hits is even smaller
172 // than the two lists before or if the list is too small
173 if (combinedWireHits.size() <= std::max(track1.size(), track2.size())
174 or combinedWireHits.size() < 15) {
175 return NAN;
176 }
177
178 return commonTrajectory2D.getPValue();
179}
static void removeStrangeHits(double factor, std::vector< const TrackingUtilities::CDCWireHit * > &wireHits, TrackingUtilities::CDCTrajectory2D &trajectory)
Remove all hits that are further than factor * driftlength away from the trajectory.
static const CDCKarimakiFitter & getNoDriftVarianceFitter()
Static getter for a general fitter that does not use the drift length variances.
double getPValue() const
Getter for p-value.
bool isCurler(double factor=1) const
Checks if the trajectory leaves the outer radius of the CDC times the given tolerance factor.
ROOT::Math::XYZVector getFlightDirection3DAtSupport() const
Get the unit momentum at the start point of the trajectory.
bool isValid(EForwardBackward eForwardBackward)
Check whether the given enum instance is one of the valid values.
EForwardBackward
Enumeration to represent the distinct possibilities of the right left passage information.

◆ doTracksMerging()

void doTracksMerging ( std::vector< TrackingUtilities::CDCTrack > & axialTracks,
const std::vector< const TrackingUtilities::CDCWireHit * > & allAxialWireHits )
private

The track finding often finds two curling tracks, originating from the same particle.

This function merges them.

Definition at line 71 of file AxialTrackMerger.cc.

73{
74 // Search for best matches - cannot use range for here :(.
75 for (auto itTrack = axialTracks.begin(); itTrack != axialTracks.end(); ++itTrack) {
76 CDCTrack& track = *itTrack;
77 auto followingTracks = asRange(std::next(itTrack), axialTracks.end());
78
79 WithWeight<MayBePtr<CDCTrack> > bestTrack = calculateBestTrackToMerge(track, followingTracks);
80 double fitProb = bestTrack.getWeight();
81
82 if (bestTrack != nullptr and fitProb > m_param_minFitProb) {
83 mergeTracks(track, *bestTrack, allAxialWireHits);
84 }
85 }
86
88}
static void mergeTracks(TrackingUtilities::CDCTrack &track1, TrackingUtilities::CDCTrack &track2, const std::vector< const TrackingUtilities::CDCWireHit * > &allAxialWireHits)
Function to merge two track candidates.
static TrackingUtilities::WithWeight< TrackingUtilities::MayBePtr< TrackingUtilities::CDCTrack > > calculateBestTrackToMerge(TrackingUtilities::CDCTrack &track, ACDCTracks &tracks)
Searches for the best candidate to merge this track to.
double m_param_minFitProb
Parameter : Minimal fit probability of the common fit of two tracks to be eligible for merging.
Weight getWeight() const
Getter for the weight.
Definition WithWeight.h:56

◆ endRun()

void endRun ( )
overridevirtualinherited

Receive and dispatch signal for the end of the run.

Reimplemented from ProcessingSignalListener.

Definition at line 39 of file CompositeProcessingSignalListener.cc.

40{
42 psl->endRun();
43 }
45}
virtual void endRun()
Receive signal for the end of the run.

◆ exposeParameters()

void exposeParameters ( ModuleParamList * moduleParamList,
const std::string & prefix )
finalvirtual

Expose the parameters to a module.

Reimplemented from CompositeProcessingSignalListener.

Definition at line 35 of file AxialTrackMerger.cc.

36{
37 moduleParamList->addParameter(prefixed(prefix, "minFitProb"),
39 "Minimal fit probability of the common fit "
40 "of two tracks to be eligible for merging",
42}
void addParameter(const std::string &name, T &paramVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module list.

◆ getDescription()

std::string getDescription ( )
finalvirtual

Short description of the findlet.

Reimplemented from Findlet< AIOTypes >.

Definition at line 30 of file AxialTrackMerger.cc.

31{
32 return "Merges axial tracks found in the Legendre search";
33}

◆ getNProcessingSignalListener()

int getNProcessingSignalListener ( )
protectedinherited

Get the number of currently registered listeners.

Definition at line 60 of file CompositeProcessingSignalListener.cc.

61{
63}

◆ initialize()

void initialize ( )
overridevirtualinherited

Receive and dispatch signal before the start of the event processing.

Reimplemented from ProcessingSignalListener.

Reimplemented in CosmicsTrackMergerFindlet, DATCONSVDClusterizer, DATCONSVDClusterLoaderAndPreparer, FastInterceptFinder2DFPGA, HitBasedT0Extractor, LayerPXDRelationFilter< AFilter, APrefilter >, LayerPXDRelationFilter< TrackingUtilities::ChooseableFilter< PXDPairFilterFactory > >, LayerPXDRelationFilter< TrackingUtilities::ChooseableFilter< PXDPairFilterFactory > >, NonIPCrossingStateFilter< AllPXDStateFilter >, NonIPCrossingStateFilter< AllPXDStateFilter >, NonIPCrossingStateFilter< AllSVDStateFilter >, NonIPCrossingStateFilter< AllSVDStateFilter >, PXDResultVarSet, RelationApplier, RelationFromSVDTracksCreator, ResultStorer< AResult >, ResultStorer< Belle2::CKFToPXDResult >, ResultStorer< Belle2::CKFToSVDResult >, ROICalculator, StoreArrayMerger, SVDResultVarSet, SVDShaperDigitConverter, ToPXDExtrapolator, CutsFromDBWireHitFilter, HitReclaimer, MCFacetRelationFilter, MCSegmentPairRelationFilter, MCSegmentTripleFilter, MCSegmentTripleRelationFilter, MCSymmetric< BaseAxialSegmentPairFilter >, MCSymmetric< BaseAxialSegmentPairFilter >, MCSymmetric< BaseFacetFilter >, MCSymmetric< BaseFacetFilter >, MCSymmetric< BaseFacetRelationFilter >, MCSymmetric< BaseFacetRelationFilter >, MCSymmetric< BaseSegmentPairFilter >, MCSymmetric< BaseSegmentPairFilter >, MCSymmetric< BaseSegmentPairRelationFilter >, MCSymmetric< BaseSegmentPairRelationFilter >, MCSymmetric< BaseSegmentRelationFilter >, MCSymmetric< BaseSegmentRelationFilter >, MCSymmetric< BaseSegmentTripleFilter >, MCSymmetric< BaseSegmentTripleFilter >, MCSymmetric< BaseSegmentTripleRelationFilter >, MCSymmetric< BaseSegmentTripleRelationFilter >, MCSymmetric< BaseTrackRelationFilter >, MCSymmetric< BaseTrackRelationFilter >, SegmentAliasResolver, SegmentCreatorMCTruth, SegmentFitter, SegmentOrienter, SegmentTrackTruthVarSet, StereoHitTrackQuadTreeMatcher< AQuadTree >, StereoHitTrackQuadTreeMatcher< Belle2::TrackFindingCDC::HyperHough< std::pair< TrackingUtilities::CDCRecoHit3D, const TrackingUtilities::CDCRLWireHit * >, FirstOfPairInBox< HitInHyperBox >, 4, 3, 2 > >, StereoHitTrackQuadTreeMatcher< Belle2::TrackFindingCDC::QuadraticLegendre< std::pair< TrackingUtilities::CDCRecoHit3D, const TrackingUtilities::CDCRLWireHit * >, FirstOfPairInBox< HitInQuadraticBox >, 2, 2 > >, StereoHitTrackQuadTreeMatcher< Belle2::TrackFindingCDC::Z0TanLambdaLegendre< std::pair< TrackingUtilities::CDCRecoHit3D, const TrackingUtilities::CDCRLWireHit * >, FirstOfPairInBox< HitInZ0TanLambdaBox >, 2, 2 > >, StereoHitTruthVarSet, TrackExporter, TrackOrienter, TrackQualityEstimator, TruthAxialSegmentPairVarSet, TruthSegmentVarSet, TruthTrackVarSet, WireHitCreator, WireHitMCMultiLoopBlocker, FilterVarSet< AFilter >, MVA< Filter< AVarSet::Object > >, MVA< Filter< Belle2::TrackFindingCDC::CDCWireHitVarSet::Object > >, MVA< Filter< typename AVarSet::Object > >, MVA< Filter< typename AVarSet::Object > >, OnVarSet< Filter< ATruthVarSet::Object > >, OnVarSet< Filter< AVarSet::Object > >, OnVarSet< Filter< Belle2::TrackFindingCDC::CDCWireHitVarSet::Object > >, OnVarSet< Filter< PXDResultVarSet::Object > >, OnVarSet< Filter< SVDResultVarSet::Object > >, OnVarSet< Filter< typename AVarSet::Object > >, OnVarSet< Filter< typename AVarSet::Object > >, Recording< Filter< AVarSet::Object > >, Recording< Filter< typename AVarSet::Object > >, Recording< Filter< typename AVarSet::Object > >, RelationVarSet< ABaseVarSet >, StoreArrayLoader< IOType >, StoreArrayLoader< const Belle2::SpacePoint >, StoreArrayLoader< DataStoreInputTypeRefType >, StoreVectorSwapper< IOType, a_alwaysWrite >, StoreVectorSwapper< Belle2::TrackingUtilities::CDCFacet >, StoreVectorSwapper< Belle2::TrackingUtilities::CDCSegment2D >, StoreVectorSwapper< Belle2::TrackingUtilities::CDCSegmentPair >, StoreVectorSwapper< Belle2::TrackingUtilities::CDCSegmentTriple >, StoreVectorSwapper< Belle2::TrackingUtilities::CDCTrack >, StoreVectorSwapper< Belle2::TrackingUtilities::CDCWireHit, true >, UnionVarSet< AObject >, UnionVarSet< Object >, VariadicUnionVarSet< AVarSets >, VariadicUnionVarSet< BasicAxialSegmentPairVarSet, FitlessAxialSegmentPairVarSet, FitAxialSegmentPairVarSet >, VariadicUnionVarSet< BasicAxialSegmentPairVarSet, FitlessAxialSegmentPairVarSet, FitAxialSegmentPairVarSet >, VariadicUnionVarSet< BasicAxialSegmentPairVarSet, HitGapAxialSegmentPairVarSet >, VariadicUnionVarSet< BasicAxialSegmentPairVarSet, HitGapAxialSegmentPairVarSet >, VariadicUnionVarSet< BasicFacetVarSet, TrackingUtilities::FilterVarSet< Chi2FacetFilter > >, VariadicUnionVarSet< BasicFacetVarSet, TrackingUtilities::FilterVarSet< Chi2FacetFilter > >, VariadicUnionVarSet< BasicSegmentPairRelationVarSet, FitSegmentPairRelationVarSet >, VariadicUnionVarSet< BasicSegmentPairRelationVarSet, FitSegmentPairRelationVarSet >, VariadicUnionVarSet< BasicSegmentPairVarSet, FitlessSegmentPairVarSet, FitSegmentPairVarSet >, VariadicUnionVarSet< BasicSegmentPairVarSet, FitlessSegmentPairVarSet, FitSegmentPairVarSet >, VariadicUnionVarSet< BasicSegmentPairVarSet, SkimmedHitGapSegmentPairVarSet >, VariadicUnionVarSet< BasicSegmentPairVarSet, SkimmedHitGapSegmentPairVarSet >, VariadicUnionVarSet< BasicSegmentRelationVarSet, FitlessSegmentRelationVarSet, FitSegmentRelationVarSet >, VariadicUnionVarSet< BasicSegmentRelationVarSet, FitlessSegmentRelationVarSet, FitSegmentRelationVarSet >, VariadicUnionVarSet< BasicSegmentRelationVarSet, HitGapSegmentRelationVarSet >, VariadicUnionVarSet< BasicSegmentRelationVarSet, HitGapSegmentRelationVarSet >, VariadicUnionVarSet< BasicTrackRelationVarSet, FitTrackRelationVarSet >, VariadicUnionVarSet< BasicTrackRelationVarSet, FitTrackRelationVarSet >, VariadicUnionVarSet< BasicTrackRelationVarSet, HitGapTrackRelationVarSet >, VariadicUnionVarSet< BasicTrackRelationVarSet, HitGapTrackRelationVarSet >, TrackLoader, MultiHoughSpaceFastInterceptFinder, QualityIndicatorFilter, RawTrackCandCleaner< AHit >, RawTrackCandCleaner< Belle2::vxdHoughTracking::VXDHoughState >, RecoTrackStorer, ROIFinder, SingleHoughSpaceFastInterceptFinder, SpacePointLoaderAndPreparer, TrackCandidateOverlapResolver, TrackCandidateResultRefiner, and TwoHitVirtualIPQIFilter.

Definition at line 15 of file CompositeProcessingSignalListener.cc.

16{
19 psl->initialize();
20 }
21}
virtual void initialize()
Receive signal before the start of the event processing.

◆ mergeTracks()

void mergeTracks ( TrackingUtilities::CDCTrack & track1,
TrackingUtilities::CDCTrack & track2,
const std::vector< const TrackingUtilities::CDCWireHit * > & allAxialWireHits )
staticprivate

Function to merge two track candidates.

The hits of track2 are deleted and transferred to track1 and the track1 is resorted. The method also applies some post processing and splits the track1 in case it appears to contain two back-to-back arms,

Definition at line 194 of file AxialTrackMerger.cc.

197{
198 if (&track1 == &track2) return;
199
200 CDCTrajectory2D trajectory2D = track1.getStartTrajectory3D().getTrajectory2D();
201 for (const CDCRecoHit3D& orgRecoHit3D : track2) {
202 CDCRecoHit3D recoHit3D = CDCRecoHit3D::reconstruct(orgRecoHit3D.getRLWireHit(), trajectory2D);
203 track1.push_back(std::move(recoHit3D));
204 }
205 track2.clear();
206
208
209 track2 = CDCTrack(AxialTrackUtil::splitBack2BackTrack(track1));
210
212
213 for (CDCRecoHit3D& recoHit3D : track2) {
214 const auto& tmp = recoHit3D.getRefPos2D();
215 recoHit3D.setRecoPos3D({tmp.X(), tmp.Y(), 0});
216 recoHit3D.setRLInfo(ERightLeft::c_Unknown);
217 }
218
220 bool success = AxialTrackUtil::postprocessTrack(track2, allAxialWireHits);
221 if (not success) {
222 for (const CDCRecoHit3D& recoHit3D : track2) {
223 recoHit3D.getWireHit()->setTakenFlag(false);
224 }
225 track2.clear();
226 }
227}
void setTakenFlag(bool setTo=true)
Sets the taken flag to the given value. Default value true.
const CDCWireHit & getWireHit() const
Getter for the wire hit.
const ROOT::Math::XYVector & getRefPos2D() const
Getter for the reference position of the wire.
static CDCRecoHit3D reconstruct(const CDCRecoHit2D &recoHit2D, const CDCTrajectory2D &trajectory2D)
Reconstructs the three dimensional hit from the two dimensional and the two dimensional trajectory.
void setRLInfo(ERightLeft rlInfo)
Setter the right left passage information.
void setRecoPos3D(const ROOT::Math::XYZVector &recoPos3D)
Setter for the 3d position of the hit.
static std::vector< TrackingUtilities::CDCRecoHit3D > splitBack2BackTrack(TrackingUtilities::CDCTrack &track)
Tries to split back-to-back tracks into two different tracks.
static bool postprocessTrack(TrackingUtilities::CDCTrack &track, const std::vector< const TrackingUtilities::CDCWireHit * > &allAxialWireHits)
Perform all track postprocessing - return whether the track is considered good after the postprocessi...

◆ removeStrangeHits()

void removeStrangeHits ( double factor,
std::vector< const TrackingUtilities::CDCWireHit * > & wireHits,
TrackingUtilities::CDCTrajectory2D & trajectory )
staticprivate

Remove all hits that are further than factor * driftlength away from the trajectory.

Parameters
factorgives a number how far the hit is allowed to be.
wireHitsthe wirehits that should be considered
trajectorythe reference trajectory

Definition at line 181 of file AxialTrackMerger.cc.

184{
185 auto farFromTrajectory = [&trajectory2D, &factor](const CDCWireHit * wireHit) {
186 ROOT::Math::XYVector pos2D = wireHit->getRefPos2D();
187 double driftLength = wireHit->getRefDriftLength();
188 double dist = std::fabs(trajectory2D.getDist2D(pos2D)) - driftLength;
189 return std::fabs(dist) > driftLength * factor;
190 };
191 erase_remove_if(wireHits, farFromTrajectory);
192}

◆ terminate()

Member Data Documentation

◆ m_initialized

bool m_initialized = false
privateinherited

Flag to keep track whether initialization happened before.

Definition at line 52 of file ProcessingSignalListener.h.

◆ m_initializedAs

std::string m_initializedAs
privateinherited

Name of the type during initialisation.

Definition at line 58 of file ProcessingSignalListener.h.

◆ m_param_minFitProb

double m_param_minFitProb = 0.85
private

Parameter : Minimal fit probability of the common fit of two tracks to be eligible for merging.

Definition at line 101 of file AxialTrackMerger.h.

◆ m_subordinaryProcessingSignalListeners

std::vector<ProcessingSignalListener*> m_subordinaryProcessingSignalListeners
privateinherited

References to subordinary signal processing listener contained in this findlet.

Definition at line 60 of file CompositeProcessingSignalListener.h.

◆ m_terminated

bool m_terminated = false
privateinherited

Flag to keep track whether termination happened before.

Definition at line 55 of file ProcessingSignalListener.h.


The documentation for this class was generated from the following files: