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

Hit pattern of CDC hits within a track. More...

#include <HitPatternCDC.h>

Collaboration diagram for HitPatternCDC:

Public Member Functions

 HitPatternCDC ()
 Create empty pattern.
 
 HitPatternCDC (ULong64_t initValue)
 Initialize the pattern with an integer.
 
ULong64_t getInteger () const
 Getter for underlying integer type.
 
unsigned short getNHits () const
 Get the total Number of CDC hits in the fit. More...
 
void setNHits (unsigned short nHits)
 Sets the 8 MSBs to the total number of hits in the CDC. More...
 
void setLayer (const unsigned short layer)
 Set bit corresponding to layer to true. More...
 
void resetLayer (const unsigned short layer)
 Set bit corresponding to layer to false. More...
 
bool hasLayer (const unsigned short layer) const
 Getter for single layer. More...
 
short getFirstLayer () const
 Returns the index of the first layer with a hit. More...
 
short getLastLayer () const
 Returns the index of the last layer with a hit. More...
 
bool hasSLayer (const unsigned short sLayer) const
 Getter for super-layer match. More...
 
void resetSLayer (const unsigned short sLayer)
 Reset complete superLayer, e.g. More...
 
std::bitset< 64 > getSLayerPattern (const unsigned short sLayer)
 Get the bit pattern in a specific super layer. More...
 
unsigned short getSLayerNHits (const unsigned short sLayer) const
 Getter for the number of hits in one super-layer. More...
 
unsigned short getLongestContRunInSL (const unsigned short sLayer) const
 Getter for longest run of consecutive layers with hits within the given Super-layer. More...
 
bool hasAxialLayer () const
 True, if at least one axial layer is true.
 
bool hasStereoLayer () const
 True, if at least one axial layer is true.
 
std::string __str__ () const
 String for printing in python.
 

Private Member Functions

std::bitset< 64 > getBitSet () const
 Getter for underlying bit set. More...
 
void resetPattern ()
 Reset the complete hit pattern. More...
 

Private Attributes

std::bitset< 64 > m_pattern
 Saves the actual pattern.
 

Static Private Attributes

static const std::bitset< 64 > s_sLayerMasks [9]
 Masks to zero out all bits from other layers. More...
 
static const std::bitset< 64 > s_infoLayerMask = infoLayerCDC
 Mask to zero out all bits from other layers.
 
static const std::map< unsigned short, std::pair< unsigned short, unsigned short > > s_superLayerIndices
 Holds the indices for super layer access. More...
 

Friends

class HitPatternCDCTest_settersNGetters_Test
 
class HitPatternCDCTest_getFirstLastLayer_Test
 

Detailed Description

Hit pattern of CDC hits within a track.

The pattern is stored using a std::bitset. This allows to use the STL, which is very efficiently programmed.

For each layer there is one bit. The layer counting is from 0 to 55. Super-layer information is generated on demand. The super-layer counting goes from 0 to 8.

The numbering scheme just in this class is equivalent to the one defined in the note BELLE2-NOTE-TE-2015-022: https://docs.belle2.org/record/256

See also
HitPatternVXD

Definition at line 35 of file HitPatternCDC.h.

Member Function Documentation

◆ getBitSet()

std::bitset<64> getBitSet ( ) const
inlineprivate

Getter for underlying bit set.

Just for testing.

Definition at line 166 of file HitPatternCDC.h.

166 { return m_pattern; }
std::bitset< 64 > m_pattern
Saves the actual pattern.

◆ getFirstLayer()

short getFirstLayer ( ) const

Returns the index of the first layer with a hit.

If there is no hit in the whole pattern, -1 is returned.

Returns
Index of last layer.

Definition at line 96 of file HitPatternCDC.cc.

97 {
98  for (unsigned int i = 0; i < m_pattern.size(); ++i) {
99  if ((m_pattern & ~s_infoLayerMask).test(i)) return i;
100  }
101  return -1;
102 }
static const std::bitset< 64 > s_infoLayerMask
Mask to zero out all bits from other layers.

◆ getLastLayer()

short getLastLayer ( ) const

Returns the index of the last layer with a hit.

If there is no hit in the whole pattern, -1 is returned.

Returns
Index of last layer.

