Back to home page

EIC code displayed by LXR

 
 

    


File indexing completed on 2025-09-17 08:59:25

0001 //
0002 // ********************************************************************
0003 // * License and Disclaimer                                           *
0004 // *                                                                  *
0005 // * The  Geant4 software  is  copyright of the Copyright Holders  of *
0006 // * the Geant4 Collaboration.  It is provided  under  the terms  and *
0007 // * conditions of the Geant4 Software License,  included in the file *
0008 // * LICENSE and available at  http://cern.ch/geant4/license .  These *
0009 // * include a list of copyright holders.                             *
0010 // *                                                                  *
0011 // * Neither the authors of this software system, nor their employing *
0012 // * institutes,nor the agencies providing financial support for this *
0013 // * work  make  any representation or  warranty, express or implied, *
0014 // * regarding  this  software system or assume any liability for its *
0015 // * use.  Please see the license in the file  LICENSE  and URL above *
0016 // * for the full disclaimer and the limitation of liability.         *
0017 // *                                                                  *
0018 // * This  code  implementation is the result of  the  scientific and *
0019 // * technical work of the GEANT4 collaboration.                      *
0020 // * By using,  copying,  modifying or  distributing the software (or *
0021 // * any work based  on the software)  you  agree  to acknowledge its *
0022 // * use  in  resulting  scientific  publications,  and indicate your *
0023 // * acceptance of all terms of the Geant4 Software license.          *
0024 // ********************************************************************
0025 //
0026 // G4SmartVoxelNode inline implementation
0027 //
0028 // --------------------------------------------------------------------
0029 
0030 
0031 // --------------------------------------------------------------------
0032 inline
0033 G4int G4SmartVoxelNode::GetVolume(G4int pVolumeNo) const
0034 {
0035   return fcontents[pVolumeNo];
0036 }
0037 
0038 // --------------------------------------------------------------------
0039 inline
0040 void G4SmartVoxelNode::Insert(G4int pVolumeNo)
0041 {
0042   fcontents.push_back(pVolumeNo);
0043 }
0044 
0045 // --------------------------------------------------------------------
0046 inline
0047 std::size_t G4SmartVoxelNode::GetNoContained() const
0048 {
0049   return fcontents.size();
0050 }
0051 
0052 // --------------------------------------------------------------------
0053 inline
0054 std::size_t G4SmartVoxelNode::GetCapacity() const
0055 {
0056   return fcontents.capacity();
0057 }
0058 
0059 // --------------------------------------------------------------------
0060 inline
0061 void G4SmartVoxelNode::Reserve(G4int noSlices)
0062 {
0063   fcontents.reserve(noSlices);
0064 }
0065 
0066 // --------------------------------------------------------------------
0067 inline
0068 void G4SmartVoxelNode::Shrink()
0069 {
0070   G4SliceVector(fcontents).swap(fcontents);
0071 }
0072 
0073 // --------------------------------------------------------------------
0074 inline
0075 G4int G4SmartVoxelNode::GetMaxEquivalentSliceNo() const
0076 {
0077   return fmaxEquivalent;
0078 }
0079 
0080 // --------------------------------------------------------------------
0081 inline
0082 void G4SmartVoxelNode::SetMaxEquivalentSliceNo(G4int pMax)
0083 {
0084   fmaxEquivalent = pMax;
0085 }
0086 
0087 // --------------------------------------------------------------------
0088 inline
0089 G4int G4SmartVoxelNode::GetMinEquivalentSliceNo() const
0090 {
0091   return fminEquivalent;
0092 }
0093 
0094 // --------------------------------------------------------------------
0095 inline
0096 void G4SmartVoxelNode::SetMinEquivalentSliceNo(G4int pMin)
0097 {
0098   fminEquivalent = pMin;
0099 }