source: trunk/examples/advanced/human_phantom/src/G4MIRDPelvis.cc@ 1354

Last change on this file since 1354 was 807, checked in by garnier, 17 years ago

update

File size: 5.9 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// Authors: S. Guatelli and M. G. Pia, INFN Genova, Italy
27//
28// Based on code developed by the undergraduate student G. Guerrieri
29// Note: this is a preliminary beta-version of the code; an improved
30// version will be distributed in the next Geant4 public release, compliant
31// with the design in a forthcoming publication, and subject to a
32// design and code review.
33//
34#include "G4MIRDPelvis.hh"
35
36#include "globals.hh"
37#include "G4SDManager.hh"
38#include "G4VisAttributes.hh"
39#include "G4HumanPhantomMaterial.hh"
40#include "G4EllipticalTube.hh"
41#include "G4RotationMatrix.hh"
42#include "G4ThreeVector.hh"
43#include "G4VPhysicalVolume.hh"
44#include "G4PVPlacement.hh"
45#include "G4SubtractionSolid.hh"
46#include "G4Box.hh"
47#include "G4VSolid.hh"
48#include "G4LogicalVolume.hh"
49#include "G4HumanPhantomColour.hh"
50G4MIRDPelvis::G4MIRDPelvis()
51{
52}
53
54G4MIRDPelvis::~G4MIRDPelvis()
55{
56
57}
58
59G4VPhysicalVolume* G4MIRDPelvis::Construct(const G4String& volumeName,G4VPhysicalVolume* mother,
60 const G4String& colourName, G4bool wireFrame,G4bool sensitivity)
61{
62 G4HumanPhantomMaterial* material = new G4HumanPhantomMaterial();
63
64 G4cout << "Construct " << volumeName <<G4endl;
65
66 G4Material* skeleton = material -> GetMaterial("skeleton");
67
68 delete material;
69 /*
70 G4double dx= 10.35 * cm;//12. *cm; // a2
71 G4double dy= 11.76 * cm;//12. * cm; // b2
72 G4double dz= 9.915 * cm; // z2/2
73
74 G4VSolid* outPelvis = new G4EllipticalTube("OutPelvis",dx, dy, dz);
75
76 G4double dx_in = 9.75 * cm;//11.3 * cm; // a1
77 G4double dy_in = 11.07 *cm; //11.3* cm; //b1
78 G4double dz_in = 10. * cm;//11.0 *cm; // z2/2
79
80 */
81 G4double dx= 12. *cm; // a2
82 G4double dy= 12. * cm; //b2
83 G4double dz= 11. * cm; // z2/2
84
85 G4VSolid* outPelvis = new G4EllipticalTube("OutPelvis",dx, dy, dz);
86
87 dx = 11.3 * cm; // a1
88 dy = 11.3* cm; // b1
89 dz = 12.0 *cm; // z2/2
90
91 G4VSolid* inPelvis = new G4EllipticalTube("InPelvis",dx, dy, dz);
92
93 G4double x = 28. * cm; // a2 * 2
94 G4double y = 28. * cm; //b2*2
95 G4double z = 24. *cm; // z2
96
97 G4VSolid* subPelvis = new G4Box("SubtrPelvis", x/2., y/2., z/2.);
98
99
100
101 G4SubtractionSolid* firstPelvis = new G4SubtractionSolid("FirstPelvis",
102 outPelvis,
103 inPelvis, 0, G4ThreeVector(0.*cm, -0.8 *cm, 0. * cm));
104
105
106 G4SubtractionSolid* secondPelvis = new G4SubtractionSolid("SecondPelvis",
107 firstPelvis,
108 subPelvis, 0,
109 G4ThreeVector(0.0,
110 -14. * cm, 0.*cm));
111 // half of the y size of the box
112
113
114 G4SubtractionSolid* pelvis = new G4SubtractionSolid("Pelvis", secondPelvis, subPelvis,
115 0,
116 G4ThreeVector(0.0,
117 22. * cm, -9. *cm));
118
119
120 G4LogicalVolume* logicPelvis = new G4LogicalVolume(pelvis, skeleton,
121 "logical" + volumeName, 0, 0, 0);
122
123
124 G4VPhysicalVolume* physPelvis = new G4PVPlacement(0,G4ThreeVector(0.0, -3. * cm,-24. * cm),// 0, y02, z position
125 // with respect to the trunk
126 "physicalPelvis",
127 logicPelvis,
128 mother,
129 false,
130 0, true);
131
132 // Sensitive Body Part
133 if (sensitivity==true)
134 {
135 G4SDManager* SDman = G4SDManager::GetSDMpointer();
136 logicPelvis->SetSensitiveDetector( SDman->FindSensitiveDetector("BodyPartSD") );
137 }
138
139 // Visualization Attributes
140 // G4VisAttributes* PelvisVisAtt = new G4VisAttributes(G4Colour(0.46,0.53,0.6));
141
142 G4HumanPhantomColour* colourPointer = new G4HumanPhantomColour();
143 G4Colour colour = colourPointer -> GetColour(colourName);
144 G4VisAttributes* PelvisVisAtt = new G4VisAttributes(colour);
145 PelvisVisAtt->SetForceSolid(wireFrame);
146 logicPelvis->SetVisAttributes(PelvisVisAtt);
147
148 G4cout << "Pelvis created !!!!!!" << G4endl;
149
150 // Testing Pelvis Volume
151 G4double PelvisVol = logicPelvis->GetSolid()->GetCubicVolume();
152 G4cout << "Volume of Pelvis = " << PelvisVol/cm3 << " cm^3" << G4endl;
153
154 // Testing Pelvis Material
155 G4String PelvisMat = logicPelvis->GetMaterial()->GetName();
156 G4cout << "Material of Pelvis = " << PelvisMat << G4endl;
157
158 // Testing Density
159 G4double PelvisDensity = logicPelvis->GetMaterial()->GetDensity();
160 G4cout << "Density of Material = " << PelvisDensity*cm3/g << " g/cm^3" << G4endl;
161
162 // Testing Mass
163 G4double PelvisMass = (PelvisVol)*PelvisDensity;
164 G4cout << "Mass of Pelvis = " << PelvisMass/gram << " g" << G4endl;
165
166
167 return physPelvis;
168}
Note: See TracBrowser for help on using the repository browser.