130        pname != 
"deuteron" && pname != 
"triton" &&
 
  131        pname != 
"alpha+"   && pname != 
"helium" &&
 
  132        pname != 
"hydrogen") { 
isIon = 
true; }
 
  186   if(cutEnergy < tmax) {
 
  190     G4double beta2   = kineticEnergy*(kineticEnergy + 2.0*
mass)/energy2;
 
  191     cross = (maxEnergy - cutEnergy)/(cutEnergy*maxEnergy) 
 
  192       - beta2*
G4Log(maxEnergy/cutEnergy)/tmax;
 
  194     if( 0.5 == 
spin ) { cross += 0.5*(maxEnergy - cutEnergy)/energy2; }
 
  214                                          (p,kineticEnergy,cutEnergy,maxEnergy);
 
  229                                          (p,kineticEnergy,cutEnergy,maxEnergy);
 
  248     dedx = 
DEDX(material, tkin); 
 
  251   if (cutEnergy < tmax) {
 
  259     dedx += (
G4Log(x) + (1.0 - x)*beta2) * twopi_mc2_rcl2
 
  265   if (dedx < 0.0) dedx = 0.0 ;
 
  288   G4double e = preKinEnergy - eloss*0.5;
 
  289   if(e < 0.0) { e = preKinEnergy*0.5; }
 
  310   if(xmin >= xmax) { 
return; }
 
  315   G4double beta2   = kineticEnergy*(kineticEnergy + 2.0*
mass)/energy2;
 
  322     deltaKinEnergy = xmin*xmax/(xmin*(1.0 - q) + xmax*q);
 
  324     f = 1.0 - beta2*deltaKinEnergy/tmax;
 
  327         G4cout << 
"G4BraggIonModel::SampleSecondary Warning! " 
  328                << 
"Majorant " << grej << 
" < " 
  329                << f << 
" for e= " << deltaKinEnergy
 
  347       sqrt(deltaKinEnergy * (deltaKinEnergy + 2.0*electron_mass_c2));
 
  348     G4double cost = deltaKinEnergy * (energy + electron_mass_c2) /
 
  350     if(cost > 1.0) { cost = 1.0; }
 
  351     G4double sint = sqrt((1.0 - cost)*(1.0 + cost));
 
  355     deltaDirection.set(sint*cos(phi),sint*sin(phi), cost) ;
 
  363   vdp->push_back(delta);
 
  366   kineticEnergy -= deltaKinEnergy;
 
  368   finalP               = finalP.unit();
 
  381   G4double tmax = 2.0*electron_mass_c2*tau*(tau + 2.) /
 
  431        {9.43672, 0.54398, 84.341, 1.3705, 57.422},
 
  432        {67.1503, 0.41409, 404.512, 148.97, 20.99},
 
  433        {5.11203, 0.453,  36.718,  50.6,  28.058}, 
 
  434        {61.793, 0.48445, 361.537, 57.889, 50.674},
 
  435        {7.83464, 0.49804, 160.452, 3.192, 0.71922},
 
  436        {19.729, 0.52153, 162.341, 58.35, 25.668}, 
 
  437        {26.4648, 0.50112, 188.913, 30.079, 16.509},
 
  438        {7.8655, 0.5205, 63.96, 51.32, 67.775},
 
  439        {8.8965, 0.5148, 339.36, 1.7205, 0.70423},
 
  440        {2.959, 0.53255, 34.247, 60.655, 15.153}, 
 
  441        {3.80133, 0.41590, 12.9966, 117.83, 242.28} };   
 
  443     static const G4double atomicWeight[11] = {
 
  444        101.96128, 44.0098, 16.0426, 28.0536, 42.0804,
 
  445        104.1512, 44.665, 60.0843, 18.0152, 18.0152, 12.0};       
 
  452       G4double shigh = 
G4Log( 1.0 + a[i][3]*1000.0 + a[i][4]*0.001 )
 
  454       ionloss  = slow*shigh / (slow + shigh) ;
 
  455       ionloss *= sqrt(T*1000.0) ;
 
  460       G4double shigh = 
G4Log( 1.0 + a[i][3]/T + a[i][4]*T ) * a[i][2]/T ;
 
  461       ionloss = slow*shigh / (slow + shigh) ;
 
  470     if ( ionloss < 0.0) ionloss = 0.0 ;
 
  503     {0.35485, 0.6456, 6.01525,  20.8933, 4.3515
 
  504    },{ 0.58,    0.59,   6.3,     130.0,   44.07
 
  505    },{ 1.42,    0.49,   12.25,    32.0,    9.161
 
  506    },{ 2.206,   0.51,   15.32,    0.25,    8.995 
 
  508    },{ 3.691,   0.4128, 18.48,    50.72,   9.0
 
  509    },{ 3.83523, 0.42993,12.6125,  227.41,  188.97
 
  510    },{ 1.9259,  0.5550, 27.15125, 26.0665, 6.2768
 
  511    },{ 2.81015, 0.4759, 50.0253,  10.556,  1.0382
 
  512    },{ 1.533,   0.531,  40.44,    18.41,   2.718
 
  513    },{ 2.303,   0.4861, 37.01,    37.96,   5.092
 
  515    },{ 9.894,   0.3081, 23.65,    0.384,   92.93
 
  516    },{ 4.3,     0.47,   34.3,     3.3,     12.74
 
  517    },{ 2.5,     0.625,  45.7,     0.1,     4.359
 
  518    },{ 2.1,     0.65,   49.34,    1.788,   4.133
 
  519    },{ 1.729,   0.6562, 53.41,    2.405,   3.845
 
  520    },{ 1.402,   0.6791, 58.98,    3.528,   3.211
 
  521    },{ 1.117,   0.7044, 69.69,    3.705,    2.156
 
  522    },{ 2.291,   0.6284, 73.88,    4.478,    2.066
 
  523    },{ 8.554,   0.3817, 83.61,    11.84,    1.875
 
  524    },{ 6.297,   0.4622, 65.39,    10.14,    5.036
 
  526    },{ 5.307,   0.4918, 61.74,    12.4,    6.665
 
  527    },{ 4.71,    0.5087, 65.28,    8.806,    5.948
 
  528    },{ 6.151,   0.4524, 83.0,    18.31,    2.71
 
  529    },{ 6.57,    0.4322, 84.76,    15.53,    2.779
 
  530    },{ 5.738,   0.4492, 84.6,    14.18,    3.101
 
  531    },{ 5.013,   0.4707, 85.8,    16.55,    3.211
 
  532    },{ 4.32,    0.4947, 76.14,    10.85,    5.441
 
  533    },{ 4.652,   0.4571, 80.73,    22.0,    4.952
 
  534    },{ 3.114,   0.5236, 76.67,    7.62,    6.385
 
  535    },{ 3.114,   0.5236, 76.67,    7.62,    7.502
 
  537    },{ 3.114,   0.5236, 76.67,    7.62,    8.514
 
  538    },{ 5.746,   0.4662, 79.24,    1.185,    7.993
 
  539    },{ 2.792,   0.6346, 106.1,    0.2986,   2.331
 
  540    },{ 4.667,   0.5095, 124.3,    2.102,    1.667
 
  541    },{ 2.44,    0.6346, 105.0,    0.83,    2.851
 
  542    },{ 1.413,   0.7377, 147.9,    1.466,    1.016
 
  543    },{ 11.72,   0.3826, 102.8,    9.231,    4.371
 
  544    },{ 7.126,   0.4804, 119.3,    5.784,    2.454
 
  545    },{ 11.61,   0.3955, 146.7,    7.031,    1.423
 
  546    },{ 10.99,   0.41,   163.9,   7.1,      1.052
 
  548    },{ 9.241,   0.4275, 163.1,    7.954,    1.102
 
  549    },{ 9.276,   0.418,  157.1,   8.038,    1.29
 
  550    },{ 3.999,   0.6152, 97.6,    1.297,    5.792
 
  551    },{ 4.306,   0.5658, 97.99,    5.514,    5.754
 
  552    },{ 3.615,   0.6197, 86.26,    0.333,    8.689
 
  553    },{ 5.8,     0.49,   147.2,   6.903,    1.289
 
  554    },{ 5.6,     0.49,   130.0,   10.0,     2.844
 
  555    },{ 3.55,    0.6068, 124.7,    1.112,    3.119
 
  556    },{ 3.6,     0.62,   105.8,   0.1692,   6.026
 
  557    },{ 5.4,     0.53,   103.1,   3.931,    7.767
 
  559    },{ 3.97,    0.6459, 131.8,    0.2233,   2.723
 
  560    },{ 3.65,    0.64,   126.8,   0.6834,   3.411
 
  561    },{ 3.118,   0.6519, 164.9,    1.208,    1.51
 
  562    },{ 3.949,   0.6209, 200.5,    1.878,    0.9126
 
  563    },{ 14.4,    0.3923, 152.5,    8.354,    2.597
 
  564    },{ 10.99,   0.4599, 138.4,    4.811,    3.726
 
  565    },{ 16.6,    0.3773, 224.1,    6.28,    0.9121
 
  566    },{ 10.54,   0.4533, 159.3,   4.832,    2.529
 
  567    },{ 10.33,   0.4502, 162.0,   5.132,    2.444
 
  568    },{ 10.15,   0.4471, 165.6,   5.378,    2.328
 
  570    },{ 9.976,   0.4439, 168.0,   5.721,    2.258
 
  571    },{ 9.804,   0.4408, 176.2,   5.675,    1.997
 
  572    },{ 14.22,   0.363,  228.4,   7.024,    1.016
 
  573    },{ 9.952,   0.4318, 233.5,   5.065,    0.9244
 
  574    },{ 9.272,   0.4345, 210.0,   4.911,    1.258
 
  575    },{ 10.13,   0.4146, 225.7,   5.525,    1.055
 
  576    },{ 8.949,   0.4304, 213.3,   5.071,    1.221
 
  577    },{ 11.94,   0.3783, 247.2,   6.655,    0.849
 
  578    },{ 8.472,   0.4405, 195.5,   4.051,    1.604
 
  579    },{ 8.301,   0.4399, 203.7,   3.667,    1.459
 
  581    },{ 6.567,   0.4858, 193.0,   2.65,     1.66
 
  582    },{ 5.951,   0.5016, 196.1,   2.662,    1.589
 
  583    },{ 7.495,   0.4523, 251.4,   3.433,    0.8619
 
  584    },{ 6.335,   0.4825, 255.1,   2.834,    0.8228
 
  585    },{ 4.314,   0.5558, 214.8,   2.354,    1.263
 
  586    },{ 4.02,    0.5681, 219.9,   2.402,    1.191
 
  587    },{ 3.836,   0.5765, 210.2,   2.742,    1.305
 
  588    },{ 4.68,    0.5247, 244.7,   2.749,    0.8962
 
  589    },{ 2.892,   0.6204, 208.6,   2.415,    1.416 
 
  591    },{ 2.892,   0.6204, 208.6,   2.415,    1.416
 
  593    },{ 4.728,   0.5522, 217.0,   3.091,    1.386
 
  594    },{ 6.18,    0.52,   170.0,   4.0,      3.224
 
  595    },{ 9.0,     0.47,   198.0,   3.8,      2.032
 
  596    },{ 2.324,   0.6997, 216.0,   1.599,    1.399
 
  597    },{ 1.961,   0.7286, 223.0,   1.621,    1.296
 
  598    },{ 1.75,    0.7427, 350.1,   0.9789,   0.5507
 
  599    },{ 10.31,   0.4613, 261.2,   4.738,    0.9899
 
  600    },{ 7.962,   0.519,  235.7,   4.347,    1.313
 
  601    },{ 6.227,   0.5645, 231.9,   3.961,    1.379
 
  602    },{ 5.246,   0.5947, 228.6,   4.027,    1.432
 
  604    },{ 5.408,   0.5811, 235.7,   3.961,    1.358
 
  605    },{ 5.218,   0.5828, 245.0,   3.838,    1.25}
 
  611     G4double shigh = 
G4Log( 1.0 + a[i][3]*1000.0 + a[i][4]*0.001 )
 
  613     ionloss  = slow*shigh / (slow + shigh) ;
 
  614     ionloss *= sqrt(T*1000.0) ;
 
  619     G4double shigh = 
G4Log( 1.0 + a[i][3]/T + a[i][4]*T ) * a[i][2]/T ;
 
  620     ionloss = slow*shigh / (slow + shigh) ;
 
  629   if ( ionloss < 0.0) { ionloss = 0.0; }
 
  652   const G4double* theAtomicNumDensityVector =
 
  666   } 
