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/CartesianGridXY.h>
0016 #include <DDSegmentation/CartesianGridXY.h>
0017 
0018 using namespace dd4hep;
0019 
0020 /// determine the position based on the cell ID
0021 Position CartesianGridXY::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 CartesianGridXY::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 CartesianGridXY::gridSizeX() const {
0035   return access()->implementation->gridSizeX();
0036 }
0037 
0038 /// access the grid size in Y
0039 double CartesianGridXY::gridSizeY() const {
0040   return access()->implementation->gridSizeY();
0041 }
0042 
0043 /// set the grid size in X
0044 void CartesianGridXY::setGridSizeX(double cellSize) const   {
0045   access()->implementation->setGridSizeX(cellSize);
0046 }
0047 
0048 /// set the grid size in Y
0049 void CartesianGridXY::setGridSizeY(double cellSize) const   {
0050   access()->implementation->setGridSizeY(cellSize);
0051 }
0052 
0053 /// access the coordinate offset in X
0054 double CartesianGridXY::offsetX() const {
0055   return access()->implementation->offsetX();
0056 }
0057 
0058 /// access the coordinate offset in Y
0059 double CartesianGridXY::offsetY() const {
0060   return access()->implementation->offsetY();
0061 }
0062 
0063 /// set the coordinate offset in X
0064 void CartesianGridXY::setOffsetX(double offset) const   {
0065   access()->implementation->setOffsetX(offset);
0066 }
0067 
0068 /// set the coordinate offset in Y
0069 void CartesianGridXY::setOffsetY(double offset) const   {
0070   access()->implementation->setOffsetY(offset);
0071 }
0072 
0073 /// access the field name used for X
0074 const std::string& CartesianGridXY::fieldNameX() const {
0075   return access()->implementation->fieldNameX();
0076 }
0077 
0078 /// access the field name used for Y
0079 const std::string& CartesianGridXY::fieldNameY() const {
0080   return access()->implementation->fieldNameY();
0081 }
0082 
0083 // Returns a vector<double> of the cellDimensions of the given cell ID
0084 std::vector<double> CartesianGridXY::cellDimensions(const CellID& id) const  {
0085   return access()->implementation->cellDimensions(id);
0086 }