ECCE @ EIC Software
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
doiPETDetectorConstruction.hh
Go to the documentation of this file. Or view the newest version in sPHENIX GitHub for file doiPETDetectorConstruction.hh
1 // ********************************************************************
2 // * License and Disclaimer *
3 // * *
4 // * The Geant4 software is copyright of the Copyright Holders of *
5 // * the Geant4 Collaboration. It is provided under the terms and *
6 // * conditions of the Geant4 Software License, included in the file *
7 // * LICENSE and available at http://cern.ch/geant4/license . These *
8 // * include a list of copyright holders. *
9 // * *
10 // * Neither the authors of this software system, nor their employing *
11 // * institutes,nor the agencies providing financial support for this *
12 // * work make any representation or warranty, express or implied, *
13 // * regarding this software system or assume any liability for its *
14 // * use. Please see the license in the file LICENSE and URL above *
15 // * for the full disclaimer and the limitation of liability. *
16 // * *
17 // * This code implementation is the result of the scientific and *
18 // * technical work of the GEANT4 collaboration. *
19 // * By using, copying, modifying or distributing the software (or *
20 // * any work based on the software) you agree to acknowledge its *
21 // * use in resulting scientific publications, and indicate your *
22 // * acceptance of all terms of the Geant4 Software license. *
23 // ********************************************************************
24 
25 //GEANT4 - Depth-of-Interaction enabled Positron emission tomography (PET) advanced example
26 
27 //Contributors
28 
29 // Abdella M. Ahmed (1, 2), Andrew Chacon (1, 2), Harley Rutherford (1, 2),
30 // Hideaki Tashima (3), Go Akamatsu (3), Akram Mohammadi (3), Eiji Yoshida (3), Taiga Yamaya (3)
31 // Susanna Guatelli (2), and Mitra Safavi-Naeini (1, 2)
32 
33 // (1) Australian Nuclear Science and Technology Organisation, Australia
34 // (2) University of Wollongong, Australia
35 // (3) National Institute of Radiological Sciences, Japan
36 
37 
38 
39 #ifndef doiPETDetectorConstruction_h
40 #define doiPETDetectorConstruction_h 1
41 
43 #include "globals.hh"
44 #include "G4UnitsTable.hh"
45 #include "G4Element.hh"
47 
48 class G4Material;
49 class G4VPhysicalVolume;
50 class G4LogicalVolume;
51 //
52 class doiPETAnalysis;
54 
59 
61 {
62 public:
65 
66 public:
67  virtual G4VPhysicalVolume* Construct();
68 
70  void ChangePhantom(G4String choice);
74 
75 
76 private:
77  void DefineMaterials();
80 
83  // G4LogicalVolume* gelatin_logicalV;
84  // G4VPhysicalVolume* gelatin_physicalV;
85 
86  //wolrd
89 
90  //detector block
93 
94  //air volume to fill the detector block
97 
98  //crystals
101 
102 
103  //water
106 
107  //lung
110 
111  //test line phantom
114 
117 
118  //cold regions
119  // G4LogicalVolume* coldRegion_logicalV;
120  // G4VPhysicalVolume* coldRegion_physicalV;
121 
122  //
123  //Surrounding PMMA for hot sphere
126 
127  //hot water phantom (activity is distributed)
130 
131  //surrounding PMMA cold sphere
134 
135  //cold Water phantom in the cold PMMA sphere
138 
139  //fillable polyethylene phantom for sensitivity
142 
143  //Image quality phantom for small animal NEMA NU-4
146 
149 
152 
153  //
156 
157  //
160 
161 
162  //Dimension of the sphere
169 
171 
172  //materials
178  // G4Material* inflatedLung;
181 
182  //elements for GSO
187 
189  //G4Material* phantomMaterial;
190 
193 
194 
195  //size of world
199 
200 
201  //The following is moved to doiPETGlobalParameters.hh
202  //G4int numberOfCrystal_DOI;
203  //G4int numberOfCrystal_tangential;
204  //G4int numberOfCrystal_axial;
205 
207  //G4double sizeOfCrystal_DOI;
208  //G4double sizeOfCrystal_tangential;
209  //G4double sizeOfCrystal_axial;
210 
212  //G4double crystalGap_DOI;
213  //G4double crystalGap_tangential;
214  //G4double crystalGap_axial;
215 
219 
220 
224 
225  //G4double AluminumCoverThickness;
226 
227 
228  //G4int numberOfPETDetector;
229  //G4int numberOfRings;
230 
231 
232  //G4double scannerRadius;
233  G4double thetaDetector; //The azimuthal angle for arranging the detector in the PET ring
234  //G4double ringGap;
236  // G4int AlCase_Index;
238 
239  //detector position
243 
244  //crystal position
248 
249 
250 
252 
253  //
256 
257  //Phantom dimension for rectangular box (placed for therapy study)
258  // G4double phantomSizeX, phantomSizeY, phantomSizeZ;
259 
260  //the following is to make the body phantom
263  G4double lengthOfBodyPhantom; //Interior length ( = 180m mm) + wallthickness (= 3mm)
267 
268  //Test phantom defnition. The phantom has the same as that that of NECR phantom except
271 
272  //To the cylindrical phantom to make the body phantom
276 
277 
278  //Image quality phantom for small animals
281 
285 
286  //Declare position for the rod phantoms
288 
289  //Declare position for cold region chanmbers
294 
295 
296 };
297 
299 
300 #endif