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

#include <G4NeutronInelasticXS.hh>

+ Inheritance diagram for G4NeutronInelasticXS:

Public Member Functions

 G4NeutronInelasticXS ()
 
 ~G4NeutronInelasticXS () override=default
 
G4bool IsElementApplicable (const G4DynamicParticle *, G4int Z, const G4Material *) final
 
G4bool IsIsoApplicable (const G4DynamicParticle *, G4int Z, G4int A, const G4Element *, const G4Material *) final
 
G4double GetElementCrossSection (const G4DynamicParticle *, G4int Z, const G4Material *) final
 
G4double ComputeCrossSectionPerElement (G4double kinEnergy, G4double loge, const G4ParticleDefinition *, const G4Element *, const G4Material *) final
 
G4double ComputeIsoCrossSection (G4double kinEnergy, G4double loge, const G4ParticleDefinition *, G4int Z, G4int A, const G4Isotope *iso, const G4Element *elm, const G4Material *mat) final
 
G4double GetIsoCrossSection (const G4DynamicParticle *, G4int Z, G4int A, const G4Isotope *iso, const G4Element *elm, const G4Material *mat) final
 
const G4IsotopeSelectIsotope (const G4Element *, G4double kinEnergy, G4double logE) final
 
void BuildPhysicsTable (const G4ParticleDefinition &) final
 
void CrossSectionDescription (std::ostream &) const final
 
G4double ElementCrossSection (G4double kinEnergy, G4double loge, G4int Z)
 
G4double IsoCrossSection (G4double ekin, G4double logekin, G4int Z, G4int A)
 
G4NeutronInelasticXSoperator= (const G4NeutronInelasticXS &right)=delete
 
 G4NeutronInelasticXS (const G4NeutronInelasticXS &)=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 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
 

Static Public Member Functions

static const char * Default_Name ()
 

Additional Inherited Members

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

Detailed Description

Definition at line 55 of file G4NeutronInelasticXS.hh.

Constructor & Destructor Documentation

◆ G4NeutronInelasticXS() [1/2]

G4NeutronInelasticXS::G4NeutronInelasticXS ( )

Definition at line 69 of file G4NeutronInelasticXS.cc.

71 neutron(G4Neutron::Neutron()),
72 elimit(20*CLHEP::MeV),
73 lowElimit(1.0e-7*CLHEP::eV)
74{
75 verboseLevel = 0;
76 if (verboseLevel > 0) {
77 G4cout << "G4NeutronInelasticXS::G4NeutronInelasticXS Initialise for Z < "
78 << MAXZINEL << G4endl;
79 }
80 loglowElimit = G4Log(lowElimit);
81 if (nullptr == data) {
82 data = new G4ElementData(MAXZINEL);
83 data->SetName("nInelastic");
84 FindDirectoryPath();
85 }
86 ggXsection =
88 if(ggXsection == nullptr)
89 ggXsection = new G4ComponentGGHadronNucleusXsc();
90
92}
G4double G4Log(G4double x)
Definition G4Log.hh:227
#define G4endl
Definition G4ios.hh:67
G4GLOB_DLL std::ostream G4cout
G4VComponentCrossSection * GetComponentCrossSection(const G4String &name)
static G4CrossSectionDataSetRegistry * Instance()
static const char * Default_Name()
static G4Neutron * Neutron()
Definition G4Neutron.cc:101
G4VCrossSectionDataSet(const G4String &nam="")
void SetForAllAtomsAndEnergies(G4bool val)

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

◆ ~G4NeutronInelasticXS()

G4NeutronInelasticXS::~G4NeutronInelasticXS ( )
overridedefault

◆ G4NeutronInelasticXS() [2/2]

G4NeutronInelasticXS::G4NeutronInelasticXS ( const G4NeutronInelasticXS & )
delete

Member Function Documentation

◆ BuildPhysicsTable()

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

Reimplemented from G4VCrossSectionDataSet.

Definition at line 297 of file G4NeutronInelasticXS.cc.

