|
Geant4 11.4.0
Toolkit for the simulation of the passage of particles through matter
|
#include <MCGIDI_distributions.hpp>
Public Member Functions | |
| LUPI_HOST_DEVICE | IncoherentElasticTNSL () |
| LUPI_HOST | IncoherentElasticTNSL (GIDI::DoubleDifferentialCrossSection::n_ThermalNeutronScatteringLaw::IncoherentElastic const *a_incoherentElasticTNSL, SetupInfo &a_setupInfo) |
| LUPI_HOST_DEVICE | ~IncoherentElasticTNSL () |
| template<typename RNG> | |
| LUPI_HOST_DEVICE void | sample (double a_energy, Sampling::Input &a_input, RNG &&a_rng) const |
| template<typename RNG> | |
| LUPI_HOST_DEVICE double | angleBiasing (Reaction const *a_reaction, double a_temperature, double a_energy_in, double a_mu_lab, RNG &&a_rng, double &a_energy_out) const |
| LUPI_HOST_DEVICE void | serialize (LUPI::DataBuffer &a_buffer, LUPI::DataBuffer::Mode a_mode) |
| Functions::Function1d * | DebyeWallerIntegral () |
| Functions::Function1d const * | DebyeWallerIntegral () const |
| template<typename RNG> | |
| LUPI_HOST_DEVICE double | angleBiasing (LUPI_maybeUnused Reaction const *a_reaction, double a_temperature, double a_energy_in, double a_mu_lab, LUPI_maybeUnused RNG &&a_rng, double &a_energy_out) const |
| Public Member Functions inherited from MCGIDI::Distributions::Distribution | |
| LUPI_HOST_DEVICE | Distribution () |
| LUPI_HOST | Distribution (Type a_type, GIDI::Distributions::Distribution const &a_distribution, SetupInfo &a_setupInfo) |
| LUPI_HOST | Distribution (Type a_type, GIDI::Frame a_productFrame, SetupInfo &a_setupInfo) |
| LUPI_HOST_DEVICE MCGIDI_VIRTUAL_FUNCTION | ~Distribution () MCGIDI_TRUE_VIRTUAL |
| LUPI_HOST_DEVICE Type | type () const |
| LUPI_HOST_DEVICE GIDI::Frame | productFrame () const |
| LUPI_HOST_DEVICE double | projectileMass () const |
| LUPI_HOST_DEVICE double | targetMass () const |
| LUPI_HOST_DEVICE double | productMass () const |
| LUPI_HOST void | setModelDBRC_data (Sampling::Upscatter::ModelDBRC_data *a_modelDBRC_data) |
| template<typename RNG> | |
| LUPI_HOST_DEVICE MCGIDI_VIRTUAL_FUNCTION void | sample (double a_X, Sampling::Input &a_input, RNG &&a_rng) const MCGIDI_TRUE_VIRTUAL |
| template<typename RNG> | |
| LUPI_HOST_DEVICE MCGIDI_VIRTUAL_FUNCTION double | angleBiasing (Reaction const *a_reaction, double a_temperature, double a_energy_in, double a_mu_lab, RNG &&a_rng, double &a_energy_out) const MCGIDI_TRUE_VIRTUAL |
| LUPI_HOST_DEVICE void | serialize (LUPI::DataBuffer &a_buffer, LUPI::DataBuffer::Mode a_mode) |
| template<typename RNG> | |
| LUPI_HOST_DEVICE void | sample (double a_X, MCGIDI::Sampling::Input &a_input, RNG &&a_rng) const |
| template<typename RNG> | |
| LUPI_HOST_DEVICE double | angleBiasing (Reaction const *a_reaction, double a_temperature, double a_energy_in, double a_mu_lab, RNG &&a_rng, double &a_energy_out) const |
This class represents the distribution for an outgoing product whose distribution is TNSL incoherent elastic scattering. This class samples directly from the Debye/Waller function.
Definition at line 409 of file MCGIDI_distributions.hpp.
| LUPI_HOST_DEVICE MCGIDI::Distributions::IncoherentElasticTNSL::IncoherentElasticTNSL | ( | ) |
Constructor for the IncoherentElasticTNSL class.
Definition at line 1337 of file MCGIDI_distributions.cc.
| LUPI_HOST MCGIDI::Distributions::IncoherentElasticTNSL::IncoherentElasticTNSL | ( | GIDI::DoubleDifferentialCrossSection::n_ThermalNeutronScatteringLaw::IncoherentElastic const * | a_incoherentElasticTNSL, |
| SetupInfo & | a_setupInfo ) |
Constructor for the IncoherentElasticTNSL class.
| a_incoherentElasticTNSL | [in] GIDI::IncoherentElastic instance containing the Debye/Waller data. |
| a_setupInfo | [in] Used internally when constructing a Protare to pass information to other constructors. |
Definition at line 1350 of file MCGIDI_distributions.cc.
|
inline |
Definition at line 419 of file MCGIDI_distributions.hpp.
| LUPI_HOST_DEVICE double MCGIDI::Distributions::IncoherentElasticTNSL::angleBiasing | ( | LUPI_maybeUnused Reaction const * | a_reaction, |
| double | a_temperature, | ||
| double | a_energy_in, | ||
| double | a_mu_lab, | ||
| LUPI_maybeUnused RNG && | a_rng, | ||
| double & | a_energy_out ) const |
Returns the probability for a projectile with energy a_energy_in to cause a particle to be emitted at angle a_mu_lab as seen in the lab frame. a_energy_out is the sampled outgoing energy.
| a_reaction | [in] The reaction containing the particle which this distribution describes. |
| a_temperature | [in] The temperature of the material. |
| a_energy_in | [in] The energy of the incident particle. |
| a_mu_lab | [in] The desired mu in the lab frame for the emitted particle. |
| a_rng | [in] The random number generator function that returns a double in the range [0, 1.0). |
| a_energy_out | [in] The energy of the emitted outgoing particle. |
Definition at line 1532 of file MCGIDI_headerSource.hpp.
| LUPI_HOST_DEVICE double MCGIDI::Distributions::IncoherentElasticTNSL::angleBiasing | ( | Reaction const * | a_reaction, |
| double | a_temperature, | ||
| double | a_energy_in, | ||
| double | a_mu_lab, | ||
| RNG && | a_rng, | ||
| double & | a_energy_out ) const |
|
inline |
Definition at line 428 of file MCGIDI_distributions.hpp.
|
inline |
Definition at line 429 of file MCGIDI_distributions.hpp.
| LUPI_HOST_DEVICE void MCGIDI::Distributions::IncoherentElasticTNSL::sample | ( | double | a_energy, |
| Sampling::Input & | a_input, | ||
| RNG && | a_rng ) const |
This method samples the outgoing neutron data for incoherent elastic TSNL from the Debye/Waller function.
| a_energy | [in] The energy of the projectile. |
| a_input | [in] Sample options requested by user. |
| a_rng | [in] The random number generator function that returns a double in the range [0, 1.0). |
Definition at line 1494 of file MCGIDI_headerSource.hpp.
| LUPI_HOST_DEVICE void MCGIDI::Distributions::IncoherentElasticTNSL::serialize | ( | LUPI::DataBuffer & | a_buffer, |
| LUPI::DataBuffer::Mode | a_mode ) |
This method serializes this for broadcasting as needed for MPI and GPUs. The method can count the number of required bytes, pack this or unpack this depending on a_mode.
| a_buffer | [in] The buffer to read or write data to depending on a_mode. |
| a_mode | [in] Specifies the action of this method. |
Definition at line 1371 of file MCGIDI_distributions.cc.