Geant4  9.6.p02
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
RemSimMoonHabitat.cc
Go to the documentation of this file.
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 //
27 // **************************************
28 // * *
29 // * RemSimMoonHabitat.cc *
30 // * *
31 // **************************************
32 //
33 // $Id$
34 //
35 // Author:Susanna Guatelli, guatelli@ge.infn.it
36 //
37 #include "RemSimMoonHabitat.hh"
38 #include "RemSimMaterial.hh"
39 
40 #include "G4SystemOfUnits.hh"
41 #include "G4Material.hh"
42 #include "G4Box.hh"
43 #include "G4Trd.hh"
44 #include "G4LogicalVolume.hh"
45 #include "G4VPhysicalVolume.hh"
46 #include "G4PVPlacement.hh"
47 #include "G4VisAttributes.hh"
48 #include "G4UserLimits.hh"
49 #include "RemSimDecorator.hh"
51 #include "G4SubtractionSolid.hh"
52 
54 {
55  pMaterial = new RemSimMaterial();
56  moonPhys = 0;
57 }
59 {
60  delete pMaterial;
61 }
63 {
64  pMaterial -> DefineMaterials();
65 
66  G4Material* moonMaterial = pMaterial->GetMaterial("moon");
67 
68  // Moon Surface definition
69  G4double sizeX = 30.*m;
70  G4double sizeY = 30.*m;
71  G4double sizeZ = 15.*m;
72 
73  G4Box* moon = new G4Box("moon",sizeX,sizeY,sizeZ);
74 
75  G4double thick = 4.5 *m;
76  G4Box* shelter = new G4Box("shelter",5.*m,5.*m,thick/2.);
77 
78  G4ThreeVector translation(0, 0, -sizeZ + 0.5 * m + thick/2.);
79  G4SubtractionSolid* solid = new G4SubtractionSolid ("moon-shelter", moon,
80  shelter, 0, translation);
81 
82  G4LogicalVolume* moonLogical = new G4LogicalVolume(solid,
83  moonMaterial,
84  "moon",0,0,0);
85 
86  moonPhys = new G4PVPlacement(0,
87  G4ThreeVector(0.,0.,sizeZ), "moon",moonLogical,
88  motherVolume,
89  false,0);
90 
91  G4Colour red (1.0,0.0,0.0);
92 
93  G4VisAttributes* moonVisAtt = new G4VisAttributes(red);
94  moonVisAtt -> SetVisibility(true);
95  moonVisAtt -> SetForceWireframe(true);
96  moonLogical -> SetVisAttributes(moonVisAtt);
97 }
98 
100 {}
101