Belle II Software  release-08-01-10
ThreeHitFilter Class Reference

Filter for three hits. More...

#include <ThreeHitFilter.h>

Inheritance diagram for ThreeHitFilter:
Collaboration diagram for ThreeHitFilter:

Public Types

using Object = AObject
 Type of the object to be analysed.
 
using Interface = Filter< AObject >
 Mark this class as the basic interface.
 

Public Member Functions

TrackFindingCDC::Weight operator() (const BasePathFilter::Object &pair) override
 Return the weight based on the ThreeHitVariables. More...
 
void exposeParameters (ModuleParamList *moduleParamList, const std::string &prefix) override
 Expose the parameters.
 
void beginRun () override
 set BField value for estimator
 
virtual bool needsTruthInformation ()
 Indicates if the filter requires Monte Carlo information.
 
Weight operator() (const Object *obj)
 Function to evaluate the object. More...
 
void initialize () override
 Receive and dispatch signal before the start of the event processing.
 
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 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 = ProcessingSignalListener
 Type of the base class.
 

Private Attributes

double m_cosRZCut = 0.95
 cut for cosine in RZ between the two vectors (oHit - cHit) and (cHit - iHit)
 
double m_circleIPDistanceCut = 2.0
 cut on the difference between circle radius and circle center position in the x-y plane to check if the track is compatible with passing through the IP
 
ThreeHitVariables m_threeHitVariables
 Construct empty ThreeHitVariables 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.
 

Detailed Description

Filter for three hits.

Basic working principle: use ThreeHitVariables and provide three B2Vector3D to each variable. These are oHit (outer hit), cHit (middle hit), and iHit (inner hit) and then calculate the variables specified in ThreeHitVariables using the three positions, often using the difference (oHit - cHit) and (cHit - iHit).

Definition at line 26 of file ThreeHitFilter.h.

Member Function Documentation

◆ operator()() [1/2]

TrackFindingCDC::Weight operator() ( const BasePathFilter::Object pair)
overridevirtual

Return the weight based on the ThreeHitVariables.

Returns NAN if m_threeHitVariables.getCosAngleRZSimple() of the hit triplet is smaller than m_cosRZCut Returns NAN if m_threeHitVariables.getCircleDistanceIP() of the hit triplet is larger than m_circleIPDistanceCut Returns 1/m_threeHitVariables.getCircleDistanceIP() else

Reimplemented from Filter< AObject >.

Definition at line 35 of file ThreeHitFilter.cc.

36 {
37  const std::vector<TrackFindingCDC::WithWeight<const VXDHoughState*>>& previousHits = pair.first;
38 
39  // Do nothing if path is too short or too long
40  if (previousHits.size() != 2) {
41  return NAN;
42  }
43 
44  const B2Vector3D& firstHitPos = previousHits.at(0)->getHit()->getPosition();
45  const B2Vector3D& secondHitPos = previousHits.at(1)->getHit()->getPosition();
46  const B2Vector3D& currentHitPos = pair.second->getHit()->getPosition();
47 
48  m_threeHitVariables.setHits(firstHitPos, secondHitPos, currentHitPos);
49 
51  return NAN;
52  }
53 
54  const double circleDistanceIP = m_threeHitVariables.getCircleDistanceIP();
55 
56  if (circleDistanceIP > m_circleIPDistanceCut) {
57  return NAN;
58  }
59 
60  return fabs(1.0 / circleDistanceIP);
61 }
ThreeHitVariables m_threeHitVariables
Construct empty ThreeHitVariables instance.
double m_cosRZCut
cut for cosine in RZ between the two vectors (oHit - cHit) and (cHit - iHit)
double m_circleIPDistanceCut
cut on the difference between circle radius and circle center position in the x-y plane to check if t...
double getCosAngleRZSimple()
calculates the cosine of the angle between the hits/vectors (RZ), returning unit: none (calculation f...
void setHits(const B2Vector3D &oHit, const B2Vector3D &cHit, const B2Vector3D &iHit)
Set hits if not given in constructor of if they need to be changed.
double getCircleDistanceIP()
calculates the distance of the point of closest approach of circle to the IP, returning unit: cm
DataType at(unsigned i) const
safe member access (with boundary check!)
Definition: B2Vector3.h:751

◆ operator()() [2/2]

Weight operator() ( const Object obj)
inherited

Function to evaluate the object.

Base implementation accepts all objects, except nullptr.

Parameters
objThe object to be accepted or rejected.
Returns
A finit float value if the object is accepted. NAN if the object is rejected. Nullptr is always rejected.

Definition at line 58 of file Filter.icc.h.


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