Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4ComponentGGNuclNuclXsc Class Reference

#include <G4ComponentGGNuclNuclXsc.hh>

+ Inheritance diagram for G4ComponentGGNuclNuclXsc:

Public Member Functions

 G4ComponentGGNuclNuclXsc ()
 
 ~G4ComponentGGNuclNuclXsc () override
 
G4double GetTotalElementCrossSection (const G4ParticleDefinition *aParticle, G4double kinEnergy, G4int Z, G4double A) final
 
G4double GetTotalIsotopeCrossSection (const G4ParticleDefinition *aParticle, G4double kinEnergy, G4int Z, G4int A) final
 
G4double GetInelasticElementCrossSection (const G4ParticleDefinition *aParticle, G4double kinEnergy, G4int Z, G4double A) final
 
G4double GetInelasticIsotopeCrossSection (const G4ParticleDefinition *aParticle, G4double kinEnergy, G4int Z, G4int A) final
 
G4double GetElasticElementCrossSection (const G4ParticleDefinition *aParticle, G4double kinEnergy, G4int Z, G4double A) final
 
G4double GetElasticIsotopeCrossSection (const G4ParticleDefinition *aParticle, G4double kinEnergy, G4int Z, G4int A) final
 
G4double ComputeQuasiElasticRatio (const G4ParticleDefinition *aParticle, G4double kinEnergy, G4int Z, G4int A) final
 
void BuildPhysicsTable (const G4ParticleDefinition &) final
 
void DumpPhysicsTable (const G4ParticleDefinition &) final
 
void Description (std::ostream &) const final
 
G4double GetZandACrossSection (const G4DynamicParticle *, G4int Z, G4int A)
 
G4double GetCoulombBarier (const G4DynamicParticle *, G4double Z, G4double A, G4double pR, G4double tR)
 
G4double ComputeCoulombBarier (const G4ParticleDefinition *aParticle, G4double kinEnergy, G4int Z, G4int A, G4double pR, G4double tR)
 
G4double GetRatioSD (const G4DynamicParticle *, G4double At, G4double Zt)
 
G4double GetRatioQE (const G4DynamicParticle *, G4double At, G4double Zt)
 
G4double GetElasticGlauberGribov (const G4DynamicParticle *, G4int Z, G4int A)
 
G4double GetInelasticGlauberGribov (const G4DynamicParticle *, G4int Z, G4int A)
 
G4double GetTotalGlauberGribovXsc () const
 
G4double GetElasticGlauberGribovXsc () const
 
G4double GetInelasticGlauberGribovXsc () const
 
G4double GetProductionGlauberGribovXsc () const
 
G4double GetDiffractionGlauberGribovXsc () const
 
G4ComponentGGNuclNuclXscoperator= (const G4ComponentGGNuclNuclXsc &right)=delete
 
 G4ComponentGGNuclNuclXsc (const G4ComponentGGNuclNuclXsc &)=delete
 
- Public Member Functions inherited from G4VComponentCrossSection
 G4VComponentCrossSection (const G4String &nam="")
 
virtual ~G4VComponentCrossSection ()
 
G4double GetTotalElementCrossSection (const G4ParticleDefinition *, G4double kinEnergy, const G4Element *)
 
G4double GetInelasticElementCrossSection (const G4ParticleDefinition *, G4double kinEnergy, const G4Element *)
 
G4double GetElasticElementCrossSection (const G4ParticleDefinition *, G4double kinEnergy, const G4Element *)
 
void SetVerboseLevel (G4int value)
 
G4int GetVerboseLevel () const
 
G4double GetMinKinEnergy () const
 
void SetMinKinEnergy (G4double value)
 
G4double GetMaxKinEnergy () const
 
void SetMaxKinEnergy (G4double value)
 
const G4StringGetName () const
 

Detailed Description

Definition at line 52 of file G4ComponentGGNuclNuclXsc.hh.

Constructor & Destructor Documentation

◆ G4ComponentGGNuclNuclXsc() [1/2]

G4ComponentGGNuclNuclXsc::G4ComponentGGNuclNuclXsc ( )

Definition at line 47 of file G4ComponentGGNuclNuclXsc.cc.

