source: trunk/examples/extended/runAndEvent/RE03/src/RE03DetectorConstruction.cc @ 1314

Last change on this file since 1314 was 1230, checked in by garnier, 14 years ago

update to geant4.9.3

File size: 4.5 KB
Line 
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// $Id: RE03DetectorConstruction.cc,v 1.1 2007/11/13 19:55:43 asaim Exp $
28// GEANT4 tag $Name: geant4-09-03-cand-01 $
29//
30//
31
32#include "RE03DetectorConstruction.hh"
33
34#include "G4Material.hh"
35#include "G4Box.hh"
36#include "G4LogicalVolume.hh"
37#include "G4PVPlacement.hh"
38
39#include "G4VisAttributes.hh"
40#include "G4Colour.hh"
41
42#include "G4SDManager.hh"
43#include "G4MultiFunctionalDetector.hh"
44#include "G4VPrimitiveScorer.hh"
45#include "G4PSEnergyDeposit.hh"
46#include "G4PSTrackLength.hh"
47#include "G4PSNofStep.hh"
48#include "G4SDParticleFilter.hh"
49
50#include "G4ios.hh"
51
52RE03DetectorConstruction::RE03DetectorConstruction()
53:constructed(false)
54{;}
55
56RE03DetectorConstruction::~RE03DetectorConstruction()
57{;}
58
59G4VPhysicalVolume* RE03DetectorConstruction::Construct()
60{
61  if(!constructed)
62  { 
63    constructed = true;
64    DefineMaterials();
65    SetupGeometry();
66  }
67  return worldPhys;
68}
69
70void RE03DetectorConstruction::DefineMaterials()
71{ 
72  G4String name, symbol;             //a=mass of a mole;
73  G4double a, z, density;            //z=mean number of protons; 
74
75  G4int ncomponents, natoms;
76  G4double fractionmass;
77
78  //
79  // define Elements
80  //
81
82  a = 1.01*g/mole;
83  G4Element* H  = new G4Element(name="Hydrogen",symbol="H" , z= 1., a);
84
85  a = 14.01*g/mole;
86  G4Element* N  = new G4Element(name="Nitrogen",symbol="N" , z= 7., a);
87
88  a = 16.00*g/mole;
89  G4Element* O  = new G4Element(name="Oxygen"  ,symbol="O" , z= 8., a);
90
91  //
92  // define a material from elements.   case 1: chemical molecule
93  //
94 
95  density = 1.000*g/cm3;
96  water = new G4Material(name="Water", density, ncomponents=2);
97  water->AddElement(H, natoms=2);
98  water->AddElement(O, natoms=1);
99
100  //
101  // define a material from elements.   case 2: mixture by fractional mass
102  //
103
104  density = 1.290*mg/cm3;
105  air = new G4Material(name="Air"  , density, ncomponents=2);
106  air->AddElement(N, fractionmass=0.7);
107  air->AddElement(O, fractionmass=0.3);
108}
109
110void RE03DetectorConstruction::SetupGeometry()
111{
112  //     
113  // World
114  //
115  G4VSolid* worldSolid = new G4Box("World",2.*m,2.*m,2.*m);
116  G4LogicalVolume* worldLogical = new G4LogicalVolume(worldSolid,air,"World");
117  worldPhys = new G4PVPlacement(0,G4ThreeVector(),worldLogical,"World",
118                        0,false,0);
119 
120  //                               
121  // Phantom
122  // 
123  G4VSolid* phantomSolid = new G4Box("Calor",1.*m,1.*m,1.*m);
124  G4LogicalVolume* phantomLogical = new G4LogicalVolume(phantomSolid,water,"Phantom");
125  phantomPhys = new G4PVPlacement(0,G4ThreeVector(),phantomLogical,"Phantom",
126                         worldLogical,false,0);
127  //                                       
128  // Visualization attributes
129  //
130//  worldLogical->SetVisAttributes(G4VisAttributes::Invisible);
131  G4VisAttributes* simpleBoxVisAtt= new G4VisAttributes(G4Colour(1.0,1.0,1.0));
132  simpleBoxVisAtt->SetVisibility(true);
133  phantomLogical->SetVisAttributes(simpleBoxVisAtt);
134}
135
136
Note: See TracBrowser for help on using the repository browser.