Geant4 11.1.1
Toolkit for the simulation of the passage of particles through matter
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
G4ElectronIonPair.cc
Go to the documentation of this file.
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// -------------------------------------------------------------------
28//
29// GEANT4 Class file
30//
31//
32// File name: G4ElectronIonPair
33//
34// Author: Vladimir Ivanchenko
35//
36// Creation date: 08.07.2008
37//
38// Modifications:
39//
40// -------------------------------------------------------------
41
42//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
43//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
44
45#include "G4ElectronIonPair.hh"
46#include "G4SystemOfUnits.hh"
47#include "G4Material.hh"
48#include "G4MaterialTable.hh"
49#include "G4StepPoint.hh"
50#include "G4VProcess.hh"
51#include "G4ProcessType.hh"
52#include "G4Track.hh"
53#include "Randomize.hh"
54
55//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
56
58{
59 verbose = verb;
60 curMaterial = nullptr;
61 curMeanEnergy = 0.0;
62 nMaterials = 0;
63 invFanoFactor = 1.0/0.2;
64 Initialise();
65}
66
67//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
68
70
71//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
72
74 const G4ParticleDefinition* part,
75 const G4Material* material,
76 G4double edep,
77 G4double niel)
78{
79 G4double nion = 0.0;
80
81 // NIEL does not provide ionisation clusters
82 if(edep > niel) {
83
84 // neutral particles do not produce ionisation along step
85 if(part->GetPDGCharge() != 0.0) {
86
87 // select material
88 if(material != curMaterial) {
89 curMaterial = material;
90 curMeanEnergy = material->GetIonisation()->GetMeanEnergyPerIonPair();
91
92 // if mean energy is not defined then look into G4 DB
93 if(0.0 == curMeanEnergy) {
94 curMeanEnergy = FindG4MeanEnergyPerIonPair(material);
95 }
96 }
97 if(curMeanEnergy > 0.0) { nion = (edep - niel)/curMeanEnergy; }
98 }
99 }
100 return nion;
101}
102
103//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
104
105std::vector<G4ThreeVector>*
107{
108 std::vector<G4ThreeVector>* v = nullptr;
109
111
112 // sample ionisation along step
113 if(nion > 0) {
114
115 v = new std::vector<G4ThreeVector>;
116 G4ThreeVector prePos = step->GetPreStepPoint()->GetPosition();
117 G4ThreeVector deltaPos = step->GetPostStepPoint()->GetPosition() - prePos;
118 for(G4int i=0; i<nion; ++i) {
119 v->push_back( prePos + deltaPos*G4UniformRand() );
120 }
121 if(verbose > 1 ) {
122 G4cout << "### G4ElectronIonPair::SampleIonisationPoints: "
123 << v->size() << " ion pairs are added" << G4endl;
124 }
125 }
126 return v;
127}
128
129//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
130
131G4int
133 const G4TrackVector*,
134 G4int subType) const
135{
136 G4int nholes = 0;
137
138 if(2 == subType || 12 == subType || 13 == subType) { nholes = 1; }
139 return nholes;
140}
141
142//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
143
146{
147 G4String name = mat->GetName();
148 G4double res = 0.0;
149
150 // is this material in the vector?
151 for(G4int j=0; j<nMaterials; ++j) {
152 if(name == g4MatNames[j]) {
153 res = g4MatData[j];
155 if(verbose > 0) {
156 G4cout << "### G4ElectronIonPair::FindG4MeanEnergyPerIonPair for "
157 << name << " Epair= " << res/eV << " eV is set"
158 << G4endl;
159 }
160 break;
161 }
162 }
163 return res;
164}
165
166//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
167
169{
170 std::size_t nmat = G4Material::GetNumberOfMaterials();
172 if(nmat > 0) {
173 G4cout << "### G4ElectronIonPair: mean energy per ion pair available:"
174 << G4endl;
175 for(std::size_t i=0; i<nmat; ++i) {
176 const G4Material* mat = (*mtable)[i];
178 if(x > 0.0) {
179 G4cout << " " << mat->GetName() << " Epair= "
180 << x/eV << " eV" << G4endl;
181 }
182 }
183 }
184}
185
186//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
187
189{
190 if(nMaterials > 0) {
191 G4cout << "### G4ElectronIonPair: mean energy per ion pair "
192 << " for Geant4 materials" << G4endl;
193 for(G4int i=0; i<nMaterials; ++i) {
194 G4cout << " " << g4MatNames[i] << " Epair= "
195 << g4MatData[i]/eV << " eV" << G4endl;
196 }
197 }
198}
199
200//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
201
202void G4ElectronIonPair::Initialise()
203{
204 // ICRU Report 31, 1979
205 g4MatNames.push_back("G4_Si");
206 g4MatData.push_back(3.62*eV);
207
208 g4MatNames.push_back("G4_Ge");
209 g4MatData.push_back(2.97*eV);
210
211 g4MatNames.push_back("G4_He");
212 g4MatData.push_back(44.4*eV);
213
214 g4MatNames.push_back("G4_N");
215 g4MatData.push_back(36.4*eV);
216
217 g4MatNames.push_back("G4_O");
218 g4MatData.push_back(32.3*eV);
219
220 g4MatNames.push_back("G4_Ne");
221 g4MatData.push_back(36.8*eV);
222
223 g4MatNames.push_back("G4_Ar");
224 g4MatData.push_back(26.34*eV);
225
226 g4MatNames.push_back("G4_Kr");
227 g4MatData.push_back(24.1*eV);
228
229 g4MatNames.push_back("G4_Xe");
230 g4MatData.push_back(21.6*eV);
231
232 g4MatNames.push_back("G4_lAr");
233 g4MatData.push_back(23.6*eV);
234
235 g4MatNames.push_back("G4_lKr");
236 g4MatData.push_back(20.5*eV);
237
238 g4MatNames.push_back("G4_lXe");
239 g4MatData.push_back(15.6*eV);
240
241 g4MatNames.push_back("G4_AIR");
242 g4MatData.push_back(35.1*eV);
243
244 nMaterials = (G4int)g4MatData.size();
245}
246
247//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
std::vector< G4Material * > G4MaterialTable
std::vector< G4Track * > G4TrackVector
double G4double
Definition: G4Types.hh:83
int G4int
Definition: G4Types.hh:85
#define G4endl
Definition: G4ios.hh:57
G4GLOB_DLL std::ostream G4cout
#define G4UniformRand()
Definition: Randomize.hh:52
G4int SampleNumberOfIonsAlongStep(const G4Step *)
void DumpG4MeanEnergyPerIonPair() const
G4double FindG4MeanEnergyPerIonPair(const G4Material *) const
virtual ~G4ElectronIonPair()
void DumpMeanEnergyPerIonPair() const
G4double MeanNumberOfIonsAlongStep(const G4ParticleDefinition *, const G4Material *, G4double edepTotal, G4double edepNIEL=0.0)
G4int ResidualeChargePostStep(const G4ParticleDefinition *, const G4TrackVector *secondary=nullptr, G4int processSubType=-1) const
G4ElectronIonPair(G4int verb)
std::vector< G4ThreeVector > * SampleIonsAlongStep(const G4Step *)
G4double GetMeanEnergyPerIonPair() const
void SetMeanEnergyPerIonPair(G4double value)
static size_t GetNumberOfMaterials()
Definition: G4Material.cc:684
G4IonisParamMat * GetIonisation() const
Definition: G4Material.hh:221
static G4MaterialTable * GetMaterialTable()
Definition: G4Material.cc:677
const G4String & GetName() const
Definition: G4Material.hh:172
G4double GetPDGCharge() const
const G4ThreeVector & GetPosition() const
Definition: G4Step.hh:62
G4StepPoint * GetPreStepPoint() const
G4StepPoint * GetPostStepPoint() const