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

Base class for filtering the neighborhood of segments. More...

#include <BaseSegmentRelationFilter.h>

Inheritance diagram for BaseSegmentRelationFilter:
Collaboration diagram for BaseSegmentRelationFilter:

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

 BaseSegmentRelationFilter ()
 Default constructor.
 
virtual ~BaseSegmentRelationFilter ()
 Default destructor.
 
std::vector< const CDCSegment2D * > getPossibleTos (const CDCSegment2D *from, const std::vector< const CDCSegment2D * > &segments) const final
 Returns all equivalent segment in the range.
 
Weight operator() (const Relation< const CDCSegment2D > &relation) override
 Main filter method overriding the filter interface method. More...
 
virtual std::vector< const CDCSegment2D * > getPossibleTos (const CDCSegment2D *from, const std::vector< const CDCSegment2D * > &objects) const
 Selects the objects possibly related to the given one from the given pool of objects.
 
virtual Weight operator() (const const CDCSegment2D &from, const const CDCSegment2D &to)
 Main filter method returning the weight of the neighborhood relation. More...
 
Weight operator() (const Relation< const CDCSegment2D > &relation) override
 Main filter method overriding the filter interface method. More...
 
virtual Weight operator() (const Object &obj)
 Function to evaluate the object. More...
 
Weight operator() (const Object *obj)
 Function to evaluate the object. More...
 
virtual void exposeParameters (ModuleParamList *moduleParamList, const std::string &prefix)
 Expose the set of parameters of the filter to the module parameter list. More...
 
virtual bool needsTruthInformation ()
 Indicates if the filter requires Monte Carlo information.
 
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 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 = RelationFilter< const CDCSegment2D >
 Type of the base class.
 

Private Attributes

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

Base class for filtering the neighborhood of segments.

Definition at line 30 of file BaseSegmentRelationFilter.h.

Member Function Documentation

◆ exposeParameters()

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

Expose the set of parameters of the filter to the module parameter list.

Note that not all filters have yet exposed their parameters in this way.

This method is deprecated as the exposeParams below uses a less compile heavy equivalent.

Reimplemented in SimpleRelationFilter, AngleAndTimeRelationFilter, TwoHitVirtualIPQIFilter, TwoHitVirtualIPFilter, ThreeHitFilter, QualityIndicatorFilter, FourHitFilter, FiveHitFilter, BridgingWireHitRelationFilter, PhiTrackRelationFilter, SimpleFacetRelationFilter, Chi2FacetRelationFilter, Recording< Filter< AVarSet::Object > >, MVA< Filter< AVarSet::Object > >, MCSymmetric< BaseAxialSegmentPairFilter >, MCSymmetric< BaseSegmentPairFilter >, MCSymmetric< BaseSegmentTripleRelationFilter >, MCSymmetric< BaseSegmentPairRelationFilter >, MCSymmetric< BaseTrackRelationFilter >, MCSymmetric< BaseSegmentTripleFilter >, MCSymmetric< BaseSegmentRelationFilter >, MCSymmetric< BaseFacetRelationFilter >, MCSymmetric< BaseFacetFilter >, PhiRecoTrackRelationFilter, ResidualSVDStateFilter, SensorSVDPairFilter, LooseSVDPairFilter, SensorPXDPairFilter, LoosePXDPairFilter, LayerPXDRelationFilter< AFilter, APrefilter >, AdvanceFilter< AState, AnAdvancer >, RoughCDCStateFilter, RoughCDCfromEclStateFilter, ExtrapolateAndUpdateCDCStateFilter, DistanceCDCStateFilter, DuplicateCDCPathPairFilter, LayerRelationFilter< AFilter >, WholeWireHitRelationFilter, MCSegmentTripleRelationFilter, MCSegmentTripleFilter, MCSegmentRelationFilter, MCSegmentPairRelationFilter, MCSegmentPairFilter, MCFacetRelationFilter, SimpleFacetFilter, RealisticFacetFilter, FeasibleRLFacetFilter, Chi2FacetFilter, MCAxialSegmentPairFilter, SectorMapBasedSVDPairFilter, and LayerSVDRelationFilter< AFilter, APrefilter >.

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

◆ operator()() [1/5]

Weight operator() ( const const CDCSegment2D from,
const const CDCSegment2D to 
)
virtualinherited

Main filter method returning the weight of the neighborhood relation.

Return always returns NAN to reject all segment neighbors.

Definition at line 44 of file RelationFilter.icc.h.

◆ operator()() [2/5]

◆ operator()() [3/5]

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.

◆ operator()() [4/5]

Weight operator() ( const Relation< const CDCSegment2D > &  relation)
overrideinherited

Main filter method overriding the filter interface method.

Checks the validity of the pointers in the relation and unpacks the relation to the method implementing the rejection.

Definition at line 51 of file RelationFilter.icc.h.

◆ operator()() [5/5]

Weight operator() ( const Relation< const CDCSegment2D > &  relation)
override

Main filter method overriding the filter interface method.

Checks the validity of the pointers in the relation and unpacks the relation to the method implementing the rejection.

Definition at line 49 of file BaseSegmentRelationFilter.cc.

50 {
51  const CDCSegment2D* from = relation.getFrom();
52  const CDCSegment2D* to = relation.getTo();
53  if (from == to) return NAN; // Prevent relation to same.
54  if ((from == nullptr) or (to == nullptr)) return NAN;
55 
56  // Make an overlap check to prevent aliases and reverse segments to be linked
57  std::vector<const CDCWireHit*> fromWireHits;
58  fromWireHits.reserve(from->size());
59  for (const CDCRecoHit2D& recoHit2D : *from) {
60  fromWireHits.push_back(&recoHit2D.getWireHit());
61  }
62  std::sort(fromWireHits.begin(), fromWireHits.end());
63  int nOverlap = 0;
64  for (const CDCRecoHit2D& recoHit2D : *to) {
65  if (std::binary_search(fromWireHits.begin(), fromWireHits.end(), &recoHit2D.getWireHit())) {
66  ++nOverlap;
67  }
68  }
69 
70  if (1.0 * nOverlap / from->size() > 0.8) {
71  return NAN;
72  }
73 
74  return this->operator()(*from, *to);
75 }
Weight operator()(const Relation< const CDCSegment2D > &relation) override
Main filter method overriding the filter interface method.
Class representing a two dimensional reconstructed hit in the central drift chamber.
Definition: CDCRecoHit2D.h:47
A reconstructed sequence of two dimensional hits in one super layer.
Definition: CDCSegment2D.h:39
To * getTo() const
Getter for the pointer to the to side object.
Definition: Relation.h:65
From * getFrom() const
Getter for the pointer to the from side object.
Definition: Relation.h:59

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