Geant4.10
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Public Member Functions
FCALCryostatVolumes Class Reference

#include <FCALCryostatVolumes.hh>

Public Member Functions

 FCALCryostatVolumes ()
 
 ~FCALCryostatVolumes ()
 
G4LogicalVolumeConstruct ()
 

Detailed Description

Definition at line 45 of file FCALCryostatVolumes.hh.

Constructor & Destructor Documentation

FCALCryostatVolumes::FCALCryostatVolumes ( )

Definition at line 59 of file FCALCryostatVolumes.cc.

60 {
61 #include "FCALCryostatVolumesParameters.input"
62 }
FCALCryostatVolumes::~FCALCryostatVolumes ( )

Definition at line 64 of file FCALCryostatVolumes.cc.

64 {;}

Member Function Documentation

G4LogicalVolume * FCALCryostatVolumes::Construct ( void  )

Definition at line 66 of file FCALCryostatVolumes.cc.

References FCALEMModule::Construct(), FCALHadModule::Construct(), FCALMaterialConsultant::construct(), G4VisAttributes::Invisible, FCALMaterialConsultant::Material(), CLHEP::HepRotation::rotateZ(), and G4LogicalVolume::SetVisAttributes().

Referenced by FCALTestbeamSetup::Construct().

67 {
68 
69  //-----------------------------
70  // construction of materials
71  //-----------------------------
72 
73  FCALMaterialConsultant * FCALMaterials = new FCALMaterialConsultant();
74 
75  FCALMaterials->construct();
76 
77 
78 //-----------------------------------------
79 // G4VisAttributes * ColorOfIron = new G4VisAttributes(G4Colour(0.3,0.3,0.3));
80  G4VisAttributes * ColorOfLead = new G4VisAttributes(G4Colour(0.5,0.5,0.5));
81  G4VisAttributes * ColorOfAir = new G4VisAttributes(G4Colour(1.,1.,1.));
82 // G4VisAttributes * ColorOfLarg = new G4VisAttributes(G4Colour(1.0, 1.0, 0.0));
83 
84 
85  //-----------------------------
86  // Cryostat
87  //-----------------------------
88  G4Tubs * SolidCryostat =
89  new G4Tubs("CryostatSolid", CryostatRMin, CryostatRMax, CryostatLenght,
90  StartingPhi, DPhi);
91  G4LogicalVolume * LogicalCryostat =
92  new G4LogicalVolume(SolidCryostat,FCALMaterials->Material("Iron"),
93  "CryostatLogical");
94 
95  // LogicalCryostat->SetVisAttributes(ColorOfIron);
97 
98 
99  //------------------------------
100  // Insulation
101  //------------------------------
102  G4Tubs * SolidInsulation =
103  new G4Tubs("InsulationSolid", InsulationRMin, InsulationRMax,
104  InsulationLenght, StartingPhi, DPhi);
105  G4LogicalVolume * LogicalInsulation =
106  new G4LogicalVolume(SolidInsulation, FCALMaterials->Material("Air"),
107  "InsulationLogical");
108 // G4VPhysicalVolume * PhysicalInsulation =
109  new G4PVPlacement(0, G4ThreeVector(), LogicalInsulation, "InsulationPhysical",
110  LogicalCryostat, 0, 0);
111 
112  LogicalInsulation->SetVisAttributes(ColorOfAir);
113  // LogicalInsulation->SetVisAttributes(G4VisAttributes::Invisible);
114 
115 
116  //-------------------------------------
117  // Air to replace Iron inside Cryostat
118  //-------------------------------------
119  /*
120  G4Tubs * SolidAirCryostat =
121  new G4Tubs("AirCryostatSolid", CryostatRMin, LArgRMax, CryostatLength,
122  StartingPhi, DPhi);
123  G4LogicalVolume * LogicalAirCryostat =
124  new G4LogicalVolume(SolidAirCryostat, FCALMaterials->Material("Air"),
125  "AirCryostatLogical");
126  G4VPhysicalVolume * PhysicalAirCryostat =
127  new G4PVPlacement(0, 0, LogicalAirCryostat, "AirCryostatPhysical",
128  LogicalCryostat, 0, 0);
129 
130  LogicalAirCryostat->SetVisAttributes(ColorOfAir);
131  // LogicalAirCryostat->SetVisAttributes(G4VisAttributes::Invisible);
132  */
133 
134 
135  //--------------------
136  // Liquid Argon
137  //--------------------
138  G4Tubs * SolidLArg =
139  new G4Tubs("LArgSolid", LArgRMin, LArgRMax, LArgLenght,StartingPhi,DPhi);
140  G4LogicalVolume * LogicalLArg =
141  new G4LogicalVolume(SolidLArg, FCALMaterials->Material("LiquidArgon"),
142  "LArgLogical");
143  G4VPhysicalVolume * PhysicalLArg =
144  new G4PVPlacement(0,G4ThreeVector(LArgPosX, LArgPosY, LArgPosZ),
145  LogicalLArg, "LArgPhysical", LogicalCryostat, 0,0);
146 
147  // LogicalLArg->SetVisAttributes(ColorOfLarg);
149 
150  //-------------------
151  // Front Excluder
152  //-------------------
153  G4Box * SolidFrontExcluder =
154  new G4Box("FrontExcluderSolid", FrontExcluderSizeX, FrontExcluderSizeY,
155  FrontExcluderSizeZ);
156  G4LogicalVolume * LogicalFrontExcluder =
157  new G4LogicalVolume(SolidFrontExcluder, FCALMaterials->Material("Air")
158  , "FrontExcluderLogical");
159 
160 // G4VPhysicalVolume * PhysicalFrontExcluder =
161  new G4PVPlacement(0,G4ThreeVector(FrontExcluderPosX, FrontExcluderPosY,
162  FrontExcluderPosZ), "FrontExcluderPhysical",
163  LogicalFrontExcluder, PhysicalLArg, 0,0);
164 
165  LogicalFrontExcluder->SetVisAttributes(ColorOfLead);
166  // LogicalFrontExcluder->SetVisAttributes(G4VisAttributes::Invisible);
167 
168 
169  //--------------------
170  // Back Excluder
171  //--------------------
172  G4Trd * SolidBackExcluder =
173  new G4Trd("BackExcluderSolid", BackExcluderSize1X, BackExcluderSize2X,
174  BackExcluderSize1Y, BackExcluderSize2Y, BackExcluderSizeZ);
175  G4LogicalVolume * LogicalBackExcluder =
176  new G4LogicalVolume(SolidBackExcluder, FCALMaterials->Material("Air"),
177  "BackExcluderLogical");
178 
179  G4RotationMatrix * BackExcluderRotationMatrix = new G4RotationMatrix();
180  BackExcluderRotationMatrix->rotateX(BackExcluderRotX);
181 
182 // G4VPhysicalVolume * PhysicalBackExcluder =
183  new G4PVPlacement(BackExcluderRotationMatrix,
184  G4ThreeVector(BackExcluderPosX, BackExcluderPosY,
185  BackExcluderPosZ), "BackExcluder", LogicalBackExcluder,
186  PhysicalLArg, 0,0);
187 
188  LogicalBackExcluder->SetVisAttributes(ColorOfLead);
189  // LogicalBackExcluder->SetVisAttributes(G4VisAttributes::Invisible);
190 
191 
192  //------------------------
193  // fcal envelope
194  //------------------------
195  G4Tubs * SolidFCALEnvelope =
196  new G4Tubs("FCALEnvelopeSolid", FCALEnvelopeRMin, FCALEnvelopeRMax,
197  FCALEnvelopeLenght, FCALEnvelopeStartPhi, FCALEnvelopeDPhi);
198 
199  G4LogicalVolume * LogicalFCALEnvelope =
200  new G4LogicalVolume(SolidFCALEnvelope, FCALMaterials->Material("LiquidArgon"),
201  "FCALEnvelopeLogical");
202 
203  G4RotationMatrix * FCALRotationMatrix = new G4RotationMatrix();
204  FCALRotationMatrix->rotateX(FCALEnvelopeRotX);
205  // FCALRotationMatrix->rotateY(FCALEnvelopeRotY);
206 
207 // G4VPhysicalVolume * PhysicalFCALEnvelopp =
208  new G4PVPlacement(FCALRotationMatrix,
209  G4ThreeVector(FCALEnvelopePosX,FCALEnvelopePosY,FCALEnvelopePosZ)
210  , LogicalFCALEnvelope, "FCALEnvelopePhysical", LogicalLArg, 0,0);
211 
212  //LogicalFCALEnvelope->SetVisAttributes(ColorOfIron);
213  LogicalFCALEnvelope->SetVisAttributes(G4VisAttributes::Invisible);
214 
215  //-----------------------------
216  // FCAL electromagnetic Module
217  //-----------------------------
218  EmModule = new FCALEMModule();
219  G4LogicalVolume * LogicalFCALEmModule = EmModule->Construct();
220 
221  G4RotationMatrix * EmModuleRot = new G4RotationMatrix();
222  EmModuleRot->rotateZ(ModuleRotZ);
223 
224 // G4VPhysicalVolume * PhysicalFCALEmModule =
225  new G4PVPlacement(EmModuleRot,
226  G4ThreeVector(FCALEmModulePosX,FCALEmModulePosY,FCALEmModulePosZ),
227  LogicalFCALEmModule,"FCALEmModulePhysical",LogicalFCALEnvelope,0,0);
228 
229 
230  //-----------------------------
231  // hadronic fcal
232  //----------------------------
233  HadModule = new FCALHadModule();
234  G4LogicalVolume * LogicalFCALHadModule = HadModule->Construct();
235 
236  G4RotationMatrix * HadModuleRot = new G4RotationMatrix();
237  HadModuleRot->rotateZ(ModuleRotZ);
238 
239 // G4VPhysicalVolume * PhysicalFCALHadModule =
240  new G4PVPlacement(HadModuleRot,
241  G4ThreeVector(FCALHadModulePosX,FCALHadModulePosY,FCALHadModulePosZ),
242  LogicalFCALHadModule, "FCALHadModulePhysical",LogicalFCALEnvelope,0,0);
243 
244 
245 
246  //-------------------------
247  // Returning the mother
248  //-------------------------
249 
250  return LogicalCryostat;
251 
252 }
CLHEP::Hep3Vector G4ThreeVector
CLHEP::HepRotation G4RotationMatrix
Definition: G4Box.hh:63
static FCALMaterialConsultant * construct()
Definition: G4Tubs.hh:84
G4LogicalVolume * Construct()
Definition: G4Trd.hh:71
G4Material * Material(G4String)
G4LogicalVolume * Construct()
static const G4VisAttributes Invisible
HepRotation & rotateZ(double delta)
Definition: Rotation.cc:92
void SetVisAttributes(const G4VisAttributes *pVA)

The documentation for this class was generated from the following files: