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

#include <G4BGGPionInelasticXS.hh>

+ Inheritance diagram for G4BGGPionInelasticXS:

Public Member Functions

 G4BGGPionInelasticXS (const G4ParticleDefinition *)
 
 ~G4BGGPionInelasticXS () final
 
G4bool IsElementApplicable (const G4DynamicParticle *, G4int Z, const G4Material *mat) final
 
G4bool IsIsoApplicable (const G4DynamicParticle *, G4int Z, G4int A, const G4Element *elm, const G4Material *mat) final
 
G4double GetElementCrossSection (const G4DynamicParticle *, G4int Z, const G4Material *mat) final
 
G4double GetIsoCrossSection (const G4DynamicParticle *, G4int Z, G4int A, const G4Isotope *iso=nullptr, const G4Element *elm=nullptr, const G4Material *mat=nullptr) final
 
void BuildPhysicsTable (const G4ParticleDefinition &) final
 
void CrossSectionDescription (std::ostream &) const final
 
G4BGGPionInelasticXSoperator= (const G4BGGPionInelasticXS &right)=delete
 
 G4BGGPionInelasticXS (const G4BGGPionInelasticXS &)=delete
 
- Public Member Functions inherited from G4VCrossSectionDataSet
 G4VCrossSectionDataSet (const G4String &nam="")
 
virtual ~G4VCrossSectionDataSet ()
 
G4double GetCrossSection (const G4DynamicParticle *, const G4Element *, const G4Material *mat=nullptr)
 
G4double ComputeCrossSection (const G4DynamicParticle *, const G4Element *, const G4Material *mat=nullptr)
 
virtual G4double ComputeCrossSectionPerElement (G4double kinEnergy, G4double loge, const G4ParticleDefinition *, const G4Element *, const G4Material *mat=nullptr)
 
virtual G4double ComputeIsoCrossSection (G4double kinEnergy, G4double loge, const G4ParticleDefinition *, G4int Z, G4int A, const G4Isotope *iso=nullptr, const G4Element *elm=nullptr, const G4Material *mat=nullptr)
 
virtual const G4IsotopeSelectIsotope (const G4Element *, G4double kinEnergy, G4double logE)
 
virtual void DumpPhysicsTable (const G4ParticleDefinition &)
 
virtual void SetVerboseLevel (G4int value)
 
G4double GetMinKinEnergy () const
 
void SetMinKinEnergy (G4double value)
 
G4double GetMaxKinEnergy () const
 
void SetMaxKinEnergy (G4double value)
 
bool ForAllAtomsAndEnergies () const
 
void SetForAllAtomsAndEnergies (G4bool val)
 
const G4StringGetName () const
 
void SetName (const G4String &nam)
 
G4VCrossSectionDataSetoperator= (const G4VCrossSectionDataSet &right)=delete
 
 G4VCrossSectionDataSet (const G4VCrossSectionDataSet &)=delete
 

Additional Inherited Members

- Protected Attributes inherited from G4VCrossSectionDataSet
G4int verboseLevel {0}
 
G4String name
 

Detailed Description

Definition at line 65 of file G4BGGPionInelasticXS.hh.

Constructor & Destructor Documentation

◆ G4BGGPionInelasticXS() [1/2]

G4BGGPionInelasticXS::G4BGGPionInelasticXS ( const G4ParticleDefinition * p)
explicit

Definition at line 61 of file G4BGGPionInelasticXS.cc.

62 : G4VCrossSectionDataSet("BarashenkovGlauberGribov")
63{
64 verboseLevel = 0;
65 fGlauberEnergy = 91.*CLHEP::GeV;
66 fLowEnergy = 20.*CLHEP::MeV;
67 fLowestEnergy = 1.*CLHEP::MeV;
68 SetMinKinEnergy(0.0);
70
71 fPion = new G4UPiNuclearCrossSection();
72 fGlauber = new G4ComponentGGHadronNucleusXsc();
73 fHadron = new G4HadronNucleonXsc();
74
75 fG4pow = G4Pow::GetInstance();
76
77 theProton = G4Proton::Proton();
78 thePiPlus = G4PionPlus::PionPlus();
79 isPiplus = (p == thePiPlus);
81
82 if (0 == theA[0]) { Initialise(); }
83}
static G4HadronicParameters * Instance()
static G4PionPlus * PionPlus()
Definition G4PionPlus.cc:93
static G4Pow * GetInstance()
Definition G4Pow.cc:41
static G4Proton * Proton()
Definition G4Proton.cc:90
G4VCrossSectionDataSet(const G4String &nam="")
void SetMaxKinEnergy(G4double value)
void SetMinKinEnergy(G4double value)
void SetForAllAtomsAndEnergies(G4bool val)

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

◆ ~G4BGGPionInelasticXS()

G4BGGPionInelasticXS::~G4BGGPionInelasticXS ( )
final

Definition at line 87 of file G4BGGPionInelasticXS.cc.

88{
89 delete fHadron;
90}

◆ G4BGGPionInelasticXS() [2/2]

G4BGGPionInelasticXS::G4BGGPionInelasticXS ( const G4BGGPionInelasticXS & )
delete

Member Function Documentation

◆ BuildPhysicsTable()

void G4BGGPionInelasticXS::BuildPhysicsTable ( const G4ParticleDefinition & p)
finalvirtual

Reimplemented from G4VCrossSectionDataSet.

Definition at line 176 of file G4BGGPionInelasticXS.cc.

