61   LowestKineticEnergy(1*
GeV), HighestKineticEnergy(1*
PeV),
 
   69       delete theCrossSection[i];
 
   70       theCrossSection[i] = 0;
 
   79     outFile << 
"G4KokoulinMuonNuclearXS provides the total inelastic\n" 
   80     << 
"cross section for mu- and mu+ interactions with nuclei.\n" 
   81     << 
"R. Kokoulin's approximation of the Borog and Petrukhin double\n" 
   82     << 
"differential cross section at high energy and low Q**2 is integrated\n" 
   83     << 
"over the muon energy loss to get the total cross section as a\n" 
   84     << 
"function of muon kinetic energy\n" ;
 
  101       if(theCrossSection[i]) { 
return; }
 
  117   for (
G4int j = 0; j < nEl; j++) {
 
  118     Z = 
G4lrint((*theElementTable)[j]->GetZ());
 
  120     if(Z < 
MAXZMUN && !theCrossSection[Z]) {
 
  122                           HighestKineticEnergy, 
 
  124       for (
G4int i = 0; i <= TotBin; ++i) {
 
  125     energy = theCrossSection[
Z]->
Energy(i);
 
  126     Value = ComputeMicroscopicCrossSection(energy, A);
 
  140     {0.0199,0.1017,0.2372,0.4083,0.5917,0.7628,0.8983,0.9801};
 
  142     {0.0506,0.1112,0.1569,0.1813,0.1813,0.1569,0.1112,0.0506};
 
  149   if (KineticEnergy <= CutFixed) 
return CrossSection; 
 
  153   if (epmax <= epmin) 
return CrossSection; 
 
  163   for (
G4int l = 0; l < kkk; ++l) {
 
  165     for (
G4int ll = 0; ll < 8; ++ll) {
 
  173   CrossSection *= hhh ;
 
  174   if (CrossSection < 0.) { CrossSection = 0.; }
 
  191   G4double TotalEnergy = KineticEnergy + ParticleMass;
 
  196       (epsilon <= CutFixed) ) { 
return DCrossSection; }
 
  205   G4double mass2 = ParticleMass*ParticleMass;
 
  207   G4double up = TotalEnergy*TotalEnergy*v1/mass2*(1.+mass2*v2/(alam2*v1));
 
  210   DCrossSection = coeffn*aeff*sigph/epsilon*
 
  211                   (-v1+(v1+0.5*v2*(1.+2.*mass2/alam2))*
G4Log(up/down));
 
  213   if (DCrossSection < 0.) { DCrossSection = 0.; }
 
  214   return DCrossSection;
 
G4double GetKineticEnergy() const 
 
static const G4double ak2
 
G4double ComputeDDMicroscopicCrossSection(G4double incidentKE, G4double Z, G4double A, G4double epsilon)
 
virtual void CrossSectionDescription(std::ostream &) const 
 
static G4NistManager * Instance()
 
double A(double temperature)
 
static size_t GetNumberOfElements()
 
G4double GetElementCrossSection(const G4DynamicParticle *particle, G4int Z, const G4Material *)
 
static const G4double ak1
 
void PutValue(size_t index, G4double theValue)
 
static constexpr double PeV
 
G4double Energy(size_t index) const 
 
G4bool IsElementApplicable(const G4DynamicParticle *particle, G4int Z, const G4Material *)
 
G4double Value(G4double theEnergy, size_t &lastidx) const 
 
G4double G4Log(G4double x)
 
G4double G4Exp(G4double initial_x)
Exponential Function double precision. 
 
#define G4_DECLARE_XS_FACTORY(cross_section)
 
virtual ~G4KokoulinMuonNuclearXS()
 
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)
 
G4KokoulinMuonNuclearXS()
 
G4double GetAtomicMassAmu(const G4String &symb) const 
 
static constexpr double GeV
 
void BuildCrossSectionTable()
 
static G4MuonMinus * MuonMinus()
 
static constexpr double pi
 
void BuildPhysicsTable(const G4ParticleDefinition &)
 
std::vector< G4Element * > G4ElementTable
 
static G4ElementTable * GetElementTable()
 
double epsilon(double density, double temperature)
 
static constexpr double microbarn