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

A segment consisting of three dimensional reconstructed hits. More...

#include <CDCSegment3D.h>

Inheritance diagram for CDCSegment3D:
Collaboration diagram for CDCSegment3D:

Public Member Functions

CDCSegment2D stereoProjectToRef () const
 Constructs a two dimensional segment by carrying out the stereo ! projection to the wire reference postion. More...
 
AutomatonCellgetAutomatonCell () const
 Mutable getter for the automaton cell.
 
AutomatonCelloperator-> () const
 Indirection to the automaton cell for easier access to the flags.
 
void unsetAndForwardMaskedFlag (bool toHits=true) const
 Unset the masked flag of the automaton cell of this segment and of all contained wire hits.
 
void setAndForwardMaskedFlag (bool toHits=true) const
 Set the masked flag of the automaton cell of this segment and forward the masked flag to all contained wire hits.
 
void receiveMaskedFlag (bool fromHits=true) const
 Check all contained wire hits if one has the masked flag. More...
 
CDCTrajectory3DgetTrajectory3D () const
 Getter for the two dimensional trajectory fitted to the segment.
 
void setTrajectory3D (const CDCTrajectory3D &trajectory3D) const
 Setter for the two dimensional trajectory fitted to the segment.
 
EStereoKind getStereoKind () const
 Returns the common stereo type of all hits. More...
 
bool isAxial () const
 Indicator if the underlying wires are axial.
 
ISuperLayer getISuperLayer () const
 Returns the common super layer id of all stored tracking hits. More...
 
const std::vector< CDCRecoHit3D > & items () const
 Legacy accessor for the items of the segments, still used in some corners.
 
CDCTrajectory2DgetTrajectory2D () const
 Getter for the two dimensional trajectory fitted to the segment.
 
void setTrajectory2D (const CDCTrajectory2D &trajectory2D) const
 Setter for the two dimensional trajectory fitted to the segment.
 
void sortByArcLength2D ()
 Sort the recoHits according to their perpS information.
 
double getAliasScore () const
 Getter for the flag that this segment may have an aliased version.
 
void setAliasScore (double aliasScore)
 Setter for the flag that this segment may have an aliased version.
 

Static Public Member Functions

static CDCSegment3D reconstruct (const CDCSegment2D &segment2D, const CDCTrajectory2D &trajectory2D)
 Reconstructs a two dimensional stereo segment by shifting each hit onto the given two dimensional trajectory.
 

Public Attributes

elements
 STL member.
 

Private Attributes

AutomatonCell m_automatonCell
 Memory for the automaton cell. More...
 
CDCTrajectory3D m_trajectory3D
 Memory for the three dimensional trajectory fitted to this segment.
 
CDCTrajectory2D m_trajectory2D
 Memory for the two dimensional trajectory fitted to this segment.
 
double m_aliasScore
 Boolean flag to indicate that this segment has a valid alias version.
 

Detailed Description

A segment consisting of three dimensional reconstructed hits.

Definition at line 26 of file CDCSegment3D.h.

Member Function Documentation

◆ getISuperLayer()

ISuperLayer getISuperLayer ( ) const
inlineinherited

Returns the common super layer id of all stored tracking hits.

This checks if all items are located in the same superlayer and returns the superlayer id of the later. Returns ISuperLayerUtil::c_Invalid, if the superlayer is not shared among the hits.

Definition at line 57 of file CDCSegment.h.

◆ getStereoKind()

EStereoKind getStereoKind ( ) const
inlineinherited

Returns the common stereo type of all hits.

This checks if all tracking hits are located in the same superlayer and
returns the stereo type of the later. Returns EStereoKind::c_Invalid if the superlayer
is not shared among the tracking hits.

Definition at line 39 of file CDCSegment.h.

◆ receiveMaskedFlag()

void receiveMaskedFlag ( bool  fromHits = true) const

Check all contained wire hits if one has the masked flag.

Set the masked flag of this segment in case at least one of the contained wire hits is flagged as masked.

Definition at line 62 of file CDCSegment3D.cc.

63 {
64  if (not fromHits) return;
65  int nMasked = 0 ;
66  int nNotMasked = 0;
67  for (const CDCRecoHit3D& recoHit3D : *this) {
68  const CDCWireHit& wireHit = recoHit3D.getWireHit();
69  if (wireHit.getAutomatonCell().hasMaskedFlag()) {
70  ++nMasked;
71  } else {
72  ++nNotMasked;
73  }
74  }
75 
76  const int nTolerance = 2;
77  if (nMasked > nNotMasked or nMasked >= nTolerance) {
79  }
80 }
void setMaskedFlag(bool setTo=true)
Sets the masked flag to the given value. Default value true.
bool hasMaskedFlag() const
Gets the current state of the masked marker flag.
Class representing a three dimensional reconstructed hit.
Definition: CDCRecoHit3D.h:52
const CDCWireHit & getWireHit() const
Getter for the wire hit.
Definition: CDCRecoHit3D.h:238
AutomatonCell & getAutomatonCell() const
Mutable getter for the automaton cell.
Definition: CDCSegment3D.h:40
Class representing a hit wire in the central drift chamber.
Definition: CDCWireHit.h:55
AutomatonCell & getAutomatonCell() const
Mutable getter for the automaton cell.
Definition: CDCWireHit.h:286

◆ stereoProjectToRef()

CDCSegment2D stereoProjectToRef ( ) const

Constructs a two dimensional segment by carrying out the stereo ! projection to the wire reference postion.

Note : no fitting information is transported to the resulting segment.

Definition at line 32 of file CDCSegment3D.cc.

Member Data Documentation

◆ m_automatonCell

AutomatonCell m_automatonCell
mutableprivate

Memory for the automaton cell.

It is declared mutable because it can vary rather freely despite of the hit content might be required fixed.

Definition at line 88 of file CDCSegment3D.h.


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