298{
299 if (verboseLevel > 0) {
300 G4cout << "G4NeutronInelasticXS::BuildPhysicsTable for "
301 << p.GetParticleName() << G4endl;
302 }
303 if (p.GetParticleName() != "neutron") {
305 ed << p.GetParticleName() << " is a wrong particle type -"
306 << " only neutron is allowed";
307 G4Exception("G4NeutronInelasticXS::BuildPhysicsTable(..)","had012",
308 FatalException, ed, "");
309 return;
310 }
311 // it is possible re-initialisation for the new run
313
314 // initialise static tables only once
315 std::call_once(applyOnce, [this]() { isInitializer = true; });
316
317 if (isInitializer) {
318 G4AutoLock l(&nInelasticXSMutex);
319
320 // Upload data for elements used in geometry
321 for ( auto const & elm : *table ) {
322 G4int Z = std::max( 1, std::min( elm->GetZasInt(), MAXZINEL-1) );
323 if ( nullptr == data->GetElementData(Z) ) { Initialise(Z); }
324 }
325 l.unlock();
326 }
327 // prepare isotope selection
328 std::size_t nIso = temp.size();
329 for ( auto const & elm : *table ) {
330 std::size_t n = elm->GetNumberOfIsotopes();
331 if (n > nIso) { nIso = n; }
332 }
333 temp.resize(nIso, 0.0);
334}
G4TemplateAutoLock< G4Mutex > G4AutoLock
std::vector< G4Element * > G4ElementTable
@ FatalException
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
std::ostringstream G4ExceptionDescription
int G4int
Definition G4Types.hh:85
static const G4ElementTable * GetElementTable()
Definition G4Element.cc:401
const G4String & GetParticleName() const

Referenced by G4InterfaceToXS::G4InterfaceToXS().

◆ ComputeCrossSectionPerElement()

G4double G4NeutronInelasticXS::ComputeCrossSectionPerElement ( G4double kinEnergy,
G4double loge,
const G4ParticleDefinition * ,
const G4Element * elm,
const G4Material *  )
finalvirtual

Reimplemented from G4VCrossSectionDataSet.

Definition at line 127 of file G4NeutronInelasticXS.cc.

131{
132 return ElementCrossSection(ekin, loge, elm->GetZasInt());
133}
G4int GetZasInt() const
Definition G4Element.hh:120
G4double ElementCrossSection(G4double kinEnergy, G4double loge, G4int Z)

◆ ComputeIsoCrossSection()

G4double G4NeutronInelasticXS::ComputeIsoCrossSection ( G4double kinEnergy,
G4double loge,
const G4ParticleDefinition * ,
G4int Z,
G4int A,
const G4Isotope * iso,
const G4Element * elm,
const G4Material * mat )
finalvirtual

Reimplemented from G4VCrossSectionDataSet.

Definition at line 174 of file G4NeutronInelasticXS.cc.

179{
180 return IsoCrossSection(ekin, loge, Z, A);
181}
const G4double A[17]
G4double IsoCrossSection(G4double ekin, G4double logekin, G4int Z, G4int A)

◆ CrossSectionDescription()

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

Reimplemented from G4VCrossSectionDataSet.

Definition at line 94 of file G4NeutronInelasticXS.cc.

95{
96 outFile << "G4NeutronInelasticXS calculates the neutron inelastic scattering\n"
97 << "cross section on nuclei using data from the high precision\n"
98 << "neutron database. These data are simplified and smoothed over\n"
99 << "the resonance region in order to reduce CPU time.\n"
100 << "For high energy Glauber-Gribov cross section model is used\n";
101}

◆ Default_Name()

static const char * G4NeutronInelasticXS::Default_Name ( )
inlinestatic

Definition at line 63 of file G4NeutronInelasticXS.hh.

63{ return "G4NeutronInelasticXS"; }

Referenced by G4INCLXXNeutronBuilder::Build(), G4NeutronCrossSectionXS::ConstructProcess(), and G4NeutronInelasticXS().

◆ ElementCrossSection()

