#include <G4KokoulinMuonNuclearXS.hh>
 | 
|   | G4KokoulinMuonNuclearXS () | 
|   | 
| virtual  | ~G4KokoulinMuonNuclearXS () | 
|   | 
| virtual void  | CrossSectionDescription (std::ostream &) const | 
|   | 
| G4bool  | IsElementApplicable (const G4DynamicParticle *particle, G4int Z, const G4Material *) | 
|   | 
| G4double  | GetElementCrossSection (const G4DynamicParticle *particle, G4int Z, const G4Material *) | 
|   | 
| void  | BuildPhysicsTable (const G4ParticleDefinition &) | 
|   | 
| void  | BuildCrossSectionTable () | 
|   | 
| G4double  | ComputeDDMicroscopicCrossSection (G4double incidentKE, G4double Z, G4double A, G4double epsilon) | 
|   | 
|   | G4VCrossSectionDataSet (const G4String &nam="") | 
|   | 
| virtual  | ~G4VCrossSectionDataSet () | 
|   | 
| virtual G4bool  | IsIsoApplicable (const G4DynamicParticle *, G4int Z, G4int A, const G4Element *elm=0, const G4Material *mat=0) | 
|   | 
| G4double  | GetCrossSection (const G4DynamicParticle *, const G4Element *, const G4Material *mat=0) | 
|   | 
| G4double  | ComputeCrossSection (const G4DynamicParticle *, const G4Element *, const G4Material *mat=0) | 
|   | 
| virtual G4double  | GetIsoCrossSection (const G4DynamicParticle *, G4int Z, G4int A, const G4Isotope *iso=0, const G4Element *elm=0, const G4Material *mat=0) | 
|   | 
| virtual G4Isotope *  | SelectIsotope (const G4Element *, G4double kinEnergy) | 
|   | 
| virtual void  | DumpPhysicsTable (const G4ParticleDefinition &) | 
|   | 
| virtual G4int  | GetVerboseLevel () const | 
|   | 
| virtual void  | SetVerboseLevel (G4int value) | 
|   | 
| G4double  | GetMinKinEnergy () const | 
|   | 
| void  | SetMinKinEnergy (G4double value) | 
|   | 
| G4double  | GetMaxKinEnergy () const | 
|   | 
| void  | SetMaxKinEnergy (G4double value) | 
|   | 
| const G4String &  | GetName () const | 
|   | 
Definition at line 53 of file G4KokoulinMuonNuclearXS.hh.
 
◆ G4KokoulinMuonNuclearXS() [1/2]
      
        
          | G4KokoulinMuonNuclearXS::G4KokoulinMuonNuclearXS  | 
          ( | 
           | ) | 
           | 
        
      
 
Definition at line 59 of file G4KokoulinMuonNuclearXS.cc.
G4double HighestKineticEnergy
 
G4VCrossSectionDataSet(const G4String &nam="")
 
static const char * Default_Name()
 
G4double LowestKineticEnergy
 
 
 
 
◆ ~G4KokoulinMuonNuclearXS()
  
  
      
        
          | G4KokoulinMuonNuclearXS::~G4KokoulinMuonNuclearXS  | 
          ( | 
           | ) | 
           | 
         
       
   | 
  
virtual   | 
  
 
 
◆ G4KokoulinMuonNuclearXS() [2/2]
◆ BuildCrossSectionTable()
      
        
          | void G4KokoulinMuonNuclearXS::BuildCrossSectionTable  | 
          ( | 
           | ) | 
           | 
        
      
 
Definition at line 108 of file G4KokoulinMuonNuclearXS.cc.
  117   for (
G4int j = 0; j < nEl; j++) {
   118     Z = 
G4lrint((*theElementTable)[j]->GetZ());
 G4double HighestKineticEnergy
 
G4double ComputeMicroscopicCrossSection(G4double incidentKE, G4double A)
 
static G4NistManager * Instance()
 
double A(double temperature)
 
static size_t GetNumberOfElements()
 
void PutValue(size_t index, G4double theValue)
 
static G4PhysicsVector * theCrossSection[MAXZMUN]
 
G4double Energy(size_t index) const
 
std::vector< G4Element * > G4ElementTable
 
static G4ElementTable * GetElementTable()
 
G4double GetAtomicMassAmu(const G4String &symb) const
 
G4double LowestKineticEnergy
 
 
 
 
◆ BuildPhysicsTable()
◆ ComputeDDMicroscopicCrossSection()
Definition at line 179 of file G4KokoulinMuonNuclearXS.cc.
  191   G4double TotalEnergy = KineticEnergy + ParticleMass;
   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;
 static const double microbarn
 
double A(double temperature)
 
G4double G4Log(G4double x)
 
G4double G4Exp(G4double initial_x)
Exponential Function double precision. 
 
G4double GetPDGMass() const
 
static G4MuonMinus * MuonMinus()
 
double epsilon(double density, double temperature)
 
 
 
 
◆ ComputeMicroscopicCrossSection()
Definition at line 134 of file G4KokoulinMuonNuclearXS.cc.
  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.; }
 
G4double ComputeDDMicroscopicCrossSection(G4double incidentKE, G4double Z, G4double A, G4double epsilon)
 
double A(double temperature)
 
G4double G4Log(G4double x)
 
G4double G4Exp(G4double initial_x)
Exponential Function double precision. 
 
G4double GetPDGMass() const
 
static G4MuonMinus * MuonMinus()
 
 
 
 
◆ CrossSectionDescription()
  
  
      
        
          | void G4KokoulinMuonNuclearXS::CrossSectionDescription  | 
          ( | 
          std::ostream &  | 
          outFile | ) | 
           const | 
         
       
   | 
  
virtual   | 
  
 
Reimplemented from G4VCrossSectionDataSet.
Definition at line 77 of file G4KokoulinMuonNuclearXS.cc.
   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" ;
  
 
 
◆ Default_Name()
  
  
      
        
          | static const char* G4KokoulinMuonNuclearXS::Default_Name  | 
          ( | 
           | ) | 
           | 
         
       
   | 
  
inlinestatic   | 
  
 
 
◆ GetElementCrossSection()
◆ IsElementApplicable()
◆ operator=()
◆ CutFixed
  
  
      
        
          | G4double G4KokoulinMuonNuclearXS::CutFixed | 
         
       
   | 
  
private   | 
  
 
 
◆ HighestKineticEnergy
  
  
      
        
          | G4double G4KokoulinMuonNuclearXS::HighestKineticEnergy | 
         
       
   | 
  
private   | 
  
 
 
◆ isInitialized
  
  
      
        
          | G4bool G4KokoulinMuonNuclearXS::isInitialized | 
         
       
   | 
  
private   | 
  
 
 
◆ isMaster
  
  
      
        
          | G4bool G4KokoulinMuonNuclearXS::isMaster | 
         
       
   | 
  
private   | 
  
 
 
◆ LowestKineticEnergy
  
  
      
        
          | G4double G4KokoulinMuonNuclearXS::LowestKineticEnergy | 
         
       
   | 
  
private   | 
  
 
 
◆ theCrossSection
◆ TotBin
  
  
      
        
          | G4int G4KokoulinMuonNuclearXS::TotBin | 
         
       
   | 
  
private   | 
  
 
 
The documentation for this class was generated from the following files: