DD4hep  1.30.0
Detector Description Toolkit for High Energy Physics
Public Member Functions | Protected Attributes | List of all members
dd4hep::DDSegmentation::CylindricalGridPhiZ Class Reference

Segmentation base class describing cylindrical grid segmentation in the Phi-Z cylinder. More...

#include <CylindricalGridPhiZ.h>

Inheritance diagram for dd4hep::DDSegmentation::CylindricalGridPhiZ:
dd4hep::DDSegmentation::CylindricalSegmentation dd4hep::DDSegmentation::Segmentation

Public Member Functions

 CylindricalGridPhiZ (const std::string &cellEncoding)
 default constructor using an arbitrary type More...
 
 CylindricalGridPhiZ (const BitFieldCoder *decoder)
 Default constructor used by derived classes passing an existing decoder. More...
 
virtual ~CylindricalGridPhiZ ()
 destructor More...
 
virtual Vector3D position (const CellID &cellID) const
 determine the local based on the cell ID More...
 
virtual CellID cellID (const Vector3D &localPosition, const Vector3D &globalPosition, const VolumeID &volumeID) const
 determine the cell ID based on the position More...
 
double gridSizePhi () const
 access the grid size in phi More...
 
double gridSizeZ () const
 access the grid size in Z More...
 
double offsetPhi () const
 access the coordinate offset in phi More...
 
double offsetZ () const
 access the coordinate offset in Z More...
 
double radius () const
 access the radius More...
 
const std::string & fieldNamePhi () const
 access the field name used for phi More...
 
const std::string & fieldNameZ () const
 access the field name used for Z More...
 
void setGridSizePhi (double cellSize)
 set the grid size in phi More...
 
void setGridSizeZ (double cellSize)
 set the grid size in Z More...
 
void setOffsetPhi (double offset)
 set the coordinate offset in phi More...
 
void setOffsetZ (double offset)
 set the coordinate offset in Z More...
 
void setRadius (double radius)
 set the radius More...
 
void setFieldNamePhi (const std::string &fieldName)
 set the field name used for phi More...
 
void setFieldNameZ (const std::string &fieldName)
 set the field name used for Z More...
 
virtual std::vector< double > cellDimensions (const CellID &cellID) const
 Returns a vector<double> of the cellDimensions of the given cell ID in the following order: R*dPhi,dZ. More...
 
virtual void setDecoder (const BitFieldCoder *decoder)
 Set the underlying decoder (setting, inter alia, whether phi isSigned) More...
 
- Public Member Functions inherited from dd4hep::DDSegmentation::CylindricalSegmentation
virtual ~CylindricalSegmentation ()
 Destructor. More...
 
- Public Member Functions inherited from dd4hep::DDSegmentation::Segmentation
virtual ~Segmentation ()
 Destructor. More...
 
virtual void addSubsegmentation (long key_min, long key_max, Segmentation *entry)
 Add subsegmentation. Call only valid for Multi-segmentations. Default implementation throws an exception. More...
 
virtual VolumeID volumeID (const CellID &cellID) const
 Determine the volume ID from the full cell ID by removing all local fields. More...
 
virtual void neighbours (const CellID &cellID, std::set< CellID > &neighbours) const
 Calculates the neighbours of the given cell ID and adds them to the list of neighbours. More...
 
virtual std::string fieldDescription () const
 Access the encoding string. More...
 
virtual const std::string & name () const
 Access the segmentation name. More...
 
virtual void setName (const std::string &value)
 Set the segmentation name. More...
 
virtual const std::string & type () const
 Access the segmentation type. More...
 
virtual const std::string & description () const
 Access the description of the segmentation. More...
 
virtual const BitFieldCoderdecoder () const
 Access the underlying decoder. More...
 
virtual Parameter parameter (const std::string &parameterName) const
 Access to parameter by name. More...
 
virtual Parameters parameters () const
 Access to all parameters. More...
 
virtual void setParameters (const Parameters &parameters)
 Set all parameters from an existing set of parameters. More...
 
virtual bool cellsSpanVolumes () const
 

Protected Attributes

double _gridSizePhi
 the grid size in phi More...
 
double _offsetPhi
 the coordinate offset in phi More...
 
double _gridSizeZ
 the grid size in Z More...
 
double _offsetZ
 the coordinate offset in Z More...
 
double _radius
 the radius More...
 
std::string _phiId
 the field name used for phi More...
 
std::string _zId
 the field name used for Z More...
 
bool _phiIsSigned
 the isSigned attribute of the bitfield used for phi More...
 
- Protected Attributes inherited from dd4hep::DDSegmentation::Segmentation
std::string _name
 The segmentation name. More...
 
std::string _type
 The segmentation type. More...
 
std::string _description
 The description of the segmentation. More...
 
std::map< std::string, Parameter_parameters
 The parameters for this segmentation. More...
 
std::map< std::string, StringParameter_indexIdentifiers
 The indices used for the encoding. More...
 
