Geant4  10.03.p03
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
G4LindhardPartition.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  * \file electromagnetic/TestEm7/src/G4LindhardPartition.cc
28  * \brief Implementation of the G4LindhardPartition class
29  *
30  * Created by Marcus Mendenhall on 1/14/08.
31  * 2008 Vanderbilt University, Nashville, TN, USA.
32  *
33  */
34 
35 //
36 // $Id: G4LindhardPartition.cc 68263 2013-03-20 10:16:46Z maire $
37 
38 #include "G4LindhardPartition.hh"
39 #include "G4Material.hh"
40 #include "G4Element.hh"
41 #include "G4PhysicalConstants.hh"
42 #include "G4SystemOfUnits.hh"
43 
44 /*
45 for a first cut, we will compute NIEL from a Lindhard-Robinson partition
46 based on the most abundant element in the material.
47 
48 this is from IEEE Trans. Nucl Science Vol. 48 No.1 February 2001 page 162++
49 Insoo Jun, "Effects of Secondary Particles on the Total Dose..."
50 and, by reference,
51 Lindhard, Nielsen, Scharff & Thompson,
52 "Integral Equations Governing Radiation Efects...",
53 Mat. Fys. Medd. Dan. Vid. Selsk. vol 33 #10, pp1-42, 1963
54 and
55 Robinson, "The dependence of radiation effects on primary recoil energy",
56 in Proc. Int. Conf. Radiation-Induced Voids in Metal,
57 Albany, NY 1972 pp. 397-439
58 def lindhard_robinson(z1, a1, z2, a2, ke):
59 el=30.724*z1*z2*math.sqrt(z1**0.6667+z2**0.6667)*(a1+a2)/a2
60 fl=0.0793*z1**0.6667*math.sqrt(z2)*(a1+a2)**1.5/
61 ((z1**0.6667+z2**0.6667)**0.75*a1**1.5*math.sqrt(a2))
62 eps=ke*(1.0/el)
63 return 1.0/(1+fl*(3.4008*eps**0.16667+0.40244*eps**0.75+eps))
64 */
65 
67 {
68  max_z = 120;
69  for(size_t i=1; i<max_z; i++) {z23[i]=std::pow((G4double)i, 2./3.);}
70 }
71 
73  G4int z1, G4double a1, const G4Material *material, G4double energy) const
74 {
75  size_t nMatElements = material->GetNumberOfElements();
76 
77  const G4double *atomDensities=material->GetVecNbOfAtomsPerVolume();
78  G4double maxdens=0.0;
79  size_t maxindex=0;
80  for (size_t k=0 ; k < nMatElements ; k++ )
81  {
82  if(atomDensities[k] > maxdens) {
83  maxdens=atomDensities[k];
84  maxindex=k;
85  }
86  }
87  const G4Element *element=material->GetElement(maxindex);
88 
89  G4int z2=G4int(element->GetZ());
90 
91  G4double a2=element->GetA()/(Avogadro*amu);
92 
93  G4double zpow=z23[z1]+z23[z2];
94  G4double asum=a1+a2;
95 
96  G4double el=30.724*z1*z2*std::sqrt(zpow)*asum/a2;
97  G4double fl=0.0793*z23[z1]*std::sqrt(z2*asum*asum*asum/(a1*a1*a1*a2))
98  /std::pow(zpow, 0.75);
99  G4double eps=(energy/eV)*(1.0/el);
100 
101  return
102  1.0/(1+fl*(3.4008*std::pow(eps, 0.16667)+0.40244*std::pow(eps, 0.75)+eps));
103 }
104 
virtual G4double PartitionNIEL(G4int z1, G4double a1, const G4Material *material, G4double energy) const
G4double GetZ() const
Definition: G4Element.hh:131
static const G4double eps
const G4Element * GetElement(G4int iel) const
Definition: G4Material.hh:202
G4double GetA() const
Definition: G4Element.hh:139
int G4int
Definition: G4Types.hh:78
float Avogadro
Definition: hepunit.py:253
string material
Definition: eplot.py:19
const G4double * GetVecNbOfAtomsPerVolume() const
Definition: G4Material.hh:206
static constexpr double eV
Definition: G4SIunits.hh:215
G4double energy(const ThreeVector &p, const G4double m)
size_t GetNumberOfElements() const
Definition: G4Material.hh:186
double G4double
Definition: G4Types.hh:76