48 : G4VComponentCrossSection("Glauber-Gribov Nucl-nucl")
49{
50 theProton = G4Proton::Proton();
51 theNeutron = G4Neutron::Neutron();
52 theLambda = G4Lambda::Lambda();
53 fHNXsc = new G4HadronNucleonXsc();
54 fHadrNucl = new G4ComponentGGHadronNucleusXsc();
55}
static G4Lambda * Lambda()
Definition G4Lambda.cc:105
static G4Neutron * Neutron()
Definition G4Neutron.cc:101
static G4Proton * Proton()
Definition G4Proton.cc:90
G4VComponentCrossSection(const G4String &nam="")

Referenced by G4ComponentGGNuclNuclXsc(), and operator=().

◆ ~G4ComponentGGNuclNuclXsc()

G4ComponentGGNuclNuclXsc::~G4ComponentGGNuclNuclXsc ( )
override

Definition at line 57 of file G4ComponentGGNuclNuclXsc.cc.

58{
59 delete fHNXsc;
60}

◆ G4ComponentGGNuclNuclXsc() [2/2]

G4ComponentGGNuclNuclXsc::G4ComponentGGNuclNuclXsc ( const G4ComponentGGNuclNuclXsc & )
delete

Member Function Documentation

◆ BuildPhysicsTable()

void G4ComponentGGNuclNuclXsc::BuildPhysicsTable ( const G4ParticleDefinition & )
finalvirtual

Reimplemented from G4VComponentCrossSection.

Definition at line 135 of file G4ComponentGGNuclNuclXsc.cc.

136{}

◆ ComputeCoulombBarier()

G4double G4ComponentGGNuclNuclXsc::ComputeCoulombBarier ( const G4ParticleDefinition * aParticle,
G4double kinEnergy,
G4int Z,
G4int A,
G4double pR,
G4double tR )

Definition at line 241 of file G4ComponentGGNuclNuclXsc.cc.

245{
246 G4int pZ = aParticle->GetPDGCharge()*inve;
247 G4double pM = aParticle->GetPDGMass();
249 G4double pElab = pTkin + pM;
250 G4double totEcm = std::sqrt(pM*pM + tM*tM + 2.*pElab*tM);
251 G4double totTcm = totEcm - pM -tM;
252
253 // 0.5 defines shape of Cross section correction
254 // at cB = totTcm it become zero
255 static const G4double qfact = 0.5*CLHEP::elm_coupling;
256 G4double bC = qfact*pZ*Z/(pR + tR);
257
258 G4double ratio = (totTcm <= bC) ? 0. : 1. - bC/totTcm;
259
260#ifdef G4VERBOSE
261 if (GetVerboseLevel() > 1) {
262 G4cout << "G4ComponentGGNuclNuclXsc::ComputeCoulombBarier(..)=" <<ratio
263 << "; pTkin(GeV)=" << pTkin/CLHEP::MeV
264 << " totTcm= " << totTcm/CLHEP::MeV<< "; bC=" << bC/CLHEP::MeV
265 << G4endl;
266 }
267#endif
268 return ratio;
269}
double G4double
Definition G4Types.hh:83
int G4int
Definition G4Types.hh:85
const G4double A[17]
#define G4endl
Definition G4ios.hh:67
G4GLOB_DLL std::ostream G4cout
static G4double GetNuclearMass(const G4double A, const G4double Z)

Referenced by GetCoulombBarier().

◆ ComputeQuasiElasticRatio()

G4double G4ComponentGGNuclNuclXsc::ComputeQuasiElasticRatio ( const G4ParticleDefinition * aParticle,
G4double kinEnergy,
G4int Z,
G4int A )
finalvirtual

Reimplemented from G4VComponentCrossSection.

Definition at line 124 of file G4ComponentGGNuclNuclXsc.cc.

127{
128 ComputeCrossSections(aParticle, kinEnergy, Z, A);
129 return (fInelasticXsc > fProductionXsc)
130 ? (fInelasticXsc - fProductionXsc)/fInelasticXsc : 0.0;
131}

◆ Description()

void G4ComponentGGNuclNuclXsc::Description ( std::ostream & outFile) const
finalvirtual

Reimplemented from G4VComponentCrossSection.

Definition at line 147 of file G4ComponentGGNuclNuclXsc.cc.

