Back to home page

EIC code displayed by LXR

 
 

    


File indexing completed on 2025-01-18 09:13:52

0001 //==========================================================================
0002 //  AIDA Detector description implementation 
0003 //--------------------------------------------------------------------------
0004 // Copyright (C) Organisation europeenne pour la Recherche nucleaire (CERN)
0005 // All rights reserved.
0006 //
0007 // For the licensing terms see $DD4hepINSTALL/LICENSE.
0008 // For the list of contributors see $DD4hepINSTALL/doc/CREDITS.
0009 //
0010 // Author     : M.Frank
0011 //
0012 //==========================================================================
0013 
0014 // Framework include files
0015 #include <DD4hep/CartesianGridXZ.h>
0016 #include <DDSegmentation/CartesianGridXZ.h>
0017 
0018 using namespace dd4hep;
0019 
0020 /// determine the position based on the cell ID
0021 Position CartesianGridXZ::position(const CellID& id) const   {
0022   return Position(access()->implementation->position(id));
0023 }
0024 
0025 /// determine the cell ID based on the position
0026 dd4hep::CellID CartesianGridXZ::cellID(const Position& local,
0027                                const Position& global,
0028                                const VolumeID& volID) const
0029 {
0030   return access()->implementation->cellID(local, global, volID);
0031 }
0032 
0033 /// access the grid size in X
0034 double CartesianGridXZ::gridSizeX() const {
0035   return access()->implementation->gridSizeX();
0036 }
0037 
0038 /// access the grid size in Z
0039 double CartesianGridXZ::gridSizeZ() const {
0040   return access()->implementation->gridSizeZ();
0041 }
0042 
0043 /// set the grid size in X
0044 void CartesianGridXZ::setGridSizeX(double cellSize) const   {
0045   access()->implementation->setGridSizeX(cellSize);
0046 }
0047 
0048 /// set the grid size in Z
0049 void CartesianGridXZ::setGridSizeZ(double cellSize) const   {
0050   access()->implementation->setGridSizeZ(cellSize);
0051 }
0052 
0053 /// access the coordinate offset in X
0054 double CartesianGridXZ::offsetX() const {
0055   return access()->implementation->offsetX();
0056 }
0057 
0058 /// access the coordinate offset in Z
0059 double CartesianGridXZ::offsetZ() const {
0060   return access()->implementation->offsetZ();
0061 }
0062 
0063 /// set the coordinate offset in X
0064 void CartesianGridXZ::setOffsetX(double offset) const   {
0065   access()->implementation->setOffsetX(offset);
0066 }
0067 
0068 /// set the coordinate offset in Z
0069 void CartesianGridXZ::setOffsetZ(double offset) const   {
0070   access()->implementation->setOffsetZ(offset);
0071 }
0072 
0073 /// access the field name used for X
0074 const std::string& CartesianGridXZ::fieldNameX() const {
0075   return access()->implementation->fieldNameX();
0076 }
0077 
0078 /// access the field name used for Z
0079 const std::string& CartesianGridXZ::fieldNameZ() const {
0080   return access()->implementation->fieldNameZ();
0081 }
0082 
0083 // Returns a vector<double> of the cellDimensions of the given cell ID
0084 std::vector<double> CartesianGridXZ::cellDimensions(const CellID& id) const  {
0085   return access()->implementation->cellDimensions(id);
0086 }