File indexing completed on 2026-04-07 07:51:53
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024
0025
0026
0027
0028
0029 #ifndef DetectorConstruction_h
0030 #define DetectorConstruction_h 1
0031
0032 #include "G4Cache.hh"
0033 #include "G4VUserDetectorConstruction.hh"
0034 #include "globals.hh"
0035
0036 class G4Box;
0037 class G4LogicalVolume;
0038 class G4VPhysicalVolume;
0039 class G4Material;
0040 class DetectorMessenger;
0041
0042 class G4GlobalMagFieldMessenger;
0043
0044 const G4int kMaxAbsor = 10;
0045
0046
0047
0048 class DetectorConstruction : public G4VUserDetectorConstruction
0049 {
0050 public:
0051 DetectorConstruction();
0052 ~DetectorConstruction() override;
0053
0054 public:
0055 void SetNbOfAbsor(G4int);
0056 void SetAbsorMaterial(G4int, const G4String&);
0057 void SetAbsorThickness(G4int, G4double);
0058
0059 void SetWorldMaterial(const G4String&);
0060 void SetCalorSizeYZ(G4double);
0061 void SetNbOfLayers(G4int);
0062
0063 G4VPhysicalVolume* Construct() override;
0064 void ConstructSDandField() override;
0065
0066 public:
0067 void PrintCalorParameters();
0068
0069 G4double GetWorldSizeX() const { return fWorldSizeX; };
0070 G4double GetWorldSizeYZ() const { return fWorldSizeYZ; };
0071
0072 G4double GetCalorThickness() const { return fCalorThickness; };
0073 G4double GetCalorSizeYZ() const { return fCalorSizeYZ; };
0074
0075 G4int GetNbOfLayers() const { return fNbOfLayers; };
0076
0077 G4int GetNbOfAbsor() const { return fNbOfAbsor; };
0078 G4double GetAbsorThickness(G4int i) const { return fAbsorThickness[i]; };
0079 const G4Material* GetAbsorMaterial(G4int i) const { return fAbsorMaterial[i]; };
0080
0081 const G4VPhysicalVolume* GetphysiWorld() const { return fPhysiWorld; };
0082 const G4Material* GetWorldMaterial() const { return fWorldMaterial; };
0083 const G4VPhysicalVolume* GetAbsorber(G4int i) const { return fPhysiAbsor[i]; };
0084
0085 private:
0086 void DefineMaterials();
0087 void ComputeCalorParameters();
0088
0089 G4int fNbOfAbsor = 0;
0090 G4Material* fAbsorMaterial[kMaxAbsor];
0091 G4double fAbsorThickness[kMaxAbsor];
0092
0093 G4int fNbOfLayers = 0;
0094 G4double fLayerThickness = 0.;
0095
0096 G4double fCalorSizeYZ = 0.;
0097 G4double fCalorThickness = 0.;
0098
0099 G4Material* fWorldMaterial = nullptr;
0100 G4double fWorldSizeYZ = 0.;
0101 G4double fWorldSizeX = 0.;
0102
0103 G4Box* fSolidWorld = nullptr;
0104 G4LogicalVolume* fLogicWorld = nullptr;
0105 G4VPhysicalVolume* fPhysiWorld = nullptr;
0106
0107 G4Box* fSolidCalor = nullptr;
0108 G4LogicalVolume* fLogicCalor = nullptr;
0109 G4VPhysicalVolume* fPhysiCalor = nullptr;
0110
0111 G4Box* fSolidLayer = nullptr;
0112 G4LogicalVolume* fLogicLayer = nullptr;
0113 G4VPhysicalVolume* fPhysiLayer = nullptr;
0114
0115 G4Box* fSolidAbsor[kMaxAbsor];
0116 G4LogicalVolume* fLogicAbsor[kMaxAbsor];
0117 G4VPhysicalVolume* fPhysiAbsor[kMaxAbsor];
0118
0119 DetectorMessenger* fDetectorMessenger = nullptr;
0120 G4Cache<G4GlobalMagFieldMessenger*> fFieldMessenger = nullptr;
0121 };
0122
0123
0124
0125 #endif