const BitFieldCoder_decoder = 0
 The cell ID encoder and decoder. More...
 
bool _ownsDecoder = false
 Keeps track of the decoder ownership. More...
 

Additional Inherited Members

- Protected Member Functions inherited from dd4hep::DDSegmentation::CylindricalSegmentation
 CylindricalSegmentation (const std::string &cellEncoding)
 Default constructor using an arbitrary type. More...
 
 CylindricalSegmentation (const BitFieldCoder *decoder)
 Default constructor used by derived classes passing an existing decoder. More...
 
- Protected Member Functions inherited from dd4hep::DDSegmentation::Segmentation
 Segmentation (const std::string &cellEncoding="")
 Default constructor used by derived classes passing the encoding string. More...
 
 Segmentation (const BitFieldCoder *decoder)
 Default constructor used by derived classes passing an existing decoder. More...
 
template<typename TYPE >
void registerParameter (const std::string &nam, const std::string &desc, TYPE &param, const TYPE &defaultVal, UnitType unitTyp=SegmentationParameter::NoUnit, bool isOpt=false)
 Add a parameter to this segmentation. Used by derived classes to define their parameters. More...
 
void registerIdentifier (const std::string &nam, const std::string &desc, std::string &ident, const std::string &defaultVal)
 Add a cell identifier to this segmentation. Used by derived classes to define their required identifiers. More...
 
- Static Protected Member Functions inherited from dd4hep::DDSegmentation::Segmentation
static double binToPosition (FieldID bin, double cellSize, double offset=0.)
 Helper method to convert a bin number to a 1D position. More...
 
static int positionToBin (double position, double cellSize, double offset=0.)
 Helper method to convert a 1D position to a cell ID. More...
 
static double binToPosition (FieldID bin, std::vector< double > const &cellBoundaries, double offset=0.)
 Helper method to convert a bin number to a 1D position given a vector of binBoundaries. More...
 
static int positionToBin (double position, std::vector< double > const &cellBoundaries, double offset=0.)
 Helper method to convert a 1D position to a cell ID given a vector of binBoundaries. More...
 

Detailed Description

Segmentation base class describing cylindrical grid segmentation in the Phi-Z cylinder.

Definition at line 27 of file CylindricalGridPhiZ.h.

Constructor & Destructor Documentation

◆ CylindricalGridPhiZ() [1/2]

dd4hep::DDSegmentation::CylindricalGridPhiZ::CylindricalGridPhiZ ( const std::string &  cellEncoding)

default constructor using an arbitrary type

default constructor using an encoding string

Definition at line 27 of file CylindricalGridPhiZ.cpp.

◆ CylindricalGridPhiZ() [2/2]

dd4hep::DDSegmentation::CylindricalGridPhiZ::CylindricalGridPhiZ ( const BitFieldCoder decoder)

Default constructor used by derived classes passing an existing decoder.

Definition at line 44 of file CylindricalGridPhiZ.cpp.

◆ ~CylindricalGridPhiZ()

dd4hep::DDSegmentation::CylindricalGridPhiZ::~CylindricalGridPhiZ ( )
virtual

destructor

Definition at line 61 of file CylindricalGridPhiZ.cpp.

Member Function Documentation

◆ cellDimensions()

std::vector< double > dd4hep::DDSegmentation::CylindricalGridPhiZ::cellDimensions ( const CellID cellID) const
virtual

Returns a vector<double> of the cellDimensions of the given cell ID in the following order: R*dPhi,dZ.

Returns a vector of the cellDimensions of the given cell ID

Parameters
cellIDis ignored as all cells have the same dimension
Returns
std::vector<double> size 2:
  1. size in x = R * size in phi
  2. size in z

Reimplemented from dd4hep::DDSegmentation::Segmentation.

Definition at line 100 of file CylindricalGridPhiZ.cpp.

◆ cellID()

CellID dd4hep::DDSegmentation::CylindricalGridPhiZ::cellID ( const Vector3D localPosition,
const Vector3D globalPosition,
const VolumeID volumeID 
) const
virtual

determine the cell ID based on the position

Implements dd4hep::DDSegmentation::Segmentation.

Definition at line 87 of file CylindricalGridPhiZ.cpp.

◆ fieldNamePhi()

const std::string& dd4hep::DDSegmentation::CylindricalGridPhiZ::fieldNamePhi ( ) const
inline

access the field name used for phi

Definition at line 61 of file CylindricalGridPhiZ.h.

◆ fieldNameZ()

const std::string& dd4hep::DDSegmentation::CylindricalGridPhiZ::fieldNameZ ( ) const
inline

access the field name used for Z

Definition at line 65 of file CylindricalGridPhiZ.h.

◆ gridSizePhi()

double dd4hep::DDSegmentation::CylindricalGridPhiZ::gridSizePhi ( ) const
inline

access the grid size in phi

Definition at line 41 of file CylindricalGridPhiZ.h.

◆ gridSizeZ()

double dd4hep::DDSegmentation::CylindricalGridPhiZ::gridSizeZ ( ) const
inline

