Geant4-11
Public Member Functions | Private Member Functions | Private Attributes | Static Private Attributes
G4EmSaturation Class Reference

#include <G4EmSaturation.hh>

Public Member Functions

void DumpBirksCoefficients ()
 
void DumpG4BirksCoefficients ()
 
G4double FindG4BirksCoefficient (const G4Material *)
 
 G4EmSaturation (const G4EmSaturation &)=delete
 
 G4EmSaturation (G4int verb)
 
void InitialiseG4Saturation ()
 
G4EmSaturationoperator= (const G4EmSaturation &right)=delete
 
void SetVerbose (G4int)
 
virtual G4double VisibleEnergyDeposition (const G4ParticleDefinition *, const G4MaterialCutsCouple *, G4double length, G4double edepTotal, G4double edepNIEL=0.0) const
 
G4double VisibleEnergyDepositionAtAStep (const G4Step *) const
 
virtual ~G4EmSaturation ()
 

Private Member Functions

void InitialiseBirksCoefficient (const G4Material *)
 
void InitialiseG4materials ()
 

Private Attributes

const G4ParticleDefinitionelectron
 
G4int nG4Birks
 
G4NistManagernist
 
G4int nWarnings
 
const G4ParticleDefinitionproton
 
G4int verbose
 

Static Private Attributes

static std::vector< G4doubleeffCharges
 
static std::vector< G4doubleg4MatData
 
static std::vector< G4Stringg4MatNames
 
static std::vector< G4doublemassFactors
 
static size_t nMaterials = 0
 

Detailed Description

Definition at line 69 of file G4EmSaturation.hh.

Constructor & Destructor Documentation

◆ G4EmSaturation() [1/2]

G4EmSaturation::G4EmSaturation ( G4int  verb)
explicit

Definition at line 62 of file G4EmSaturation.cc.

63{
64 verbose = verb;
65 nWarnings = nG4Birks = 0;
66
67 electron = nullptr;
68 proton = nullptr;
71}
const G4ParticleDefinition * electron
G4NistManager * nist
void InitialiseG4Saturation()
const G4ParticleDefinition * proton
static G4NistManager * Instance()

References electron, InitialiseG4Saturation(), G4NistManager::Instance(), nG4Birks, nist, nWarnings, proton, and verbose.

◆ ~G4EmSaturation()

G4EmSaturation::~G4EmSaturation ( )
virtual

Definition at line 75 of file G4EmSaturation.cc.

76{}

◆ G4EmSaturation() [2/2]

G4EmSaturation::G4EmSaturation ( const G4EmSaturation )
delete

Member Function Documentation

◆ DumpBirksCoefficients()

void G4EmSaturation::DumpBirksCoefficients ( )

Definition at line 238 of file G4EmSaturation.cc.

239{
240 G4cout << "### Birks coefficients used in run time" << G4endl;
242 for(size_t i=0; i<nMaterials; ++i) {
243 const G4Material* mat = (*mtable)[i];
245 if(br > 0.0) {
246 G4cout << " " << mat->GetName() << " "
247 << br*MeV/mm << " mm/MeV" << " "
248 << br*mat->GetDensity()*MeV*cm2/g
249 << " g/cm^2/MeV massFactor= " << massFactors[i]
250 << " effCharge= " << effCharges[i] << G4endl;
251 }
252 }
253}
std::vector< G4Material * > G4MaterialTable
static constexpr double cm2
Definition: G4SIunits.hh:100
static constexpr double mm
Definition: G4SIunits.hh:95
static constexpr double g
Definition: G4SIunits.hh:168
static constexpr double MeV
Definition: G4SIunits.hh:200
double G4double
Definition: G4Types.hh:83
#define G4endl
Definition: G4ios.hh:57
G4GLOB_DLL std::ostream G4cout
static std::vector< G4double > massFactors
static std::vector< G4double > effCharges
static size_t nMaterials
G4double GetBirksConstant() const
G4double GetDensity() const
Definition: G4Material.hh:176
G4IonisParamMat * GetIonisation() const
Definition: G4Material.hh:222
static G4MaterialTable * GetMaterialTable()
Definition: G4Material.cc:672
const G4String & GetName() const
Definition: G4Material.hh:173

References cm2, effCharges, g, G4cout, G4endl, G4IonisParamMat::GetBirksConstant(), G4Material::GetDensity(), G4Material::GetIonisation(), G4Material::GetMaterialTable(), G4Material::GetName(), massFactors, MeV, mm, and nMaterials.

Referenced by InitialiseG4Saturation().

◆ DumpG4BirksCoefficients()

void G4EmSaturation::DumpG4BirksCoefficients ( )

Definition at line 257 of file G4EmSaturation.cc.

