CMS 3D CMS Logo

List of all members | Public Member Functions | Static Public Member Functions | Private Attributes | Static Private Attributes
PeriodicBinFinderInPhi< T > Class Template Reference

#include <MagBLayer.h>

Inheritance diagram for PeriodicBinFinderInPhi< T >:
BaseBinFinder< T >

Public Member Functions

int binIndex (T phi) const override
 returns an index in the valid range for the bin that contains phi More...
 
int binIndex (int i) const override
 returns an index in the valid range, modulo Nbins More...
 
T binPosition (int ind) const override
 the middle of the bin in radians More...
 
 PeriodicBinFinderInPhi ()
 
 PeriodicBinFinderInPhi (T firstPhi, int nbins)
 
- Public Member Functions inherited from BaseBinFinder< T >
 BaseBinFinder ()
 
virtual ~BaseBinFinder ()
 

Static Public Member Functions

static constexpr T pi ()
 
static constexpr T twoPi ()
 

Private Attributes

T theInvPhiStep =0
 
int theNbins =0
 
T thePhiOffset =0
 
T thePhiStep =0
 

Static Private Attributes

static constexpr T piC = 3.141592653589793238
 
static constexpr T twoPiC = 2*piC
 

Detailed Description

template<class T>
class PeriodicBinFinderInPhi< T >

Periodic Bin Finder around a circle for (almost) equidistant bins. Phi is the angle on the circle in radians.

Definition at line 21 of file MagBLayer.h.

Constructor & Destructor Documentation

template<class T>
PeriodicBinFinderInPhi< T >::PeriodicBinFinderInPhi ( )
inline

Definition at line 17 of file PeriodicBinFinderInPhi.h.

17 {}
template<class T>
PeriodicBinFinderInPhi< T >::PeriodicBinFinderInPhi ( T  firstPhi,
int  nbins 
)
inline

Member Function Documentation

template<class T>
int PeriodicBinFinderInPhi< T >::binIndex ( T  phi) const
inlineoverridevirtual

returns an index in the valid range for the bin that contains phi

Implements BaseBinFinder< T >.

Definition at line 24 of file PeriodicBinFinderInPhi.h.

Referenced by MTDDetRing::compatibleDets(), MuDetRing::compatibleDets(), TECLayer::computeCrossings(), TIDRing::computeCrossings(), Phase2EndcapRing::computeCrossings(), PixelForwardLayer::computeCrossings(), PixelForwardLayerPhase1::computeCrossings(), TIBRing::computeCrossings(), MagBLayer::findVolume(), MagGeometry::findVolume(), PixelForwardLayer::groupedCompatibleDetsV(), PixelForwardLayerPhase1::groupedCompatibleDetsV(), TIBRing::groupedCompatibleDetsV(), PixelForwardLayer::searchNeighbors(), PixelForwardLayerPhase1::searchNeighbors(), TECLayer::searchNeighbors(), TIDRing::searchNeighbors(), Phase2EndcapRing::searchNeighbors(), TBPLayer::searchNeighbors(), and TIBRing::searchNeighbors().

24  {
25  T tmp = std::fmod((phi - thePhiOffset), twoPiC)*theInvPhiStep;
26  if ( tmp < 0) tmp += theNbins;
27  return std::min( int(tmp), theNbins-1);
28  }
T min(T a, T b)
Definition: MathUtil.h:58
std::vector< std::vector< double > > tmp
Definition: MVATrainer.cc:100
long double T
template<class T>
int PeriodicBinFinderInPhi< T >::binIndex ( int  i) const
inlineoverridevirtual

returns an index in the valid range, modulo Nbins

Implements BaseBinFinder< T >.

Definition at line 31 of file PeriodicBinFinderInPhi.h.

31  {
32  int ind = i % theNbins;
33  return ind < 0 ? ind+theNbins : ind;
34  }
template<class T>
T PeriodicBinFinderInPhi< T >::binPosition ( int  ind) const
inlineoverridevirtual

the middle of the bin in radians

Implements BaseBinFinder< T >.

Definition at line 37 of file PeriodicBinFinderInPhi.h.

37  {
38  return thePhiOffset + thePhiStep * ( T(ind) + T(0.5));
39  }
long double T
template<class T>
static constexpr T PeriodicBinFinderInPhi< T >::pi ( )
inlinestatic

Definition at line 41 of file PeriodicBinFinderInPhi.h.

41 { return piC;}
template<class T>
static constexpr T PeriodicBinFinderInPhi< T >::twoPi ( )
inlinestatic

Definition at line 42 of file PeriodicBinFinderInPhi.h.

42 { return twoPiC;}

Member Data Documentation

template<class T>
constexpr T PeriodicBinFinderInPhi< T >::piC = 3.141592653589793238
staticprivate

Definition at line 46 of file PeriodicBinFinderInPhi.h.

Referenced by PeriodicBinFinderInPhi< float >::pi().

template<class T>
T PeriodicBinFinderInPhi< T >::theInvPhiStep =0
private

Definition at line 53 of file PeriodicBinFinderInPhi.h.

Referenced by PeriodicBinFinderInPhi< float >::binIndex().

template<class T>
int PeriodicBinFinderInPhi< T >::theNbins =0
private

Definition at line 51 of file PeriodicBinFinderInPhi.h.

Referenced by PeriodicBinFinderInPhi< float >::binIndex().

template<class T>
T PeriodicBinFinderInPhi< T >::thePhiOffset =0
private
template<class T>
T PeriodicBinFinderInPhi< T >::thePhiStep =0
private
template<class T>
constexpr T PeriodicBinFinderInPhi< T >::twoPiC = 2*piC
staticprivate