G4double G4NeutronInelasticXS::ElementCrossSection ( G4double kinEnergy,
G4double loge,
G4int Z )

Definition at line 136 of file G4NeutronInelasticXS.cc.

137{
138 G4int Z = std::min(ZZ, MAXZINEL-1);
139 G4double ekin = eKin;
140 G4double loge = logE;
141 G4double xs;
142
143 // very low energy limit
144 if (ekin < lowElimit) {
145 ekin = lowElimit;
146 loge = loglowElimit;
147 }
148 // pv should exist
149 auto pv = GetPhysicsVector(Z);
150
151 const G4double e0 = pv->Energy(0);
152 if (ekin <= e0) {
153 xs = (*pv)[0];
154 if (xs > 0.0) { xs *= std::sqrt(e0/ekin); }
155 } else if (ekin <= pv->GetMaxEnergy()) {
156 xs = pv->LogVectorValue(ekin, loge);
157 } else {
158 xs = coeff[Z]*ggXsection->GetInelasticElementCrossSection(neutron, ekin,
159 Z, aeff[Z]);
160 }
161
162#ifdef G4VERBOSE
163 if(verboseLevel > 1) {
164 G4cout << "G4NeutronInelasticXS::ElementCrossSection Z= " << Z
165 << " Ekin(MeV)= " << ekin/CLHEP::MeV
166 << ", ElmXSinel(b)= " << xs/CLHEP::barn
167 << G4endl;
168 }
169#endif
170 return xs;
171}
double G4double
Definition G4Types.hh:83

Referenced by ComputeCrossSectionPerElement(), GetElementCrossSection(), and IsoCrossSection().

◆ GetElementCrossSection()

G4double G4NeutronInelasticXS::GetElementCrossSection ( const G4DynamicParticle * aParticle,
G4int Z,
const G4Material *  )
finalvirtual

Reimplemented from G4VCrossSectionDataSet.

Definition at line 119 of file G4NeutronInelasticXS.cc.

121{
122 return ElementCrossSection(aParticle->GetKineticEnergy(),
123 aParticle->GetLogKineticEnergy(), Z);
124}
G4double GetLogKineticEnergy() const
G4double GetKineticEnergy() const

◆ GetIsoCrossSection()

G4double G4NeutronInelasticXS::GetIsoCrossSection ( const G4DynamicParticle * aParticle,
G4int Z,
G4int A,
const G4Isotope * iso,
const G4Element * elm,
const G4Material * mat )
finalvirtual

Reimplemented from G4VCrossSectionDataSet.

Definition at line 184 of file G4NeutronInelasticXS.cc.

188{
189 return IsoCrossSection(aParticle->GetKineticEnergy(),
190 aParticle->GetLogKineticEnergy(), Z, A);
191}

◆ IsElementApplicable()

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

Reimplemented from G4VCrossSectionDataSet.

Definition at line 104 of file G4NeutronInelasticXS.cc.

106{
107 return true;
108}

◆ IsIsoApplicable()

G4bool G4NeutronInelasticXS::IsIsoApplicable ( const G4DynamicParticle * ,
G4int Z,
G4int A,
const G4Element * ,
const G4Material *  )
finalvirtual

Reimplemented from G4VCrossSectionDataSet.

Definition at line 111 of file G4NeutronInelasticXS.cc.

114{
115 return true;
116}

◆ IsoCrossSection()

G4double G4NeutronInelasticXS::IsoCrossSection ( G4double ekin,
G4double logekin,
G4int Z,
G4int A )

Definition at line 194 of file G4NeutronInelasticXS.cc.

