Geant4  10.03.p03
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
G4ionEffectiveCharge Class Reference

#include <G4ionEffectiveCharge.hh>

Public Member Functions

 G4ionEffectiveCharge ()
 
virtual ~G4ionEffectiveCharge ()
 
G4double EffectiveChargeSquareRatio (const G4ParticleDefinition *p, const G4Material *material, G4double kineticEnergy)
 
G4double EffectiveCharge (const G4ParticleDefinition *p, const G4Material *material, G4double kineticEnergy)
 

Detailed Description

Definition at line 62 of file G4ionEffectiveCharge.hh.

Constructor & Destructor Documentation

G4ionEffectiveCharge::G4ionEffectiveCharge ( )
explicit

Definition at line 67 of file G4ionEffectiveCharge.cc.

68 {
69  chargeCorrection = 1.0;
70  energyHighLimit = 20.0*MeV;
71  energyLowLimit = 1.0*keV;
72  energyBohr = 25.*keV;
73  massFactor = amu_c2/(proton_mass_c2*keV);
74  minCharge = 1.0;
75  lastPart = 0;
76  lastMat = 0;
77  lastKinEnergy = 0.0;
78  effCharge = eplus;
79  g4calc = G4Pow::GetInstance();
80 }
static G4Pow * GetInstance()
Definition: G4Pow.cc:55
static constexpr double eplus
Definition: G4SIunits.hh:199
float proton_mass_c2
Definition: hepunit.py:275
static constexpr double MeV
Definition: G4SIunits.hh:214
float amu_c2
Definition: hepunit.py:277
static constexpr double keV
Definition: G4SIunits.hh:216

Here is the call graph for this function:

G4ionEffectiveCharge::~G4ionEffectiveCharge ( )
virtual

Definition at line 84 of file G4ionEffectiveCharge.cc.

85 {}

Member Function Documentation

G4double G4ionEffectiveCharge::EffectiveCharge ( const G4ParticleDefinition p,
const G4Material material,
G4double  kineticEnergy 
)

Definition at line 89 of file G4ionEffectiveCharge.cc.

