source: trunk/examples/extended/field/field01/include/F01DetectorConstruction.hh

Last change on this file was 1337, checked in by garnier, 14 years ago

tag geant4.9.4 beta 1 + modifs locales

File size: 4.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//
27// $Id: F01DetectorConstruction.hh,v 1.7 2006/06/29 17:15:35 gunter Exp $
28// GEANT4 tag $Name: geant4-09-04-beta-01 $
29//
30//
31
32#ifndef F01DetectorConstruction_h
33#define F01DetectorConstruction_h 1
34
35#include "G4VUserDetectorConstruction.hh"
36#include "globals.hh"
37#include "G4ios.hh"
38
39class G4Box;
40class G4Tubs;
41class G4LogicalVolume;
42class G4VPhysicalVolume;
43class G4Material;
44class G4UniformMagField;
45class F01DetectorMessenger;
46class F01CalorimeterSD;
47class F01FieldSetup;
48
49
50class F01DetectorConstruction : public G4VUserDetectorConstruction
51{
52  public:
53 
54    F01DetectorConstruction();
55   ~F01DetectorConstruction();
56
57  public:
58     
59     void SetAbsorberMaterial (G4String);     
60     void SetAbsorberThickness(G4double);     
61     void SetAbsorberRadius(G4double);         
62     
63     void SetAbsorberZpos(G4double);
64
65     void SetWorldMaterial(G4String);
66     void SetWorldSizeZ(G4double);
67     void SetWorldSizeR(G4double);
68     
69     G4VPhysicalVolume* Construct();
70
71     void UpdateGeometry();
72     
73  public:
74 
75     void PrintCalorParameters(); 
76                   
77     G4Material* GetWorldMaterial()    {return WorldMaterial;};
78     G4double GetWorldSizeZ()          {return WorldSizeZ;}; 
79     G4double GetWorldSizeR()          {return WorldSizeR;};
80     
81     G4double GetAbsorberZpos()        {return zAbsorber;}; 
82     G4double GetzstartAbs()           {return zstartAbs;};
83     G4double GetzendAbs()             {return zendAbs;};
84
85     G4Material* GetAbsorberMaterial()  {return AbsorberMaterial;};
86     G4double    GetAbsorberThickness() {return AbsorberThickness;};     
87     G4double GetAbsorberRadius()       {return AbsorberRadius;};
88     
89     const G4VPhysicalVolume* GetphysiWorld() {return physiWorld;};           
90     const G4VPhysicalVolume* GetAbsorber()   {return physiAbsorber;};
91     G4LogicalVolume* GetLogicalAbsorber()    {return logicAbsorber;};
92                 
93  private:
94     
95     G4Tubs*            solidWorld;     // pointer to the solid World
96     G4LogicalVolume*   logicWorld;     // pointer to the logical World
97     G4VPhysicalVolume* physiWorld;     // pointer to the physical World
98
99     G4Tubs*            solidAbsorber;  // pointer to the solid Absorber
100     G4LogicalVolume*   logicAbsorber;  // pointer to the logical Absorber
101     G4VPhysicalVolume* physiAbsorber;  // pointer to the physical Absorber
102     
103     F01FieldSetup*     fEmFieldSetup;     
104     F01DetectorMessenger* detectorMessenger;  // pointer to the Messenger
105     F01CalorimeterSD* calorimeterSD;   // pointer to the sensitive detector
106
107     G4Material*        AbsorberMaterial;
108     G4double           AbsorberThickness;
109     G4double           AbsorberRadius;
110     G4bool             worldchanged;
111
112     G4double           zAbsorber ;
113     G4double           zstartAbs , zendAbs ;
114     
115     G4Material*        WorldMaterial;
116     G4double           WorldSizeR;
117     G4double           WorldSizeZ;
118
119  private:
120   
121     void DefineMaterials();
122     void ComputeCalorParameters();
123     G4VPhysicalVolume* ConstructCalorimeter();     
124};
125
126//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
127
128inline void F01DetectorConstruction::ComputeCalorParameters()
129{
130  // Compute derived parameters of the calorimeter
131     
132     zstartAbs = zAbsorber-0.5*AbsorberThickness; 
133     zendAbs   = zAbsorber+0.5*AbsorberThickness; 
134
135}
136
137#endif
Note: See TracBrowser for help on using the repository browser.