148{
149 outFile << "G4ComponentGGNuclNuclXsc calculates total, inelastic and\n"
150 << "elastic cross sections for nucleus-nucleus collisions using\n"
151 << "the Glauber model with Gribov corrections. It is valid for\n"
152 << "all incident energies above 100 keV./n"
153 << "For the hydrogen target G4HadronNucleonXsc class is used.\n";
154}

◆ DumpPhysicsTable()

void G4ComponentGGNuclNuclXsc::DumpPhysicsTable ( const G4ParticleDefinition & )
finalvirtual

Reimplemented from G4VComponentCrossSection.

Definition at line 140 of file G4ComponentGGNuclNuclXsc.cc.

141{
142 G4cout << "G4ComponentGGNuclNuclXsc: uses Glauber-Gribov formula" << G4endl;
143}

◆ GetCoulombBarier()

G4double G4ComponentGGNuclNuclXsc::GetCoulombBarier ( const G4DynamicParticle * dp,
G4double Z,
G4double A,
G4double pR,
G4double tR )
inline

Definition at line 174 of file G4ComponentGGNuclNuclXsc.hh.

177{
179 G4lrint(Z), G4lrint(A), pR, tR);
180}
G4double ComputeCoulombBarier(const G4ParticleDefinition *aParticle, G4double kinEnergy, G4int Z, G4int A, G4double pR, G4double tR)
G4ParticleDefinition * GetDefinition() const
G4double GetKineticEnergy() const
int G4lrint(double ad)
Definition templates.hh:134

◆ GetDiffractionGlauberGribovXsc()

G4double G4ComponentGGNuclNuclXsc::GetDiffractionGlauberGribovXsc ( ) const
inline

Definition at line 116 of file G4ComponentGGNuclNuclXsc.hh.

116{ return fDiffractionXsc; };

◆ GetElasticElementCrossSection()

G4double G4ComponentGGNuclNuclXsc::GetElasticElementCrossSection ( const G4ParticleDefinition * aParticle,
G4double kinEnergy,
G4int Z,
G4double A )
finalvirtual

Implements G4VComponentCrossSection.

Definition at line 104 of file G4ComponentGGNuclNuclXsc.cc.

107{
108 ComputeCrossSections(aParticle, kinEnergy, Z, G4lrint(A));
109 return fElasticXsc;
110}

◆ GetElasticGlauberGribov()

G4double G4ComponentGGNuclNuclXsc::GetElasticGlauberGribov ( const G4DynamicParticle * dp,
G4int Z,
G4int A )
inline

Definition at line 150 of file G4ComponentGGNuclNuclXsc.hh.

152{
153 ComputeCrossSections(dp->GetDefinition(), dp->GetKineticEnergy(), Z, A);
154 return fElasticXsc;
155}

◆ GetElasticGlauberGribovXsc()

G4double G4ComponentGGNuclNuclXsc::GetElasticGlauberGribovXsc ( ) const
inline

Definition at line 113 of file G4ComponentGGNuclNuclXsc.hh.

113{ return fElasticXsc; };

◆ GetElasticIsotopeCrossSection()

G4double G4ComponentGGNuclNuclXsc::GetElasticIsotopeCrossSection ( const G4ParticleDefinition * aParticle,
G4double kinEnergy,
G4int Z,
G4int A )
finalvirtual

Implements G4VComponentCrossSection.

Definition at line 114 of file G4ComponentGGNuclNuclXsc.cc.

117{
118 ComputeCrossSections(aParticle, kinEnergy, Z, A);
119 return fElasticXsc;
120}

◆ GetInelasticElementCrossSection()

G4double G4ComponentGGNuclNuclXsc::GetInelasticElementCrossSection ( const G4ParticleDefinition * aParticle,
G4double kinEnergy,
G4int Z,
G4double A )
finalvirtual

Implements G4VComponentCrossSection.

Definition at line 84 of file G4ComponentGGNuclNuclXsc.cc.

87{
88 ComputeCrossSections(aParticle, kinEnergy, Z, G4lrint(A));
89 return fInelasticXsc;
90}

◆ GetInelasticGlauberGribov()

G4double G4ComponentGGNuclNuclXsc::GetInelasticGlauberGribov ( const G4DynamicParticle * dp,
G4int Z,
G4int A )
inline

Definition at line 158 of file G4ComponentGGNuclNuclXsc.hh.