177{
178 if(verboseLevel > 1) {
179 G4cout << "G4BGGPionInelasticXS::BuildPhysicsTable for "
180 << p.GetParticleName() << G4endl;
181 }
182 if(&p == G4PionPlus::PionPlus() || &p == G4PionMinus::PionMinus()) {
183 isPiplus = (&p == G4PionPlus::PionPlus());
184 } else {
186 ed << "This BGG cross section is applicable only to pions and not to "
187 << p.GetParticleName() << G4endl;
188 G4Exception("G4BGGPionInelasticXS::BuildPhysicsTable", "had001",
189 FatalException, ed);
190 }
191}
@ FatalException
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
std::ostringstream G4ExceptionDescription
#define G4endl
Definition G4ios.hh:67
G4GLOB_DLL std::ostream G4cout
const G4String & GetParticleName() const
static G4PionMinus * PionMinus()

◆ CrossSectionDescription()

void G4BGGPionInelasticXS::CrossSectionDescription ( std::ostream & outFile) const
finalvirtual

Reimplemented from G4VCrossSectionDataSet.

Definition at line 267 of file G4BGGPionInelasticXS.cc.

268{
269 outFile << "The Barashenkov-Glauber-Gribov cross section handles inelastic\n"
270 << "pion scattering from nuclei at all energies. The Barashenkov\n"
271 << "parameterization is used below 91 GeV and the Glauber-Gribov\n"
272 << "parameterization is used above 91 GeV.\n";
273}

◆ GetElementCrossSection()

G4double G4BGGPionInelasticXS::GetElementCrossSection ( const G4DynamicParticle * dp,
G4int Z,
const G4Material * mat )
finalvirtual

Reimplemented from G4VCrossSectionDataSet.

Definition at line 114 of file G4BGGPionInelasticXS.cc.

116{
117 // this method should be called only for Z > 1
118
119 G4double cross = 0.0;
120 G4double ekin = std::max(dp->GetKineticEnergy(), fLowestEnergy);
121 G4int Z = std::min(ZZ, 92);
122
123 if(1 == Z) {
124 cross = 1.0115*GetIsoCrossSection(dp,1,1);
125 } else if(ekin < fLowEnergy) {
126 cross = (isPiplus) ? theLowEPiPlus[Z]*CoulombFactorPiPlus(ekin, Z)
127 : theLowEPiMinus[Z]*FactorPiMinus(ekin);
128 } else if(ekin > fGlauberEnergy) {
129 cross = (isPiplus) ? theGlauberFacPiPlus[Z] : theGlauberFacPiMinus[Z];
130 cross *= fGlauber->GetInelasticGlauberGribov(dp, Z, theA[Z]);
131 } else {
132 cross = fPion->GetInelasticCrossSection(dp, Z, theA[Z]);
133 }
134#ifdef G4VERBOSE
135 if(verboseLevel > 1) {
136 G4cout << "G4BGGPionInelasticXS::GetCrossSection for "
138 << " Ekin(GeV)= " << dp->GetKineticEnergy()
139 << " in nucleus Z= " << Z << " A= " << theA[Z]
140 << " XS(b)= " << cross/barn
141 << G4endl;
142 }
143#endif
144 return cross;
145}
double G4double
Definition G4Types.hh:83
int G4int
Definition G4Types.hh:85
G4double GetIsoCrossSection(const G4DynamicParticle *, G4int Z, G4int A, const G4Isotope *iso=nullptr, const G4Element *elm=nullptr, const G4Material *mat=nullptr) final
G4ParticleDefinition * GetDefinition() const
G4double GetKineticEnergy() const

◆ GetIsoCrossSection()

G4double G4BGGPionInelasticXS::GetIsoCrossSection ( const G4DynamicParticle * dp,
G4int Z,
G4int A,
const G4Isotope * iso = nullptr,
const G4Element * elm = nullptr,
const G4Material * mat = nullptr )
finalvirtual

Reimplemented from G4VCrossSectionDataSet.

Definition at line 150 of file G4BGGPionInelasticXS.cc.

155{
156 // this method should be called only for Z = 1
157 fHadron->HadronNucleonXscNS(dp->GetDefinition(), theProton,
158 dp->GetKineticEnergy());
159 G4double cross = A*fHadron->GetInelasticHadronNucleonXsc();
160
161#ifdef G4VERBOSE
162 if(verboseLevel > 1) {
163 G4cout << "G4BGGPionInelasticXS::GetCrossSection for "
165 << " Ekin(GeV)= " << dp->GetKineticEnergy()
166 << " in nucleus Z=1 A=" << A
167 << " XS(b)= " << cross/barn
168 << G4endl;
169 }
170#endif
171 return cross;
172}
const G4double A[17]

Referenced by GetElementCrossSection().

◆ IsElementApplicable()

G4bool G4BGGPionInelasticXS::IsElementApplicable ( const G4DynamicParticle * ,
G4int Z,
const G4Material * mat )
finalvirtual

Reimplemented from G4VCrossSectionDataSet.

Definition at line 95 of file G4BGGPionInelasticXS.cc.

97{
98 return true;
99}

◆ IsIsoApplicable()

G4bool G4BGGPionInelasticXS::IsIsoApplicable ( const G4DynamicParticle * ,
G4int Z,
G4int A,
const G4Element * elm,
const G4Material * mat )
finalvirtual

Reimplemented from G4VCrossSectionDataSet.

Definition at line 103 of file G4BGGPionInelasticXS.cc.

107{
108 return (1 == Z);
109}

◆ operator=()

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

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