|
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 | EnergyAngularMC () |
| LUPI_HOST | EnergyAngularMC (GIDI::Distributions::EnergyAngularMC const &a_energyAngularMC, SetupInfo &a_setupInfo) |
| LUPI_HOST_DEVICE | ~EnergyAngularMC () |
| LUPI_HOST_DEVICE Probabilities::ProbabilityBase2d_d1 * | energy () const |
| LUPI_HOST_DEVICE Probabilities::ProbabilityBase3d * | angularGivenEnergy () const |
| template<typename RNG> | |
| LUPI_HOST_DEVICE void | sample (double a_X, 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) |
| template<typename RNG> | |
| LUPI_HOST_DEVICE double | angleBiasing (LUPI_maybeUnused Reaction const *a_reaction, LUPI_maybeUnused double a_temperature, double a_energy_in, double a_mu_lab, 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 particle where the distribution is give as P(E'|E) * P(mu|E,E') where E is the projectile's energy, E' is the product's outgoing energy, mu is the cosine of the product's outgoing angle relative to the projectile's velocity, P(E'|E) is the probability for E' given E and (P(mu|E,E') is the probability for mu given E and E'.
Definition at line 151 of file MCGIDI_distributions.hpp.
| LUPI_HOST_DEVICE MCGIDI::Distributions::EnergyAngularMC::EnergyAngularMC | ( | ) |
Default constructor used when broadcasting a Protare as needed by MPI or GPUs.
Definition at line 307 of file MCGIDI_distributions.cc.
| LUPI_HOST MCGIDI::Distributions::EnergyAngularMC::EnergyAngularMC | ( | GIDI::Distributions::EnergyAngularMC const & | a_energyAngularMC, |
| SetupInfo & | a_setupInfo ) |
| a_energyAngularMC | [in] The GIDI::Distributions::EnergyAngularMC instance whose data is to be used to construct this. |
| a_setupInfo | [in] Used internally when constructing a Protare to pass information to other constructors. |
Definition at line 318 of file MCGIDI_distributions.cc.
| LUPI_HOST_DEVICE MCGIDI::Distributions::EnergyAngularMC::~EnergyAngularMC | ( | ) |
Definition at line 328 of file MCGIDI_distributions.cc.
| LUPI_HOST_DEVICE double MCGIDI::Distributions::EnergyAngularMC::angleBiasing | ( | LUPI_maybeUnused Reaction const * | a_reaction, |
| LUPI_maybeUnused double | a_temperature, | ||
| double | a_energy_in, | ||
| double | a_mu_lab, | ||
| 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 773 of file MCGIDI_headerSource.hpp.
| LUPI_HOST_DEVICE double MCGIDI::Distributions::EnergyAngularMC::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 |
Returns the value of the m_angularGivenEnergy.
Definition at line 163 of file MCGIDI_distributions.hpp.
|
inline |
Returns the value of the m_energy.
Definition at line 162 of file MCGIDI_distributions.hpp.
Referenced by EnergyAngularMC().
| LUPI_HOST_DEVICE void MCGIDI::Distributions::EnergyAngularMC::sample | ( | double | a_X, |
| Sampling::Input & | a_input, | ||
| RNG && | a_rng ) const |
This method samples the outgoing product data by sampling the outgoing energy E' from the probability P(E'|E) and then samples mu from the probability P(mu|E,E'). It also samples the outgoing phi uniformly between 0 and 2 pi.
| a_X | [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 747 of file MCGIDI_headerSource.hpp.
| LUPI_HOST_DEVICE void MCGIDI::Distributions::EnergyAngularMC::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 342 of file MCGIDI_distributions.cc.