258{
259 if(nG4Birks > 0) {
260 G4cout << "### Birks coefficients for Geant4 materials" << G4endl;
261 for(G4int i=0; i<nG4Birks; ++i) {
262 G4cout << " " << g4MatNames[i] << " "
263 << g4MatData[i]*MeV/mm << " mm/MeV" << G4endl;
264 }
265 }
266}
int G4int
Definition: G4Types.hh:85
static std::vector< G4double > g4MatData
static std::vector< G4String > g4MatNames

References G4cout, G4endl, g4MatData, g4MatNames, MeV, mm, and nG4Birks.

◆ FindG4BirksCoefficient()

G4double G4EmSaturation::FindG4BirksCoefficient ( const G4Material mat)

Definition at line 161 of file G4EmSaturation.cc.

162{
163 if(0 == nG4Birks) { InitialiseG4materials(); }
164
165 G4String name = mat->GetName();
166 // is this material in the vector?
167
168 for(G4int j=0; j<nG4Birks; ++j) {
169 if(name == g4MatNames[j]) {
170 if(verbose > 0)
171 G4cout << "### G4EmSaturation::FindG4BirksCoefficient for "
172 << name << " is " << g4MatData[j]*MeV/mm << " mm/MeV "
173 << G4endl;
174 return g4MatData[j];
175 }
176 }
177 return 0.0;
178}
void InitialiseG4materials()
const char * name(G4int ptype)

References G4cout, G4endl, g4MatData, g4MatNames, G4Material::GetName(), InitialiseG4materials(), MeV, mm, G4InuclParticleNames::name(), nG4Birks, and verbose.

◆ InitialiseBirksCoefficient()

void G4EmSaturation::InitialiseBirksCoefficient ( const G4Material mat)
private

Definition at line 182 of file G4EmSaturation.cc.

183{
184 // electron and proton should exist in any case
185 if(nullptr == electron) {
188 if(nullptr == electron) {
189 G4Exception("G4EmSaturation::InitialiseBirksCoefficient", "em0001",
190 FatalException, "electron should exist");
191 }
192 }
193
194 G4double curBirks = mat->GetIonisation()->GetBirksConstant();
195
196 G4String name = mat->GetName();
197
198 // material has no Birks coeffitient defined
199 // seach in the Geant4 list
200 if(curBirks == 0.0) {
201 for(G4int j=0; j<nG4Birks; ++j) {
202 if(name == g4MatNames[j]) {
204 curBirks = g4MatData[j];
205 break;
206 }
207 }
208 }
209
210 if(curBirks == 0.0) { return; }
211
212 // compute mean mass ratio
213 G4double curRatio = 0.0;
214 G4double curChargeSq = 0.0;
215 G4double norm = 0.0;
216 const G4ElementVector* theElementVector = mat->GetElementVector();
217 const G4double* theAtomNumDensityVector = mat->GetVecNbOfAtomsPerVolume();
218 size_t nelm = mat->GetNumberOfElements();
219 for (size_t i=0; i<nelm; ++i) {
220 const G4Element* elm = (*theElementVector)[i];
221 G4double Z = elm->GetZ();
222 G4double w = Z*Z*theAtomNumDensityVector[i];
223 curRatio += w/nist->GetAtomicMassAmu(G4int(Z));
224 curChargeSq = Z*Z*w;
225 norm += w;
226 }
227 curRatio *= proton_mass_c2/norm;
228 curChargeSq /= norm;
229
230 // store results
231 G4int idx = mat->GetIndex();
232 massFactors[idx] = curRatio;
233 effCharges[idx] = curChargeSq;
234}
std::vector< const G4Element * > G4ElementVector
@ FatalException
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
Definition: G4Exception.cc:35
const G4int Z[17]
G4double GetZ() const
Definition: G4Element.hh:131
void SetBirksConstant(G4double value)
const G4ElementVector * GetElementVector() const
Definition: G4Material.hh:186
size_t GetNumberOfElements() const
Definition: G4Material.hh:182
const G4double * GetVecNbOfAtomsPerVolume() const
Definition: G4Material.hh:202
size_t GetIndex() const
Definition: G4Material.hh:256
G4double GetAtomicMassAmu(const G4String &symb) const
G4ParticleDefinition * FindParticle(G4int PDGEncoding)
static G4ParticleTable * GetParticleTable()
float proton_mass_c2
Definition: hepunit.py:274

