DD4hep  1.30.0
Detector Description Toolkit for High Energy Physics
GridRPhiEta.h
Go to the documentation of this file.
1 //==========================================================================
2 // AIDA Detector description implementation
3 //--------------------------------------------------------------------------
4 // Copyright (C) Organisation europeenne pour la Recherche nucleaire (CERN)
5 // All rights reserved.
6 //
7 // For the licensing terms see $DD4hepINSTALL/LICENSE.
8 // For the list of contributors see $DD4hepINSTALL/doc/CREDITS.
9 //
10 // \author A. Zaborowska
11 // \date 2016-10-18
12 // \version 1.0
13 //
14 //==========================================================================
15 #ifndef DD4HEP_GRIDRPHIETA_H
16 #define DD4HEP_GRIDRPHIETA_H 1
17 
18 // Framework includes
19 #include <DD4hep/Segmentations.h>
21 
23 namespace dd4hep {
24 
27 
29 
48  class GridRPhiEta : public GridRPhiEtaHandle {
49  public:
51  GridRPhiEta() = default;
53  GridRPhiEta(const GridRPhiEta& e) = default;
59  template <typename Q>
60  GridRPhiEta(const Handle<Q>& e) : Handle<Object>(e) {}
62  GridRPhiEta& operator=(const GridRPhiEta& seg) = default;
64  bool operator==(const GridRPhiEta& seg) const { return m_element == seg.m_element; }
66  inline Position position(const CellID& id) const { return Position(access()->implementation->position(id)); }
67 
69  inline dd4hep::CellID cellID(const Position& local, const Position& global, const VolumeID& volID) const {
70  return access()->implementation->cellID(local, global, volID);
71  }
72 
74  inline double gridSizeEta() const { return access()->implementation->gridSizeEta(); }
75 
77  inline int phiBins() const { return access()->implementation->phiBins(); }
78 
80  inline double gridSizeR() const { return access()->implementation->gridSizeR(); }
81 
83  inline double offsetR() const { return access()->implementation->offsetR(); }
84 
86  inline double offsetEta() const { return access()->implementation->offsetEta(); }
87 
89  inline double offsetPhi() const { return access()->implementation->offsetPhi(); }
90 
92  inline void setOffsetEta(double offset) const { access()->implementation->setOffsetEta(offset); }
93 
95  inline void setOffsetR(double offset) const { access()->implementation->setOffsetR(offset); }
96 
98  inline void setOffsetPhi(double offset) const { access()->implementation->setOffsetPhi(offset); }
99 
101  inline void setGridSizeEta(double cellSize) const { access()->implementation->setGridSizeEta(cellSize); }
102 
104  inline void setGridSizeR(double cellSize) const { access()->implementation->setGridSizeR(cellSize); }
105 
107  inline void setPhiBins(int cellSize) const { access()->implementation->setPhiBins(cellSize); }
108 
110  inline const std::string& fieldNameR() const { return access()->implementation->fieldNameR(); }
111 
113  inline const std::string& fieldNameEta() const { return access()->implementation->fieldNameEta(); }
114 
116  inline const std::string& fieldNamePhi() const { return access()->implementation->fieldNamePhi(); }
117 
128  inline std::vector<double> cellDimensions(const CellID& /*id*/) const {
129  return {access()->implementation->gridSizeR(),
130  access()->implementation->gridSizePhi(),
131  access()->implementation->gridSizeEta()};
132  }
133  };
134 } /* End namespace dd4hep */
135 #endif // DD4HEP_GRIDRPHIETA_H
Segmentations.h
dd4hep::GridRPhiEta::offsetEta
double offsetEta() const
access the coordinate offset in Eta
Definition: GridRPhiEta.h:86
dd4hep::GridRPhiEta::operator==
bool operator==(const GridRPhiEta &seg) const
Equality operator.
Definition: GridRPhiEta.h:64
dd4hep::Handle::Object
T Object
Extern accessible definition of the contained element type.
Definition: Handle.h:88
dd4hep::GridRPhiEta::setGridSizeEta
void setGridSizeEta(double cellSize) const
set the grid size in Eta
Definition: GridRPhiEta.h:101
dd4hep::GridRPhiEta::GridRPhiEta
GridRPhiEta()=default
Default constructor.
dd4hep::GridRPhiEta::fieldNamePhi
const std::string & fieldNamePhi() const
access the field name used for Phi
Definition: GridRPhiEta.h:116
dd4hep::GridRPhiEta::setOffsetEta
void setOffsetEta(double offset) const
set the coordinate offset in R
Definition: GridRPhiEta.h:92
dd4hep::Handle
Handle: a templated class like a shared pointer, which allows specialized access to tgeometry objects...
Definition: Handle.h:84
dd4hep::GridRPhiEta::setPhiBins
void setPhiBins(int cellSize) const
set the grid size in Phi
Definition: GridRPhiEta.h:107
dd4hep::GridRPhiEta::GridRPhiEta
GridRPhiEta(const Handle< Q > &e)
Copy constructor from other polymorph/equivalent handle.
Definition: GridRPhiEta.h:60
dd4hep::GridRPhiEta::GridRPhiEta
GridRPhiEta(const GridRPhiEta &e)=default
Copy constructor.
dd4hep::GridRPhiEta::gridSizeEta
double gridSizeEta() const
access the grid size in Eta
Definition: GridRPhiEta.h:74
dd4hep::GridRPhiEta::GridRPhiEta
GridRPhiEta(const Handle< Object > &e)
Copy constructor from handle.
Definition: GridRPhiEta.h:57
dd4hep::GridRPhiEta::position
Position position(const CellID &id) const
determine the position based on the cell ID
Definition: GridRPhiEta.h:66
dd4hep::GridRPhiEta::setGridSizeR
void setGridSizeR(double cellSize) const
set the grid size in R
Definition: GridRPhiEta.h:104
dd4hep::GridRPhiEtaHandle
Handle< SegmentationWrapper< DDSegmentation::GridRPhiEta > > GridRPhiEtaHandle
We need some abbreviation to make the code more readable.
Definition: GridRPhiEta.h:26
dd4hep::GridRPhiEta::gridSizeR
double gridSizeR() const
access the grid size in Phi
Definition: GridRPhiEta.h:80
dd4hep::GridRPhiEta
Implementation class for the grid phi-eta segmentation.
Definition: GridRPhiEta.h:48
dd4hep::GridRPhiEta::phiBins
int phiBins() const
access the grid size in Phi
Definition: GridRPhiEta.h:77
dd4hep::GridRPhiEta::setOffsetPhi
void setOffsetPhi(double offset) const
set the coordinate offset in Phi
Definition: GridRPhiEta.h:98
dd4hep::GridRPhiEta::cellID
dd4hep::CellID cellID(const Position &local, const Position &global, const VolumeID &volID) const
determine the cell ID based on the position
Definition: GridRPhiEta.h:69
dd4hep::GridRPhiEta::offsetPhi
double offsetPhi() const
access the coordinate offset in Phi
Definition: GridRPhiEta.h:89
dd4hep::Handle::m_element
T * m_element
Single and only data member: Reference to the actual element.
Definition: Handle.h:93
dd4hep::GridRPhiEta::operator=
GridRPhiEta & operator=(const GridRPhiEta &seg)=default
Assignment operator.
dd4hep::Position
ROOT::Math::XYZVector Position
Definition: Objects.h:81
GridRPhiEta.h
VolumeID
dd4hep::DDSegmentation::VolumeID VolumeID
Definition: SegmentationDictionary.h:50
dd4hep::GridRPhiEta::fieldNameEta
const std::string & fieldNameEta() const
access the field name used for Eta
Definition: GridRPhiEta.h:113
dd4hep::Handle::access
T * access() const
Checked object access. Throws invalid handle runtime exception if invalid handle.
dd4hep::GridRPhiEta::GridRPhiEta
GridRPhiEta(const Segmentation &e)
Copy Constructor from segmentation base object.
Definition: GridRPhiEta.h:55
dd4hep
Namespace for the AIDA detector description toolkit.
Definition: AlignmentsCalib.h:28
dd4hep::GridRPhiEta::offsetR
double offsetR() const
access the coordinate offset in R
Definition: GridRPhiEta.h:83
dd4hep::GridRPhiEta::fieldNameR
const std::string & fieldNameR() const
access the field name used for R
Definition: GridRPhiEta.h:110
dd4hep::GridRPhiEta::setOffsetR
void setOffsetR(double offset) const
set the coordinate offset in Phi
Definition: GridRPhiEta.h:95
dd4hep::Segmentation
Handle class supporting generic Segmentations of sensitive detectors.
Definition: Segmentations.h:41
dd4hep::GridRPhiEta::cellDimensions
std::vector< double > cellDimensions(const CellID &) const
Returns a std::vector<double> of the cellDimensions of the given cell ID in natural order of dimensio...
Definition: GridRPhiEta.h:128
CellID
dd4hep::DDSegmentation::CellID CellID
Definition: SegmentationDictionary.h:51