92 {
93  if(p == lastPart && material == lastMat && kineticEnergy == lastKinEnergy)
94  return effCharge;
95 
96  lastPart = p;
97  lastMat = material;
98  lastKinEnergy = kineticEnergy;
99 
100  G4double mass = p->GetPDGMass();
101  G4double charge = p->GetPDGCharge();
102  G4double Zi = charge*inveplus;
103 
104  chargeCorrection = 1.0;
105  effCharge = charge;
106 
107  // The aproximation of ion effective charge from:
108  // J.F.Ziegler, J.P. Biersack, U. Littmark
109  // The Stopping and Range of Ions in Matter,
110  // Vol.1, Pergamon Press, 1985
111  // Fast ions or hadrons
112  G4double reducedEnergy = kineticEnergy * proton_mass_c2/mass ;
113 
114  //G4cout << "e= " << reducedEnergy << " Zi= " << Zi << " "
115  //<< material->GetName() << G4endl;
116 
117  if(Zi < 1.5 || !material || reducedEnergy > Zi*energyHighLimit ) {
118  return charge;
119  }
120  G4double z = material->GetIonisation()->GetZeffective();
121  reducedEnergy = std::max(reducedEnergy,energyLowLimit);
122 
123  // Helium ion case
124  if( Zi < 2.5 ) {
125 
126  static const G4double c[6] =
127  {0.2865,0.1266,-0.001429,0.02402,-0.01135,0.001475};
128 
129  G4double Q = std::max(0.0,G4Log(reducedEnergy*massFactor));
130  G4double x = c[0];
131  G4double y = 1.0;
132  for (G4int i=1; i<6; ++i) {
133  y *= Q;
134  x += y * c[i] ;
135  }
136  G4double ex;
137  if(x < 0.2) { ex = x * (1 - 0.5*x); }
138  else { ex = 1. - G4Exp(-x); }
139 
140  G4double tq = 7.6 - Q;
141  G4double tq2= tq*tq;
142  G4double tt = ( 0.007 + 0.00005 * z );
143  if(tq2 < 0.2) { tt *= (1.0 - tq2 + 0.5*tq2*tq2); }
144  else { tt *= G4Exp(-tq2); }
145 
146  effCharge = charge*(1.0 + tt) * std::sqrt(ex);
147 
148  // Heavy ion case
149  } else {
150 
151  G4double y;
152  G4double zi13 = g4calc->A13(Zi);
153  G4double zi23 = zi13*zi13;
154 
155  // v1 is ion velocity in vF unit
156  G4double eF = material->GetIonisation()->GetFermiEnergy();
157  G4double v1sq = reducedEnergy/eF;
158  G4double vFsq = eF/energyBohr;
159  G4double vF = std::sqrt(eF/energyBohr);
160 
161  // Faster than Fermi velocity
162  if ( v1sq > 1.0 ) {
163  y = vF * std::sqrt(v1sq) * ( 1.0 + 0.2/v1sq ) / zi23 ;
164 
165  // Slower than Fermi velocity
166  } else {
167  y = 0.692308 * vF * (1.0 + 0.666666*v1sq + v1sq*v1sq/15.0) / zi23 ;
168  }
169 
170  G4double q;
171  G4double y3 = std::pow(y, 0.3) ;
172  // G4cout<<"y= "<<y<<" y3= "<<y3<<" v1= "<<v1<<" vF= "<<vF<<G4endl;
173  q = 1.0 - G4Exp( 0.803*y3 - 1.3167*y3*y3 - 0.38157*y - 0.008983*y*y);
174  q = std::max(q, minCharge/Zi);
175 
176  effCharge = q*charge;
177 
178  G4double tq = 7.6 - G4Log(reducedEnergy/keV);
179  G4double tq2= tq*tq;
180  G4double sq = 1.0 + ( 0.18 + 0.0015 * z )*G4Exp(-tq2)/ (Zi*Zi);
181 
182  // G4cout << "sq= " << sq << G4endl;
183 
184  // Screen length according to
185  // J.F.Ziegler and J.M.Manoyan, The stopping of ions in compaunds,
186  // Nucl. Inst. & Meth. in Phys. Res. B35 (1988) 215-228.
187 
188  G4double lambda = 10.0 * vF *g4calc->A23(1.0 - q)/ (zi13 * (6.0 + q));
189 
190  G4double lambda2 = lambda*lambda;
191 
192  G4double xx = (0.5/q - 0.5)*G4Log(1.0 + lambda2)/vFsq;
193 
194  chargeCorrection = sq * (1.0 + xx);
195 
196  }
197  // G4cout << "G4ionEffectiveCharge: charge= " << charge << " q= " << q
198  // << " chargeCor= " << chargeCorrection
199  // << " e(MeV)= " << kineticEnergy/MeV << G4endl;
200  return effCharge;
201 }
G4IonisParamMat * GetIonisation() const
Definition: G4Material.hh:226
const char * p
Definition: xmltok.h:285
static double Q[]
tuple x
Definition: test.py:50
int G4int
Definition: G4Types.hh:78
G4double GetZeffective() const
G4double GetFermiEnergy() const
string material
Definition: eplot.py:19
G4double A23(G4double A) const
Definition: G4Pow.hh:160
float proton_mass_c2
Definition: hepunit.py:275
G4double G4Log(G4double x)
Definition: G4Log.hh:230
G4double G4Exp(G4double initial_x)
Exponential Function double precision.
Definition: G4Exp.hh:183
G4double GetPDGMass() const
G4double A13(G4double A) const
Definition: G4Pow.hh:132
T max(const T t1, const T t2)
brief Return the largest of the two arguments
tuple z
Definition: test.py:28
double G4double
Definition: G4Types.hh:76
tuple c
Definition: test.py:13
G4double GetPDGCharge() const
static constexpr double keV
Definition: G4SIunits.hh:216

Here is the call graph for this function:

Here is the caller graph for this function:

G4double G4ionEffectiveCharge::EffectiveChargeSquareRatio ( const G4ParticleDefinition p,
const G4Material material,
G4double  kineticEnergy 
)
inline

Definition at line 106 of file G4ionEffectiveCharge.hh.

110 {
111  G4double charge = effCharge;
112  if( kineticEnergy != lastKinEnergy || material != lastMat || p != lastPart) {
113  charge = EffectiveCharge(p,material,kineticEnergy);
114  }
115  charge *= chargeCorrection*inveplus;
116 
117  return charge*charge;
118 }
G4double EffectiveCharge(const G4ParticleDefinition *p, const G4Material *material, G4double kineticEnergy)
double G4double
Definition: G4Types.hh:76

Here is the call graph for this function:

Here is the caller graph for this function:


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