source: trunk/examples/advanced/brachytherapy/src/BrachyMaterial.cc@ 1277

Last change on this file since 1277 was 1230, checked in by garnier, 16 years ago

update to geant4.9.3

File size: 7.3 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// Code developed by:
27// S.Guatelli
28//
29// *******************************
30// * *
31// * BrachyMaterial.cc *
32// * *
33// *******************************
34//
35// $Id: BrachyMaterial.cc,v 1.7 2006/06/29 15:48:33 gunter Exp $
36// GEANT4 tag $Name: geant4-09-03-cand-01 $
37//
38
39#include "G4MaterialPropertiesTable.hh"
40#include "G4MaterialPropertyVector.hh"
41#include "globals.hh"
42#include "G4MaterialTable.hh"
43#include "Randomize.hh"
44#include "G4RunManager.hh"
45#include "G4Element.hh"
46#include "G4ElementTable.hh"
47#include "BrachyMaterial.hh"
48
49BrachyMaterial::BrachyMaterial()
50{;}
51
52BrachyMaterial::~BrachyMaterial()
53{;}
54
55void BrachyMaterial::DefineMaterials()
56{
57 // Define required materials
58
59 G4double A; // atomic mass
60 G4double Z; // atomic number
61 G4double d; // density
62
63 // General elements
64
65 A = 1.01*g/mole;
66 G4Element* elH = new G4Element ("Hydrogen","H",Z = 1.,A);
67
68 A = 14.01*g/mole;
69 G4Element* elN = new G4Element("Nitrogen","N",Z = 7.,A);
70
71 A = 16.00*g/mole;
72
73 G4Element* elO = new G4Element("Oxygen","O",Z = 8.,A);
74
75 A=26.98*g/mole;
76 G4Element* elAl = new G4Element("Aluminum","Al", Z = 13.,A);
77
78 A = 12.011*g/mole;
79 G4Element* elC = new G4Element("Carbon","C",Z = 6.,A);
80
81 A = 22.99*g/mole;
82 G4Element* elNa = new G4Element("Sodium","Na",Z = 11.,A);
83
84 A = 24.305*g/mole;
85 G4Element* elMg = new G4Element("Magnesium","Mg",Z = 12.,A);
86
87 A = 30.974*g/mole;
88 G4Element* elP = new G4Element("Phosphorus","P",Z = 15.,A);
89
90 A = 32.06*g/mole;
91 G4Element* elS = new G4Element("Sulfur","S",Z = 16.,A);
92
93 A = 35.453*g/mole;
94 G4Element* elCl = new G4Element("Chlorine","Cl",Z = 17.,A);
95
96 A = 39.098*g/mole;
97 G4Element* elK = new G4Element("Potassium","K",Z = 19.,A);
98
99 A = 40.08*g/mole;
100 G4Element* elCa = new G4Element("Calcium","Ca",Z = 20.,A);
101
102 A = 65.38*g/mole;
103 G4Element* elZn = new G4Element("Zinc","Zn",Z = 30.,A);
104
105 A = 54.94*g/mole;
106 G4Element* elMn = new G4Element("Manganese","Mn",Z = 25.,A);
107
108 A = 28.09*g/mole;
109 G4Element* elSi = new G4Element("Silicon","Si",Z = 14.,A);
110
111 A = 52.00*g/mole;
112 G4Element* elCr = new G4Element("Chromium","Cr",Z = 24.,A);
113
114 A = 58.70*g/mole;
115 G4Element* elNi = new G4Element("Nickel","Ni",Z = 28.,A);
116
117 A = 55.85*g/mole;
118 G4Element* elFe = new G4Element("Iron","Fe",Z = 26.,A);
119
120 A = 183.84* g/mole;
121 d = 19.3*g/cm3;
122 matW = new G4Material("Tungsten",Z = 74.,A,d);
123
124 // Perspex, plexiglass, lucite
125 d = 1.19*g/cm3;
126 matplexiglass = new G4Material("Plexiglass",d,3);
127 matplexiglass->AddElement(elH,0.08);
128 matplexiglass->AddElement(elC,0.60);
129 matplexiglass->AddElement(elO,0.32);
130
131 // Lead material
132 A = 207.19*g/mole;
133 Z = 82;
134 d = 11.35*g/cm3;
135 matPb = new G4Material("Lead",Z,A,d);
136
137 // Iridium (Medical Physics, Vol 25, No 10, Oct 1998)
138 d = 22.42*g/cm3;
139 A = 191.96260*g/mole ;
140 Z = 77;
141 matir192 = new G4Material("Iridium",Z,A,d);
142
143 //titanium
144 A = 47.88*g/mole;
145 d = 4.50*g/cm3;
146 Titanium = new G4Material("titanium" ,Z = 22.,A,d);
147
148 // Air material
149 d = 1.290*mg/cm3;
150 G4Material* matAir = new G4Material("Air",d,2);
151 matAir->AddElement(elN,0.7);
152 matAir->AddElement(elO,0.3);
153
154 // Water
155 d = 1.000*g/cm3;
156 matH2O = new G4Material("Water",d,2);
157 matH2O->AddElement(elH,2);
158 matH2O->AddElement(elO,1);
159 matH2O->GetIonisation()->SetMeanExcitationEnergy(75.0*eV);
160
161
162 //soft tissue(http://www.nist.gov)
163 d = 1.0*g/cm3;
164 soft = new G4Material("tissue",d,13);
165 soft->AddElement(elH,0.104472);
166 soft->AddElement(elC,0.23219);
167 soft->AddElement(elN,0.02488);
168 soft->AddElement(elO,0.630238);
169 soft->AddElement(elNa,0.00113);
170 soft->AddElement(elMg,0.00013);
171 soft->AddElement(elP,0.00133);
172 soft->AddElement(elS,0.00199);
173 soft->AddElement(elCl,0.00134);
174 soft->AddElement(elK,0.00199);
175 soft->AddElement(elCa,0.00023);
176 soft->AddElement(elFe,0.00005);
177 soft->AddElement(elZn,0.00003);
178
179 // Stainless steel (Medical Physics, Vol 25, No 10, Oct 1998)
180 d = 8.02*g/cm3 ;
181 matsteel = new G4Material("Stainless steel",d,5);
182 matsteel->AddElement(elMn, 0.02);
183 matsteel->AddElement(elSi, 0.01);
184 matsteel->AddElement(elCr, 0.19);
185 matsteel->AddElement(elNi, 0.10);
186 matsteel->AddElement(elFe, 0.68);
187
188 //gold(chimica degli elementi N.N Greenwood,A.Earnshaw)
189 A = 196.97*g/mole;
190 d = 19.32*g/cm3;
191 gold = new G4Material("gold",Z = 79.,A,d);
192
193 //IodiumCore(chimica degli elementi N.N Greenwood,A.Earnshaw)
194 A = 124.9*g/mole;
195 d = 4.862*g/cm3;
196 matI = new G4Material("Iodium",Z = 53.,A,d);
197
198 //ceramic(Medical Physics, May 2000)
199 d = 2.88*g/cm3;
200 ceramic = new G4Material("allumina",d,2);
201 ceramic->AddElement(elAl,2);
202 ceramic->AddElement(elO,3);
203
204 G4double density = universe_mean_density;
205 G4double pressure = 3.e-18*pascal;
206 G4double temperature = 2.73*kelvin;
207 A=1.01*g/mole;
208 Vacuum = new G4Material("Galactic", Z = 1., A,
209 density,kStateGas,temperature,pressure);
210
211 //compact bone (http://www.NIST.gov)
212 d = 1.85*g/cm3;
213 bone = new G4Material("bone",d,8);
214 bone->AddElement(elH,0.063984);
215 bone->AddElement(elC,0.278);
216 bone->AddElement(elN,0.027);
217 bone->AddElement(elO,0.410016);
218 bone->AddElement(elMg,0.002);
219 bone->AddElement(elP,0.07);
220 bone->AddElement(elS,0.002);
221 bone->AddElement(elCa,0.147);
222
223 //muscle(http://www.NIST.gov)
224 muscle = new G4Material("muscle",d,9);
225 muscle->AddElement(elH,0.101997);
226 muscle->AddElement(elC,0.123);
227 muscle->AddElement(elN,0.035);
228 muscle->AddElement(elNa,0.0008);
229 muscle->AddElement(elO,0.729);
230 muscle->AddElement(elMg,0.0002);
231 muscle->AddElement(elP,0.002);
232 muscle->AddElement(elS,0.005);
233 muscle->AddElement(elK,0.003);
234}
235
236G4Material* BrachyMaterial::GetMat(G4String material)
237{
238 // Returns a material
239 G4Material* pttoMaterial = G4Material::GetMaterial(material);
240 return pttoMaterial;
241}
Note: See TracBrowser for help on using the repository browser.