|  | Belle II Software
    release-08-02-04
    | 
A matcher algorithm for using a stereo quad tree for matching rl tagged wire hits to tracks. More...
#include <StereoHitTrackQuadTreeMatcher.h>


| Public Types | |
| using | WeightedRelationItem = WeightedRelation< CDCTrack, const CDCRLWireHit > | 
| Shortcut class name for a weighted relation between a collector item and a collection item. | |
| using | IOTypes = std::tuple< AIOTypes... > | 
| Types that should be served to apply on invokation. | |
| using | IOVectors = std::tuple< std::vector< AIOTypes >... > | 
| Vector types that should be served to apply on invokation. | |
| Public Member Functions | |
| void | exposeParameters (ModuleParamList *moduleParamList, const std::string &prefix) override | 
| Expose the parameters to the module. | |
| void | initialize () override | 
| Initialize the filter and the quad tree. | |
| void | terminate () override | 
| Terminate the filter and the quad tree. | |
| void | apply (std::vector< CDCTrack > &collectorItems, const std::vector< CDCRLWireHit > &collectionItems, std::vector< WeightedRelationItem > &weightedRelations) override | 
| Main function: create weighted relations between collectors and collection items using the implemented functionality overriden in a derived class. | |
| virtual void | apply (ToVector< AIOTypes > &... ioVectors)=0 | 
| Main function executing the algorithm. | |
| virtual std::string | getDescription () | 
| Brief description of the purpose of the concret findlet. | |
| 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. | |
| Protected Types | |
| template<class T > | |
| using | ToVector = typename ToVectorImpl< T >::Type | 
| Short hand for ToRangeImpl. | |
| Protected Member Functions | |
| virtual void | match (CDCTrack &collectorItem, const std::vector< CDCRLWireHit > &collectionItems, std::vector< WeightedRelationItem > &relationsForCollector) | 
| Override this function to implement your own matching algorithm between one collector and many collection items.  More... | |
| virtual Weight | match (CDCTrack &collectorItem, const CDCRLWireHit &collectionItem) | 
| Override this function to implement your own matching algorithm between one collector and one collection items.  More... | |
| 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 = MatcherInterface< CDCTrack, CDCRLWireHit > | 
| The parent class. | |
| Private Member Functions | |
| void | match (CDCTrack &track, const std::vector< CDCRLWireHit > &rlWireHits, std::vector< Super::WeightedRelationItem > &relationsForCollector) override | 
| Create a QuadTree and fill with each unused stereo hit (to be exact: twice for each stereo hit - right and left).  More... | |
| void | writeDebugInformation () | 
| Use the writeDebugInformation function of the quad tree to write the tree into a root file with a ascending number. | |
| Private Attributes | |
| bool | m_param_checkForB2BTracks = true | 
| Parameters Set to false to skip the B2B check (good for curlers). | |
| double | m_param_checkForInWireBoundsFactor = 1.0 | 
| Set to false to skip the in-wire-bound check (good for second stage). | |
| unsigned int | m_param_quadTreeLevel = 7 | 
| Maximum level of the quad tree search. | |
| unsigned int | m_param_minimumNumberOfHits = 5 | 
| Minimal number of hits a quad tree node must have to be called a found bin. | |
| bool | m_param_writeDebugInformation = false | 
| Set to true to output debug information. | |
| unsigned int | m_numberOfPassedDebugCalls = 0 | 
| Store the number of passed calls to the debug function. | |
| AQuadTree | m_quadTreeInstance | 
| Quad tree instance. | |
| 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 happend before. | |
| bool | m_terminated = false | 
| Flag to keep track whether termination happend before. | |
| std::string | m_initializedAs | 
| Name of the type during initialisation. | |
A matcher algorithm for using a stereo quad tree for matching rl tagged wire hits to tracks.
Definition at line 25 of file StereoHitTrackQuadTreeMatcher.h.
| 
 | inlineprotectedvirtualinherited | 
Override this function to implement your own matching algorithm between one collector and one collection items.
If you override this function, you just have to return a weight - the rest of the logic is handled by the MatcherInterface class.
Definition at line 82 of file MatcherInterface.h.
| 
 | inlineprotectedvirtualinherited | 
Override this function to implement your own matching algorithm between one collector and many collection items.
A reason to override this instead of the other match function could be, if you want to apply some sort of caching for each collector item.
Definition at line 68 of file MatcherInterface.h.
| 
 | overrideprivate | 
Create a QuadTree and fill with each unused stereo hit (to be exact: twice for each stereo hit - right and left).
The QuadTree has two dimensions: inverse slope in z-direction and z0. Each bin with a high number of items (= stereo hits) in it is stored. Later, the one node with the highest number of items in it is taken and each hit is assigned to the track.
Definition at line 82 of file StereoHitTrackQuadTreeMatcher.cc.