access the grid size in Z

Definition at line 45 of file CylindricalGridPhiZ.h.

◆ offsetPhi()

double dd4hep::DDSegmentation::CylindricalGridPhiZ::offsetPhi ( ) const
inline

access the coordinate offset in phi

Definition at line 49 of file CylindricalGridPhiZ.h.

◆ offsetZ()

double dd4hep::DDSegmentation::CylindricalGridPhiZ::offsetZ ( ) const
inline

access the coordinate offset in Z

Definition at line 53 of file CylindricalGridPhiZ.h.

◆ position()

Vector3D dd4hep::DDSegmentation::CylindricalGridPhiZ::position ( const CellID cellID) const
virtual

determine the local based on the cell ID

determine the position based on the cell ID

Implements dd4hep::DDSegmentation::Segmentation.

Definition at line 73 of file CylindricalGridPhiZ.cpp.

◆ radius()

double dd4hep::DDSegmentation::CylindricalGridPhiZ::radius ( ) const
inline

access the radius

Definition at line 57 of file CylindricalGridPhiZ.h.

◆ setDecoder()

void dd4hep::DDSegmentation::CylindricalGridPhiZ::setDecoder ( const BitFieldCoder decoder)
virtual

Set the underlying decoder (setting, inter alia, whether phi isSigned)

Set the underlying decoder and assign isSigned attribute to phi identifier.

Reimplemented from dd4hep::DDSegmentation::Segmentation.

Definition at line 66 of file CylindricalGridPhiZ.cpp.

◆ setFieldNamePhi()

void dd4hep::DDSegmentation::CylindricalGridPhiZ::setFieldNamePhi ( const std::string &  fieldName)
inline

set the field name used for phi

Definition at line 89 of file CylindricalGridPhiZ.h.

◆ setFieldNameZ()

void dd4hep::DDSegmentation::CylindricalGridPhiZ::setFieldNameZ ( const std::string &  fieldName)
inline

set the field name used for Z

Definition at line 93 of file CylindricalGridPhiZ.h.

◆ setGridSizePhi()

void dd4hep::DDSegmentation::CylindricalGridPhiZ::setGridSizePhi ( double  cellSize)
inline

set the grid size in phi

Definition at line 69 of file CylindricalGridPhiZ.h.

◆ setGridSizeZ()

void dd4hep::DDSegmentation::CylindricalGridPhiZ::setGridSizeZ ( double  cellSize)
inline

set the grid size in Z

Definition at line 73 of file CylindricalGridPhiZ.h.

◆ setOffsetPhi()

void dd4hep::DDSegmentation::CylindricalGridPhiZ::setOffsetPhi ( double  offset)
inline

set the coordinate offset in phi

Definition at line 77 of file CylindricalGridPhiZ.h.

◆ setOffsetZ()

void dd4hep::DDSegmentation::CylindricalGridPhiZ::setOffsetZ ( double  offset)
inline

set the coordinate offset in Z

Definition at line 81 of file CylindricalGridPhiZ.h.

◆ setRadius()

void dd4hep::DDSegmentation::CylindricalGridPhiZ::setRadius ( double  radius)
inline

set the radius

Definition at line 85 of file CylindricalGridPhiZ.h.

Member Data Documentation

◆ _gridSizePhi

double dd4hep::DDSegmentation::CylindricalGridPhiZ::_gridSizePhi
protected

the grid size in phi

Definition at line 112 of file CylindricalGridPhiZ.h.

◆ _gridSizeZ

double dd4hep::DDSegmentation::CylindricalGridPhiZ::_gridSizeZ
protected

the grid size in Z

Definition at line 116 of file CylindricalGridPhiZ.h.

◆ _offsetPhi

double dd4hep::DDSegmentation::CylindricalGridPhiZ::_offsetPhi
protected

the coordinate offset in phi

Definition at line 114 of file CylindricalGridPhiZ.h.

◆ _offsetZ

double dd4hep::DDSegmentation::CylindricalGridPhiZ::_offsetZ
protected

the coordinate offset in Z

Definition at line 118 of file CylindricalGridPhiZ.h.

◆ _phiId

std::string dd4hep::DDSegmentation::CylindricalGridPhiZ::_phiId
protected

the field name used for phi

Definition at line 122 of file CylindricalGridPhiZ.h.

◆ _phiIsSigned

bool dd4hep::DDSegmentation::CylindricalGridPhiZ::_phiIsSigned
protected

the isSigned attribute of the bitfield used for phi

Definition at line 126 of file CylindricalGridPhiZ.h.

◆ _radius

double dd4hep::DDSegmentation::CylindricalGridPhiZ::_radius
protected

the radius

Definition at line 120 of file CylindricalGridPhiZ.h.

◆ _zId

std::string dd4hep::DDSegmentation::CylindricalGridPhiZ::_zId
protected

the field name used for Z

Definition at line 124 of file CylindricalGridPhiZ.h.


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