160{
161 ComputeCrossSections(dp->GetDefinition(), dp->GetKineticEnergy(), Z, A);
162 return fInelasticXsc;
163}

◆ GetInelasticGlauberGribovXsc()

G4double G4ComponentGGNuclNuclXsc::GetInelasticGlauberGribovXsc ( ) const
inline

Definition at line 114 of file G4ComponentGGNuclNuclXsc.hh.

114{ return fInelasticXsc; };

◆ GetInelasticIsotopeCrossSection()

G4double G4ComponentGGNuclNuclXsc::GetInelasticIsotopeCrossSection ( const G4ParticleDefinition * aParticle,
G4double kinEnergy,
G4int Z,
G4int A )
finalvirtual

Implements G4VComponentCrossSection.

Definition at line 94 of file G4ComponentGGNuclNuclXsc.cc.

97{
98 ComputeCrossSections(aParticle, kinEnergy, Z, A);
99 return fInelasticXsc;
100}

◆ GetProductionGlauberGribovXsc()

G4double G4ComponentGGNuclNuclXsc::GetProductionGlauberGribovXsc ( ) const
inline

Definition at line 115 of file G4ComponentGGNuclNuclXsc.hh.

115{ return fProductionXsc; };

◆ GetRatioQE()

G4double G4ComponentGGNuclNuclXsc::GetRatioQE ( const G4DynamicParticle * aParticle,
G4double At,
G4double Zt )

Definition at line 289 of file G4ComponentGGNuclNuclXsc.cc.

291{
292 ComputeCrossSections(aParticle->GetDefinition(),
293 aParticle->GetKineticEnergy(),
294 G4lrint(tZ), G4lrint(tA));
295
296 return (fInelasticXsc > 0.0) ? 1.0 - fProductionXsc/fInelasticXsc : 0.0;
297}

◆ GetRatioSD()

G4double G4ComponentGGNuclNuclXsc::GetRatioSD ( const G4DynamicParticle * aParticle,
G4double At,
G4double Zt )

Definition at line 275 of file G4ComponentGGNuclNuclXsc.cc.

277{
278 ComputeCrossSections(aParticle->GetDefinition(),
279 aParticle->GetKineticEnergy(),
280 G4lrint(tZ), G4lrint(tA));
281
282 return (fInelasticXsc > 0.0) ? fDiffractionXsc/fInelasticXsc : 0.0;
283}

◆ GetTotalElementCrossSection()

G4double G4ComponentGGNuclNuclXsc::GetTotalElementCrossSection ( const G4ParticleDefinition * aParticle,
G4double kinEnergy,
G4int Z,
G4double A )
finalvirtual

Implements G4VComponentCrossSection.

Definition at line 64 of file G4ComponentGGNuclNuclXsc.cc.

67{
68 ComputeCrossSections(aParticle, kinEnergy, Z, G4lrint(A));
69 return fTotalXsc;
70}

◆ GetTotalGlauberGribovXsc()

G4double G4ComponentGGNuclNuclXsc::GetTotalGlauberGribovXsc ( ) const
inline

Definition at line 112 of file G4ComponentGGNuclNuclXsc.hh.

112{ return fTotalXsc; };

◆ GetTotalIsotopeCrossSection()

G4double G4ComponentGGNuclNuclXsc::GetTotalIsotopeCrossSection ( const G4ParticleDefinition * aParticle,
G4double kinEnergy,
G4int Z,
G4int A )
finalvirtual

Implements G4VComponentCrossSection.

Definition at line 74 of file G4ComponentGGNuclNuclXsc.cc.

77{
78 ComputeCrossSections(aParticle, kinEnergy, Z, A);
79 return fTotalXsc;
80}

◆ GetZandACrossSection()

G4double G4ComponentGGNuclNuclXsc::GetZandACrossSection ( const G4DynamicParticle * dp,
G4int Z,
G4int A )
inline

Definition at line 166 of file G4ComponentGGNuclNuclXsc.hh.

168{
169 ComputeCrossSections(dp->GetDefinition(), dp->GetKineticEnergy(), Z, A);
170 return fInelasticXsc;
171}

◆ operator=()

G4ComponentGGNuclNuclXsc & G4ComponentGGNuclNuclXsc::operator= ( const G4ComponentGGNuclNuclXsc & right)
delete

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