Geant4 Cross Reference |
1 // 1 // 2 // ******************************************* 2 // ******************************************************************** 3 // * License and Disclaimer 3 // * License and Disclaimer * 4 // * 4 // * * 5 // * The Geant4 software is copyright of th 5 // * The Geant4 software is copyright of the Copyright Holders of * 6 // * the Geant4 Collaboration. It is provided 6 // * the Geant4 Collaboration. It is provided under the terms and * 7 // * conditions of the Geant4 Software License 7 // * conditions of the Geant4 Software License, included in the file * 8 // * LICENSE and available at http://cern.ch/ 8 // * LICENSE and available at http://cern.ch/geant4/license . These * 9 // * include a list of copyright holders. 9 // * include a list of copyright holders. * 10 // * 10 // * * 11 // * Neither the authors of this software syst 11 // * Neither the authors of this software system, nor their employing * 12 // * institutes,nor the agencies providing fin 12 // * institutes,nor the agencies providing financial support for this * 13 // * work make any representation or warran 13 // * work make any representation or warranty, express or implied, * 14 // * regarding this software system or assum 14 // * regarding this software system or assume any liability for its * 15 // * use. Please see the license in the file 15 // * use. Please see the license in the file LICENSE and URL above * 16 // * for the full disclaimer and the limitatio 16 // * for the full disclaimer and the limitation of liability. * 17 // * 17 // * * 18 // * This code implementation is the result 18 // * This code implementation is the result of the scientific and * 19 // * technical work of the GEANT4 collaboratio 19 // * technical work of the GEANT4 collaboration. * 20 // * By using, copying, modifying or distri 20 // * By using, copying, modifying or distributing the software (or * 21 // * any work based on the software) you ag 21 // * any work based on the software) you agree to acknowledge its * 22 // * use in resulting scientific publicati 22 // * use in resulting scientific publications, and indicate your * 23 // * acceptance of all terms of the Geant4 Sof 23 // * acceptance of all terms of the Geant4 Software license. * 24 // ******************************************* 24 // ******************************************************************** 25 // 25 // 26 // G4VoxelLimits << 26 // >> 27 // $Id$ >> 28 // >> 29 // class G4VoxelLimits 27 // 30 // 28 // Class description: 31 // Class description: 29 // 32 // 30 // Represents limitation/restrictions of space 33 // Represents limitation/restrictions of space, where restrictions 31 // are only made perpendicular to the cartesia 34 // are only made perpendicular to the cartesian axes. 32 // 35 // >> 36 // 33 // Member data: 37 // Member data: 34 // 38 // 35 // G4double fxAxisMin,fxAxisMax 39 // G4double fxAxisMin,fxAxisMax 36 // G4double fyAxisMin,fyAxisMax 40 // G4double fyAxisMin,fyAxisMax 37 // G4double fzAxisMin,fzAxisMax 41 // G4double fzAxisMin,fzAxisMax 38 // - The min and max values along each axis. + << 42 // - The min and max values along each axis. +-kInfinity if not restricted. >> 43 // >> 44 // >> 45 // Notes: >> 46 // >> 47 // Beware no break statements after returns in switch(pAxis)s. 39 48 40 // 13.07.95, P.Kent - Initial version. << 49 // History: >> 50 // 13.07.95 P.Kent Initial version. 41 // ------------------------------------------- 51 // -------------------------------------------------------------------- 42 #ifndef G4VOXELLIMITS_HH 52 #ifndef G4VOXELLIMITS_HH 43 #define G4VOXELLIMITS_HH 1 << 53 #define G4VOXELLIMITS_HH 44 54 45 #include "G4Types.hh" 55 #include "G4Types.hh" 46 #include "geomdefs.hh" 56 #include "geomdefs.hh" 47 57 48 #include "G4ThreeVector.hh" 58 #include "G4ThreeVector.hh" 49 59 50 #include <assert.h> 60 #include <assert.h> 51 61 52 class G4VoxelLimits 62 class G4VoxelLimits 53 { 63 { 54 public: << 64 public: // with description 55 65 56 G4VoxelLimits() = default; << 66 G4VoxelLimits(); 57 // Constructor - initialise to be unlimi 67 // Constructor - initialise to be unlimited. Volume unrestricted. 58 68 59 ~G4VoxelLimits() = default; << 69 ~G4VoxelLimits(); 60 // Destructor. No actions. 70 // Destructor. No actions. 61 71 62 void AddLimit(const EAxis pAxis, const G4d << 72 void AddLimit(const EAxis pAxis, const G4double pMin,const G4double pMax); 63 // Restrict the volume to between specif 73 // Restrict the volume to between specified min and max along the 64 // given axis. Cartesian axes only, pMin 74 // given axis. Cartesian axes only, pMin<=pMax. 65 75 66 G4double GetMaxXExtent() const; 76 G4double GetMaxXExtent() const; 67 // Return maximum x extent. 77 // Return maximum x extent. 68 G4double GetMaxYExtent() const; 78 G4double GetMaxYExtent() const; 69 // Return maximum y extent. 79 // Return maximum y extent. 70 G4double GetMaxZExtent() const; 80 G4double GetMaxZExtent() const; 71 // Return maximum z extent. 81 // Return maximum z extent. 72 82 73 G4double GetMinXExtent() const; 83 G4double GetMinXExtent() const; 74 // Return minimum x extent. 84 // Return minimum x extent. 75 G4double GetMinYExtent() const; 85 G4double GetMinYExtent() const; 76 // Return minimum y extent. 86 // Return minimum y extent. 77 G4double GetMinZExtent() const; 87 G4double GetMinZExtent() const; 78 // Return minimum z extent. 88 // Return minimum z extent. 79 89 80 G4double GetMaxExtent(const EAxis pAxis) c 90 G4double GetMaxExtent(const EAxis pAxis) const; 81 // Return maximum extent of volume along 91 // Return maximum extent of volume along specified axis. 82 G4double GetMinExtent(const EAxis pAxis) c 92 G4double GetMinExtent(const EAxis pAxis) const; 83 // Return minimum extent of volume along 93 // Return minimum extent of volume along specified axis. 84 94 85 G4bool IsXLimited() const; 95 G4bool IsXLimited() const; 86 // Return true if the x axis is limited. 96 // Return true if the x axis is limited. 87 G4bool IsYLimited() const; 97 G4bool IsYLimited() const; 88 // Return true if the y axis is limited. 98 // Return true if the y axis is limited. 89 G4bool IsZLimited() const; 99 G4bool IsZLimited() const; 90 // Return true if the z axis is limited. 100 // Return true if the z axis is limited. 91 101 92 G4bool IsLimited() const; 102 G4bool IsLimited() const; 93 // Return true if limited along any axis 103 // Return true if limited along any axis 94 G4bool IsLimited(const EAxis pAxis) const; 104 G4bool IsLimited(const EAxis pAxis) const; 95 // Return true if the specified axis is 105 // Return true if the specified axis is restricted/limited. 96 106 97 G4bool ClipToLimits(G4ThreeVector& pStart, << 107 G4bool ClipToLimits(G4ThreeVector& pStart,G4ThreeVector& pEnd) const; 98 // Clip the line segment pStart->pEnd to 108 // Clip the line segment pStart->pEnd to the volume described by the 99 // current limits. Return true if the li 109 // current limits. Return true if the line remains after clipping, 100 // else false, and leave the vectors in 110 // else false, and leave the vectors in an undefined state. 101 111 102 G4bool Inside(const G4ThreeVector& pVec) c 112 G4bool Inside(const G4ThreeVector& pVec) const; 103 // Return true if the specified vector i 113 // Return true if the specified vector is inside/on boundaries of limits. 104 114 105 G4int OutCode(const G4ThreeVector& pVec) c 115 G4int OutCode(const G4ThreeVector& pVec) const; 106 // Calculate the `outcode' for the speci 116 // Calculate the `outcode' for the specified vector. 107 // Intended for use during clipping agai 117 // Intended for use during clipping against the limits 108 // The bits are set given the following 118 // The bits are set given the following conditions: 109 // 0 pVec.x()<fxAxisMin && IsXLim 119 // 0 pVec.x()<fxAxisMin && IsXLimited() 110 // 1 pVec.x()>fxAxisMax && IsXLim 120 // 1 pVec.x()>fxAxisMax && IsXLimited() 111 // 2 pVec.y()<fyAxisMin && IsYLim 121 // 2 pVec.y()<fyAxisMin && IsYLimited() 112 // 3 pVec.y()>fyAxisMax && IsYLim 122 // 3 pVec.y()>fyAxisMax && IsYLimited() 113 // 4 pVec.z()<fzAxisMin && IsZLim 123 // 4 pVec.z()<fzAxisMin && IsZLimited() 114 // 5 pVec.z()>fzAxisMax && IsZLim 124 // 5 pVec.z()>fzAxisMax && IsZLimited() 115 125 116 private: 126 private: 117 127 118 G4double fxAxisMin = -kInfinity, fxAxisMax << 128 G4double fxAxisMin,fxAxisMax; 119 G4double fyAxisMin = -kInfinity, fyAxisMax << 129 G4double fyAxisMin,fyAxisMax; 120 G4double fzAxisMin = -kInfinity, fzAxisMax << 130 G4double fzAxisMin,fzAxisMax; 121 }; 131 }; 122 132 123 #include "G4VoxelLimits.icc" 133 #include "G4VoxelLimits.icc" 124 134 125 std::ostream& operator << (std::ostream& os, c 135 std::ostream& operator << (std::ostream& os, const G4VoxelLimits& pLim); 126 // Print the limits to the stream in the for 136 // Print the limits to the stream in the form: 127 // "{(xmin,xmax) (ymin,ymax) (zmin,zmax)}" 137 // "{(xmin,xmax) (ymin,ymax) (zmin,zmax)}" 128 // Replace (xmin,xmax) by (-,-) when not li 138 // Replace (xmin,xmax) by (-,-) when not limited. 129 139 130 #endif 140 #endif 131 141