Geant4 Cross Reference |
1 // 1 2 // ******************************************* 3 // * License and Disclaimer 4 // * 5 // * The Geant4 software is copyright of th 6 // * the Geant4 Collaboration. It is provided 7 // * conditions of the Geant4 Software License 8 // * LICENSE and available at http://cern.ch/ 9 // * include a list of copyright holders. 10 // * 11 // * Neither the authors of this software syst 12 // * institutes,nor the agencies providing fin 13 // * work make any representation or warran 14 // * regarding this software system or assum 15 // * use. Please see the license in the file 16 // * for the full disclaimer and the limitatio 17 // * 18 // * This code implementation is the result 19 // * technical work of the GEANT4 collaboratio 20 // * By using, copying, modifying or distri 21 // * any work based on the software) you ag 22 // * use in resulting scientific publicati 23 // * acceptance of all terms of the Geant4 Sof 24 // ******************************************* 25 26 // =========================================== 27 // GEANT4 class header file 28 // 29 // Class: G4ExtDEDXTable 30 // 31 // Base class: G4VIonDEDXTable 32 // 33 // Author: Anton Lechner (Anton. 34 // 35 // First implementation: 29. 02. 2009 36 // 37 // Modifications: 38 // 03.11.2009 A. Lechner: Added new methods B 39 // to interface changes in base cla 40 // 41 // 42 // Class description: 43 // Utility class for users to add their own 44 // for ions. This class is dedicated for us 45 // of the low-energy electromagnetic packag 46 // 47 // Comments: 48 // 49 // =========================================== 50 51 #ifndef G4EXTDEDXTABLE_HH 52 #define G4EXTDEDXTABLE_HH 53 54 #include "G4VIonDEDXTable.hh" 55 #include "globals.hh" 56 57 #include <map> 58 #include <utility> 59 #include <vector> 60 61 class G4ExtDEDXTable : public G4VIonDEDXTable 62 { 63 public: 64 explicit G4ExtDEDXTable() = default; 65 ~G4ExtDEDXTable() override; 66 G4ExtDEDXTable(G4ExtDEDXTable&) = delete; 67 const G4ExtDEDXTable& operator=(const G4ExtD 68 69 G4bool BuildPhysicsVector(G4int ionZ, const 70 71 G4bool BuildPhysicsVector(G4int ionZ, G4int 72 73 // Function for checking the availability of 74 // for a given ion-material couple, where th 75 // a single element only. 76 G4bool IsApplicable(G4int atomicNumberIon, 77 G4int atomicNumberElem // Atomic number o 78 ) override; 79 80 // Function for checking the availability of 81 // for given ion-material couples. 82 G4bool IsApplicable(G4int atomicNumberIon, 83 const G4String& matIdentifier // Name or 84 ) override; 85 86 // Function returning the stopping power vec 87 // couples, where the material consists of a 88 G4PhysicsVector* GetPhysicsVector(G4int atom 89 G4int atomicNumberElem // Atomic number o 90 ) override; 91 92 // Function returning the stopping power vec 93 // couples. 94 G4PhysicsVector* GetPhysicsVector(G4int atom 95 const G4String& matIdenfier // Name or ch 96 ) override; 97 98 // Function returning the stopping power val 99 // couples, where the material consists of a 100 // given energy. 101 G4double GetDEDX(G4double kinEnergyPerNucleo 102 G4int atomicNumberIon, // Atomic number o 103 G4int atomicNumberElem // Atomic number o 104 ); 105 106 // Function returning the stopping power val 107 // couples and given energy. 108 G4double GetDEDX(G4double kinEnergyPerNucleo 109 G4int atomicNumberIon, // Atomic number o 110 const G4String& matIdenfier // Name or ch 111 ); 112 113 // Function for adding dE/dx vector for an e 114 // argument only applies to elemental materi 115 G4bool AddPhysicsVector(G4PhysicsVector* phy 116 G4int atomicNumberIon, // Atomic number o 117 const G4String& matIdenfier, // Name or c 118 G4int atomicNumberElem = 0 // Atomic numb 119 ); 120 121 // Function for removing dE/dx vector for a 122 G4bool RemovePhysicsVector(G4int atomicNumbe 123 const G4String& matIdentifier // Name or 124 ); 125 126 // Function writing all stopping power vecto 127 G4bool StorePhysicsTable(const G4String& fil 128 ); 129 130 // Function retrieving all stopping power ve 131 G4bool RetrievePhysicsTable(const G4String& 132 ); 133 134 // Function deleting all physics vectors and 135 void ClearTable(); 136 137 // Function printing the ion-material pairs 138 void DumpMap(); 139 140 private: 141 G4PhysicsVector* CreatePhysicsVector(G4int v 142 143 G4int FindAtomicNumberElement(G4PhysicsVecto 144 145 using G4IonDEDXKeyElem = std::pair<G4int, G4 146 using G4IonDEDXKeyMat = std::pair<G4int, G4S 147 148 using G4IonDEDXMapElem = std::map<G4IonDEDXK 149 using G4IonDEDXMapMat = std::map<G4IonDEDXKe 150 151 G4IonDEDXMapElem dedxMapElements; 152 G4IonDEDXMapMat dedxMapMaterials; 153 }; 154 155 #endif // G4EXTDEDXTABLE_HH 156