Definition at line 104 of file HitPatternCDC.cc.

◆ getLongestContRunInSL()

unsigned short getLongestContRunInSL ( const unsigned short  sLayer) const

Getter for longest run of consecutive layers with hits within the given Super-layer.

Parameters
sLayerSuper-layer index.
Returns
Length of longest run.

Definition at line 139 of file HitPatternCDC.cc.

◆ getNHits()

unsigned short getNHits ( ) const

Get the total Number of CDC hits in the fit.

Nota Bene: The maximum value returned here is 255. This is because only 8 bits are available to store the information. If the track had more than 255 hits, e.g. because it was a curler, the returned value may be to small.

Returns
Number of hits in the CDC.

Definition at line 47 of file HitPatternCDC.cc.

◆ getSLayerNHits()

unsigned short getSLayerNHits ( const unsigned short  sLayer) const

Getter for the number of hits in one super-layer.

Nota Bene: As only a bitwise information is available if a layer is hit, under-counting is possible if in at least one layer more than one wire is hit.

Parameters
sLayerSuper-layer index.
Returns
Number of hits in super-layer.

Definition at line 133 of file HitPatternCDC.cc.

◆ getSLayerPattern()

std::bitset< 64 > getSLayerPattern ( const unsigned short  sLayer)

Get the bit pattern in a specific super layer.

Parameters
sLayerSuper-layer index.
Returns
Super-layer bit pattern.

Definition at line 128 of file HitPatternCDC.cc.

◆ hasLayer()

bool hasLayer ( const unsigned short  layer) const

Getter for single layer.

Parameters
layerLayer index.
Returns
Boolean if layer is hit or not.

Definition at line 90 of file HitPatternCDC.cc.

◆ hasSLayer()

bool hasSLayer ( const unsigned short  sLayer) const

Getter for super-layer match.

Parameters
sLayersuper-layer index.

Definition at line 114 of file HitPatternCDC.cc.

◆ resetLayer()

void resetLayer ( const unsigned short  layer)

Set bit corresponding to layer to false.

This function may throw an out-of-range exception.

Parameters
layerLayer index.

Definition at line 84 of file HitPatternCDC.cc.

◆ resetPattern()

void resetPattern ( )
inlineprivate

Reset the complete hit pattern.

Just for testing.

Definition at line 169 of file HitPatternCDC.h.

◆ resetSLayer()

void resetSLayer ( const unsigned short  sLayer)

Reset complete superLayer, e.g.

because segment shouldn't belong to that track.

Parameters
sLayerSuper-layer index.

Definition at line 120 of file HitPatternCDC.cc.

◆ setLayer()

void setLayer ( const unsigned short  layer)

Set bit corresponding to layer to true.

This function may throw an out-of-range exception.

Parameters
layerLayer index.

Definition at line 78 of file HitPatternCDC.cc.

◆ setNHits()

void setNHits ( unsigned short  nHits)

Sets the 8 MSBs to the total number of hits in the CDC.

Nota Bene: If the whole track has more than 255 hits, e.g. because it is a curler, the value is set to 255.

Parameters
nHitsNumber of hits in the CDC.

Definition at line 53 of file HitPatternCDC.cc.

Member Data Documentation

◆ s_sLayerMasks

const std::bitset< 64 > s_sLayerMasks
staticprivate
Initial value:
= {sLayerZer, sLayerOne, sLayerTwo, sLayerThr, sLayerFou,
sLayerFiv, sLayerSix, sLayerSev, sLayerEig
}

Masks to zero out all bits from other layers.

Definition at line 159 of file HitPatternCDC.h.

◆ s_superLayerIndices

const std::map< unsigned short, std::pair< unsigned short, unsigned short > > s_superLayerIndices
staticprivate
Initial value:
= {
{0, std::make_pair(0, 7)},
{1, std::make_pair(8, 13)},
{2, std::make_pair(14, 19)},
{3, std::make_pair(20, 25)},
{4, std::make_pair(26, 31)},
{5, std::make_pair(32, 37)},
{6, std::make_pair(38, 43)},
{7, std::make_pair(44, 49)},
{8, std::make_pair(50, 55)}
}

Holds the indices for super layer access.

Definition at line 163 of file HitPatternCDC.h.


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