Geant4 Cross Reference |
1 // 2 // ******************************************************************** 3 // * License and Disclaimer * 4 // * * 5 // * The Geant4 software is copyright of the Copyright Holders of * 6 // * the Geant4 Collaboration. It is provided under the terms and * 7 // * conditions of the Geant4 Software License, included in the file * 8 // * LICENSE and available at http://cern.ch/geant4/license . These * 9 // * include a list of copyright holders. * 10 // * * 11 // * Neither the authors of this software system, nor their employing * 12 // * institutes,nor the agencies providing financial support for this * 13 // * work make any representation or warranty, express or implied, * 14 // * regarding this software system or assume any liability for its * 15 // * use. Please see the license in the file LICENSE and URL above * 16 // * for the full disclaimer and the limitation of liability. * 17 // * * 18 // * This code implementation is the result of the scientific and * 19 // * technical work of the GEANT4 collaboration. * 20 // * By using, copying, modifying or distributing the software (or * 21 // * any work based on the software) you agree to acknowledge its * 22 // * use in resulting scientific publications, and indicate your * 23 // * acceptance of all terms of the Geant4 Software license. * 24 // ******************************************************************** 25 // 26 // G4VDivisionParameterisation 27 // 28 // Class description: 29 // 30 // Base class for parameterisations defining divisions of volumes 31 // for different kind of CSG and specific solids. 32 33 // 09.05.01 - P.Arce, Initial version 34 // 08.04.04 - I.Hrivnacova, Implemented reflection 35 // 21.04.10 - M.Asai, Added gaps 36 //--------------------------------------------------------------------- 37 #ifndef G4VDIVISIONPARAMETERISATION_HH 38 #define G4VDIVISIONPARAMETERISATION_HH 1 39 40 #include "G4Types.hh" 41 #include "geomdefs.hh" 42 #include "G4VPVParameterisation.hh" 43 #include "G4RotationMatrix.hh" 44 45 enum DivisionType { DivNDIVandWIDTH, DivNDIV, DivWIDTH }; 46 47 class G4VPhysicalVolume; 48 class G4VSolid; 49 50 class G4VDivisionParameterisation : public G4VPVParameterisation 51 { 52 public: // with description 53 54 G4VDivisionParameterisation( EAxis axis, G4int nDiv, G4double width, 55 G4double offset, DivisionType divType, 56 G4VSolid* motherSolid = nullptr); 57 ~G4VDivisionParameterisation() override; 58 59 G4VSolid* ComputeSolid(const G4int, G4VPhysicalVolume*) override; 60 61 void ComputeTransformation(const G4int copyNo, 62 G4VPhysicalVolume *physVol) const override = 0; 63 64 inline const G4String& GetType() const; 65 inline EAxis GetAxis() const; 66 inline G4int GetNoDiv() const; 67 inline G4double GetWidth() const; 68 inline G4double GetOffset() const; 69 inline G4VSolid* GetMotherSolid() const; 70 inline void SetType(const G4String& type); 71 inline G4int VolumeFirstCopyNo() const; 72 inline void SetHalfGap(G4double hg); 73 inline G4double GetHalfGap() const; 74 75 protected: // with description 76 77 void ChangeRotMatrix( G4VPhysicalVolume* physVol, 78 G4double rotZ = 0.0 ) const; 79 80 G4int CalculateNDiv( G4double motherDim, G4double width, 81 G4double offset ) const; 82 G4double CalculateWidth( G4double motherDim, G4int nDiv, 83 G4double offset ) const; 84 85 virtual void CheckParametersValidity(); 86 void CheckOffset( G4double maxPar ); 87 void CheckNDivAndWidth( G4double maxPar ); 88 virtual G4double GetMaxParameter() const = 0; 89 G4double OffsetZ() const; 90 91 protected: 92 93 G4String ftype; 94 EAxis faxis; 95 G4int fnDiv = 0; 96 G4double fwidth = 0.0; 97 G4double foffset = 0.0; 98 DivisionType fDivisionType; 99 G4VSolid* fmotherSolid = nullptr; 100 G4bool fReflectedSolid = false; 101 G4bool fDeleteSolid = false; 102 103 static G4ThreadLocal G4RotationMatrix* fRot; 104 105 static const G4int verbose; 106 G4int theVoluFirstCopyNo = 1; 107 108 G4double kCarTolerance; 109 110 G4double fhgap = 0.0; 111 }; 112 113 #include "G4VDivisionParameterisation.icc" 114 115 #endif 116