References effCharges, electron, FatalException, G4ParticleTable::FindParticle(), G4Exception(), g4MatData, g4MatNames, G4NistManager::GetAtomicMassAmu(), G4IonisParamMat::GetBirksConstant(), G4Material::GetElementVector(), G4Material::GetIndex(), G4Material::GetIonisation(), G4Material::GetName(), G4Material::GetNumberOfElements(), G4ParticleTable::GetParticleTable(), G4Material::GetVecNbOfAtomsPerVolume(), G4Element::GetZ(), massFactors, G4InuclParticleNames::name(), nG4Birks, nist, proton, source.hepunit::proton_mass_c2, G4IonisParamMat::SetBirksConstant(), and Z.

Referenced by InitialiseG4Saturation().

◆ InitialiseG4materials()

void G4EmSaturation::InitialiseG4materials ( )
private

Definition at line 270 of file G4EmSaturation.cc.

271{
272 nG4Birks = 4;
273 g4MatData.reserve(nG4Birks);
274
275 // M.Hirschberg et al., IEEE Trans. Nuc. Sci. 39 (1992) 511
276 // SCSN-38 kB = 0.00842 g/cm^2/MeV; rho = 1.06 g/cm^3
277 g4MatNames.push_back("G4_POLYSTYRENE");
278 g4MatData.push_back(0.07943*mm/MeV);
279
280 // C.Fabjan (private communication)
281 // kB = 0.006 g/cm^2/MeV; rho = 7.13 g/cm^3
282 g4MatNames.push_back("G4_BGO");
283 g4MatData.push_back(0.008415*mm/MeV);
284
285 // A.Ribon analysis of publications
286 // Scallettar et al., Phys. Rev. A25 (1982) 2419.
287 // NIM A 523 (2004) 275.
288 // kB = 0.022 g/cm^2/MeV; rho = 1.396 g/cm^3;
289 // ATLAS Efield = 10 kV/cm provide the strongest effect
290 // kB = 0.1576*mm/MeV
291 // A. Kiryunin and P.Strizenec "Geant4 hadronic
292 // working group meeting " kB = 0.041/9.13 g/cm^2/MeV
293 g4MatNames.push_back("G4_lAr");
294 g4MatData.push_back(0.032*mm/MeV);
295
296 //G4_BARIUM_FLUORIDE
297 //G4_CESIUM_IODIDE
298 //G4_GEL_PHOTO_EMULSION
299 //G4_PHOTO_EMULSION
300 //G4_PLASTIC_SC_VINYLTOLUENE
301 //G4_SODIUM_IODIDE
302 //G4_STILBENE
303 //G4_lAr
304
305 //G4_PbWO4 - CMS value
306 g4MatNames.push_back("G4_PbWO4");
307 g4MatData.push_back(0.0333333*mm/MeV);
308
309 //G4_Lucite
310
311}

References g4MatData, g4MatNames, MeV, mm, and nG4Birks.

Referenced by FindG4BirksCoefficient(), and InitialiseG4Saturation().

◆ InitialiseG4Saturation()

void G4EmSaturation::InitialiseG4Saturation ( )

Definition at line 144 of file G4EmSaturation.cc.

145{
148 massFactors.resize(nMaterials, 1.0);
149 effCharges.resize(nMaterials, 1.0);
150
151 if(0 == nG4Birks) { InitialiseG4materials(); }
152
153 for(size_t i=0; i<nMaterials; ++i) {
155 }
156 if(verbose > 0) { DumpBirksCoefficients(); }
157}
void DumpBirksCoefficients()
void InitialiseBirksCoefficient(const G4Material *)
static size_t GetNumberOfMaterials()
Definition: G4Material.cc:679

References DumpBirksCoefficients(), effCharges, G4Material::GetMaterialTable(), G4Material::GetNumberOfMaterials(), InitialiseBirksCoefficient(), InitialiseG4materials(), massFactors, nG4Birks, nMaterials, and verbose.

Referenced by G4EmSaturation().

◆ operator=()

G4EmSaturation & G4EmSaturation::operator= ( const G4EmSaturation right)
delete

◆ SetVerbose()

void G4EmSaturation::SetVerbose ( G4int  val)
inline

Definition at line 132 of file G4EmSaturation.hh.

133{
134 verbose = val;
135}

References verbose.

◆ VisibleEnergyDeposition()

G4double G4EmSaturation::VisibleEnergyDeposition ( const G4ParticleDefinition p,
const G4MaterialCutsCouple couple,
G4double  length,
G4double  edepTotal,
G4double  edepNIEL = 0.0 
) const
virtual

Definition at line 80 of file G4EmSaturation.cc.