196{
197 G4double xs;
198 G4int Z = std::min(ZZ, MAXZINEL-1);
199 G4double ekin = eKin;
200 G4double loge = logE;
201
202 /*
203 G4cout << "G4NeutronInelasticXS::IsoCrossSection Z= "
204 << Z << " A= " << A << G4endl;
205 G4cout << " Amin= " << amin[Z] << " Amax= " << amax[Z]
206 << " E(MeV)= " << ekin << " Ncomp="
207 << data->GetNumberOfComponents(Z) << G4endl;
208 */
209 GetPhysicsVector(Z);
210
211 // use isotope cross section if applicable
212 if (ekin <= elimit && data->GetNumberOfComponents(Z) > 0) {
213 auto pviso = data->GetComponentDataByID(Z, A);
214 if (nullptr != pviso) {
215 const G4double e0 = pviso->Energy(0);
216 if (ekin > e0) {
217 xs = pviso->LogVectorValue(ekin, loge);
218 } else {
219 xs = (*pviso)[0];
220 if (xs > 0.0) { xs *= std::sqrt(e0/ekin); }
221 }
222#ifdef G4VERBOSE
223 if(verboseLevel > 1) {
224 G4cout << "G4NeutronInelasticXS::IsoXS: Ekin(MeV)= "
225 << ekin/CLHEP::MeV
226 << " xs(b)= " << xs/CLHEP::barn
227 << " Z= " << Z << " A= " << A << G4endl;
228 }
229#endif
230 return xs;
231 }
232 }
233
234 // use element x-section
235 xs = ElementCrossSection(ekin, loge, Z)*A/aeff[Z];
236
237#ifdef G4VERBOSE
238 if(verboseLevel > 1) {
239 G4cout << "G4NeutronInelasticXS::IsoXS: Z= " << Z << " A= " << A
240 << " Ekin(MeV)= " << ekin/CLHEP::MeV
241 << ", ElmXS(b)= " << xs/CLHEP::barn << G4endl;
242 }
243#endif
244 return xs;
245}

Referenced by ComputeIsoCrossSection(), GetIsoCrossSection(), and SelectIsotope().

◆ operator=()

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

◆ SelectIsotope()

const G4Isotope * G4NeutronInelasticXS::SelectIsotope ( const G4Element * anElement,
G4double kinEnergy,
G4double logE )
finalvirtual

Reimplemented from G4VCrossSectionDataSet.

Definition at line 247 of file G4NeutronInelasticXS.cc.

249{
250 std::size_t nIso = anElement->GetNumberOfIsotopes();
251 const G4Isotope* iso = anElement->GetIsotope(0);
252 if(1 == nIso) { return iso; }
253
254 // more than 1 isotope
255 G4int Z = anElement->GetZasInt();
256 if (nullptr == data->GetElementData(Z)) { InitialiseOnFly(Z); }
257
258 const G4double* abundVector = anElement->GetRelativeAbundanceVector();
260 G4double sum = 0.0;
261 std::size_t j;
262
263 // isotope wise cross section not available
264 if (Z >= MAXZINEL || 0 == data->GetNumberOfComponents(Z)) {
265 for (j=0; j<nIso; ++j) {
266 sum += abundVector[j];
267 if(q <= sum) {
268 iso = anElement->GetIsotope((G4int)j);
269 break;
270 }
271 }
272 return iso;
273 }
274
275 // use isotope cross sections
276 auto nn = temp.size();
277 if(nn < nIso) { temp.resize(nIso, 0.); }
278
279 for (j=0; j<nIso; ++j) {
280 // G4cout << j << "-th isotope " << anElement->GetIsotope(j)->GetN()
281 // << " abund= " << abundVector[j] << G4endl;
282 sum += abundVector[j]*IsoCrossSection(kinEnergy, logE, Z,
283 anElement->GetIsotope((G4int)j)->GetN());
284 temp[j] = sum;
285 }
286 sum *= q;
287 for (j = 0; j<nIso; ++j) {
288 if (temp[j] >= sum) {
289 iso = anElement->GetIsotope((G4int)j);
290 break;
291 }
292 }
293 return iso;
294}
#define G4UniformRand()
Definition Randomize.hh:52
G4double * GetRelativeAbundanceVector() const
Definition G4Element.hh:149
std::size_t GetNumberOfIsotopes() const
Definition G4Element.hh:143
const G4Isotope * GetIsotope(G4int iso) const
Definition G4Element.hh:151
G4int GetN() const
Definition G4Isotope.hh:83

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