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

Last change on this file since 1333 was 807, checked in by garnier, 16 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.