File indexing completed on 2026-04-08 07:53:35
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
0030
0031
0032
0033
0034
0035
0036
0037
0038
0039
0040
0041
0042
0043
0044
0045
0046 #ifndef DNADAMAGE2_DetectorConstruction_h
0047 #define DNADAMAGE2_DetectorConstruction_h 1
0048
0049 #include "PhysGeoImport.hh"
0050 #include "StackingAction.hh"
0051
0052 #include "G4MoleculeGun.hh"
0053 #include "G4Orb.hh"
0054 #include "G4UIcmdWithABool.hh"
0055 #include "G4UIcmdWithADoubleAndUnit.hh"
0056 #include "G4UIcmdWithAString.hh"
0057 #include "G4UIcmdWithAnInteger.hh"
0058 #include "G4UImessenger.hh"
0059 #include "G4VUserDetectorConstruction.hh"
0060
0061 class G4VPhysicalVolume;
0062 class G4LogicalVolume;
0063
0064
0065
0066 class DetectorConstruction : public G4VUserDetectorConstruction, public G4UImessenger
0067 {
0068 public:
0069 DetectorConstruction();
0070 ~DetectorConstruction() override;
0071 void SetNewValue(G4UIcommand*, G4String) override;
0072 void SetSize(G4double);
0073
0074 G4VPhysicalVolume* Construct() override;
0075 void ConstructSDandField() override;
0076 void ReadOffsetFile(G4String);
0077 void AddDNAInformation(G4int, G4ThreeVector);
0078 void SetStacking(StackingAction* stack) { fpStacking = stack; }
0079 StackingAction* GetStacking() { return fpStacking; }
0080
0081 std::vector<G4String> GetDNANames() { return fDNANames; }
0082 std::vector<G4ThreeVector> GetDNAPositions() { return fDNAPositions; }
0083 std::vector<std::vector<G4int>> GetDNADetails() { return fDNADetails; }
0084
0085 private:
0086 G4UIdirectory* fDetDir = nullptr;
0087 G4UIcmdWithAString* fpOffSetFileUI = nullptr;
0088 G4UIcmdWithAString* fpPlasmidFile = nullptr;
0089 G4UIcmdWithAnInteger* fpPlasmidNbUI = nullptr;
0090 G4UIcmdWithADoubleAndUnit* fSizeCmd = nullptr;
0091 G4UIcmdWithABool* fpUseDNA = nullptr;
0092
0093 G4Orb* fPlasmidEnvelope = nullptr;
0094 G4double fWorldSize = 1 * um;
0095
0096 G4int fNbOfPlasmids = 0;
0097 G4String fPlasmidFile = "VoxelStraight.fab2g4dna";
0098 G4bool fUseDNAVolumes = false;
0099 std::vector<G4ThreeVector> fVOffset;
0100
0101 std::vector<G4String> fDNANames;
0102 std::vector<G4ThreeVector> fDNAPositions;
0103 std::vector<std::vector<G4int>> fDNADetails;
0104
0105 std::vector<G4String> fSampleDNANames;
0106 std::vector<G4ThreeVector> fSampleDNAPositions;
0107 std::vector<std::vector<G4int>> fSampleDNADetails;
0108
0109 StackingAction* fpStacking = nullptr;
0110 };
0111
0112
0113
0114 #endif