86{
87 // no energy deposition
88 if(edep <= 0.0) { return 0.0; }
89
90 // zero step length may happens only if step limiter process
91 // is applied, in that case saturation should not be applied
92 if(length <= 0.0) { return edep; }
93
94 G4double evis = edep;
95 G4double bfactor = couple->GetMaterial()->GetIonisation()->GetBirksConstant();
96
97 if(bfactor > 0.0) {
98
99 // atomic relaxations for gamma incident
100 if(22 == p->GetPDGEncoding()) {
101 //G4cout << "%% gamma edep= " << edep/keV << " keV " << G4endl;
102 evis /= (1.0 + bfactor*edep/
104
105 // energy loss
106 } else {
107
108 // protections
109 G4double nloss = std::max(niel, 0.0);
110 G4double eloss = edep - nloss;
111
112 // neutrons and neutral hadrons
113 if(0.0 == p->GetPDGCharge() || eloss < 0.0) {
114 nloss = edep;
115 eloss = 0.0;
116 } else {
117
118 // continues energy loss
119 eloss /= (1.0 + bfactor*eloss/length);
120 }
121 // non-ionizing energy loss
122 if(nloss > 0.0) {
123 G4int idx = couple->GetMaterial()->GetIndex();
124 G4double escaled = nloss*massFactors[idx];
125 /*
126 G4cout << "%% p edep= " << nloss/keV << " keV Escaled= "
127 << escaled << " MeV in " << couple->GetMaterial()->GetName()
128 << " " << p->GetParticleName()
129 << G4endl;
130 G4cout << proton->GetParticleName() << G4endl;
131 */
133 ->GetRange(proton,escaled,couple)/effCharges[idx];
134 nloss /= (1.0 + bfactor*nloss/range);
135 }
136 evis = eloss + nloss;
137 }
138 }
139 return evis;
140}
static G4LossTableManager * Instance()
G4double GetRange(const G4ParticleDefinition *aParticle, G4double kineticEnergy, const G4MaterialCutsCouple *couple)
const G4Material * GetMaterial() const
G4double GetPDGCharge() const
T max(const T t1, const T t2)
brief Return the largest of the two arguments

References effCharges, electron, G4IonisParamMat::GetBirksConstant(), G4Material::GetIndex(), G4Material::GetIonisation(), G4MaterialCutsCouple::GetMaterial(), G4ParticleDefinition::GetPDGCharge(), G4ParticleDefinition::GetPDGEncoding(), G4LossTableManager::GetRange(), G4LossTableManager::Instance(), massFactors, G4INCL::Math::max(), and proton.

Referenced by VisibleEnergyDepositionAtAStep().

◆ VisibleEnergyDepositionAtAStep()

G4double G4EmSaturation::VisibleEnergyDepositionAtAStep ( const G4Step step) const
inline

Definition at line 139 of file G4EmSaturation.hh.

141{
144 step->GetStepLength(),
145 step->GetTotalEnergyDeposit(),
147}
virtual G4double VisibleEnergyDeposition(const G4ParticleDefinition *, const G4MaterialCutsCouple *, G4double length, G4double edepTotal, G4double edepNIEL=0.0) const
G4Track * GetTrack() const
G4double GetNonIonizingEnergyDeposit() const
G4double GetStepLength() const
G4double GetTotalEnergyDeposit() const
const G4ParticleDefinition * GetParticleDefinition() const
const G4MaterialCutsCouple * GetMaterialCutsCouple() const

References G4Track::GetMaterialCutsCouple(), G4Step::GetNonIonizingEnergyDeposit(), G4Track::GetParticleDefinition(), G4Step::GetStepLength(), G4Step::GetTotalEnergyDeposit(), G4Step::GetTrack(), and VisibleEnergyDeposition().

Referenced by G4Scintillation::PostStepDoIt().

Field Documentation

◆ effCharges

std::vector< G4double > G4EmSaturation::effCharges
staticprivate

◆ electron

const G4ParticleDefinition* G4EmSaturation::electron
private

◆ g4MatData

std::vector< G4double > G4EmSaturation::g4MatData
staticprivate

◆ g4MatNames

std::vector< G4String > G4EmSaturation::g4MatNames
staticprivate

◆ massFactors

std::vector< G4double > G4EmSaturation::massFactors
staticprivate

◆ nG4Birks

G4int G4EmSaturation::nG4Birks
private

◆ nist

G4NistManager* G4EmSaturation::nist
private

Definition at line 113 of file G4EmSaturation.hh.

Referenced by G4EmSaturation(), and InitialiseBirksCoefficient().

◆ nMaterials

size_t G4EmSaturation::nMaterials = 0
staticprivate

Definition at line 119 of file G4EmSaturation.hh.

Referenced by DumpBirksCoefficients(), and InitialiseG4Saturation().

◆ nWarnings

G4int G4EmSaturation::nWarnings
private

Definition at line 117 of file G4EmSaturation.hh.

Referenced by G4EmSaturation().

◆ proton

const G4ParticleDefinition* G4EmSaturation::proton
private

◆ verbose

G4int G4EmSaturation::verbose
private

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