else if(1 == numberOfElements) {
 
  678     for (
G4int i=0; i<numberOfElements; i++)
 
  680       const G4Element* element = (*theElementVector)[i] ;
 
  682                                    * theAtomicNumDensityVector[i];
 
  698   static const G4double c[6] = {0.2865,  0.1266, -0.001429,
 
  699                                 0.02402,-0.01135, 0.001475};
 
  704   for (
G4int i=1; i<6; i++) {
 
  710   w = 1.0 + (0.007 + 0.00005*
z) * 
G4Exp( -w*w ) ;
 
  711   w = 4.0 * (1.0 - 
G4Exp(-x)) * w * w ;
 
G4double MaxSecondaryKinEnergy(const G4DynamicParticle *dynParticle)
G4IonisParamMat * GetIonisation() const 
static G4LossTableManager * Instance()
G4ParticleChangeForLoss * GetParticleChangeForLoss()
static G4ASTARStopping * fASTAR
std::vector< G4Element * > G4ElementVector
G4BraggIonModel(const G4ParticleDefinition *p=0, const G4String &nam="BraggIon")
G4double GetElectronicDEDX(G4int idx, G4double energy) const 
G4double StoppingPower(const G4Material *material, G4double kineticEnergy)
G4double GetKineticEnergy() const 
CLHEP::Hep3Vector G4ThreeVector
G4bool HasMaterial(const G4Material *material)
virtual void CorrectionsAlongStep(const G4MaterialCutsCouple *, const G4DynamicParticle *, G4double &eloss, G4double &niel, G4double length)
G4double EffectiveChargeSquareRatio(const G4ParticleDefinition *, const G4Material *, G4double kineticEnergy)
G4VEmAngularDistribution * GetAngularDistribution()
G4double GetDensity() const 
G4double GetParticleCharge(const G4ParticleDefinition *, const G4Material *, G4double kineticEnergy)
G4double EffectiveChargeCorrection(const G4ParticleDefinition *, const G4Material *, G4double kineticEnergy)
G4ParticleDefinition * GetDefinition() const 
G4double GetEffectiveZ(G4int idx) const 
G4VEmFluctuationModel * GetModelOfFluctuations()
const G4ElementVector * GetElementVector() const 
virtual G4double CrossSectionPerVolume(const G4Material *, const G4ParticleDefinition *, G4double kineticEnergy, G4double cutEnergy, G4double maxEnergy)
G4double theZieglerFactor
const G4String & GetParticleName() const 
const G4ParticleDefinition * particle
virtual G4double MinEnergyCut(const G4ParticleDefinition *, const G4MaterialCutsCouple *couple)
void SetHighEnergyLimit(G4double)
G4double GetTotalMomentum() const 
G4ParticleChangeForLoss * fParticleChange
virtual G4double GetParticleCharge(const G4ParticleDefinition *p, const G4Material *mat, G4double kineticEnergy)
G4GLOB_DLL std::ostream G4cout
virtual G4ThreeVector & SampleDirection(const G4DynamicParticle *dp, G4double finalTotalEnergy, G4int Z, const G4Material *)=0
G4double GetElectronDensity() const 
G4bool UseAngularGeneratorFlag() const 
G4double HeEffChargeSquare(G4double z, G4double kinEnergyInMeV) const 
G4EmCorrections * EmCorrections()
const G4ThreeVector & GetMomentumDirection() const 
G4double DEDX(const G4Material *material, G4double kineticEnergy)
void SetProposedKineticEnergy(G4double proposedKinEnergy)
const G4String & GetParticleType() const 
virtual void SampleSecondaries(std::vector< G4DynamicParticle * > *, const G4MaterialCutsCouple *, const G4DynamicParticle *, G4double tmin, G4double maxEnergy)
G4double ElectronicStoppingPower(G4double z, G4double kineticEnergy) const 
void SetProposedMomentumDirection(const G4ThreeVector &dir)
const G4double * GetAtomicNumDensityVector() const 
G4double G4Log(G4double x)
G4double G4Exp(G4double initial_x)
Exponential Function double precision. 
G4double GetTotNbOfAtomsPerVolume() const 
virtual void Initialise(const G4ParticleDefinition *, const G4DataVector &)
G4double GetPDGMass() const 
T max(const T t1, const T t2)
brief Return the largest of the two arguments 
G4double energy(const ThreeVector &p, const G4double m)
void SetAngularDistribution(G4VEmAngularDistribution *)
void SetParticle(const G4ParticleDefinition *p)
T min(const T t1, const T t2)
brief Return the smallest of the two arguments 
G4ParticleDefinition * theElectron
G4double GetMeanExcitationEnergy() const 
static G4Electron * Electron()
virtual G4double GetChargeSquareRatio(const G4ParticleDefinition *, const G4Material *, G4double kineticEnergy)
virtual G4double ComputeCrossSectionPerAtom(const G4ParticleDefinition *, G4double kineticEnergy, G4double Z, G4double A, G4double cutEnergy, G4double maxEnergy)
G4int GetIndex(const G4Material *) const 
size_t GetNumberOfElements() const 
virtual G4double ComputeCrossSectionPerElectron(const G4ParticleDefinition *, G4double kineticEnergy, G4double cutEnergy, G4double maxEnergy)
void SetDeexcitationFlag(G4bool val)
virtual ~G4BraggIonModel()
const G4Material * currentMaterial
virtual void SetParticleAndCharge(const G4ParticleDefinition *, G4double q2)
virtual G4double ComputeDEDXPerVolume(const G4Material *, const G4ParticleDefinition *, G4double kineticEnergy, G4double cutEnergy)
virtual G4double MaxSecondaryEnergy(const G4ParticleDefinition *, G4double kinEnergy)
G4ThreeVector GetMomentum() const 
const G4Material * GetMaterial() const 
G4int SelectRandomAtomNumber(const G4Material *)