|
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 | PairProductionGamma () |
| LUPI_HOST | PairProductionGamma (SetupInfo &a_setupInfo, bool a_firstSampled) |
| LUPI_HOST_DEVICE | ~PairProductionGamma () |
| 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 void | sample (LUPI_maybeUnused double a_X, Sampling::Input &a_input, RNG &&a_rng) const |
| template<typename RNG> | |
| LUPI_HOST_DEVICE double | angleBiasing (LUPI_maybeUnused Reaction const *a_reaction, LUPI_maybeUnused double a_temperature, LUPI_maybeUnused double a_energy_in, LUPI_maybeUnused 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 photon the is the result of an electron annihilating with a positron.
Definition at line 359 of file MCGIDI_distributions.hpp.
| LUPI_HOST_DEVICE MCGIDI::Distributions::PairProductionGamma::PairProductionGamma | ( | ) |
Basic constructor.
Definition at line 1177 of file MCGIDI_distributions.cc.
| LUPI_HOST MCGIDI::Distributions::PairProductionGamma::PairProductionGamma | ( | SetupInfo & | a_setupInfo, |
| bool | a_firstSampled ) |
| a_setupInfo | [in] Used internally when constructing a Protare to pass information to other constructors. |
| a_firstSampled | [in] FIX ME |
Definition at line 1187 of file MCGIDI_distributions.cc.
| LUPI_HOST_DEVICE MCGIDI::Distributions::PairProductionGamma::~PairProductionGamma | ( | ) |
Definition at line 1196 of file MCGIDI_distributions.cc.
| LUPI_HOST_DEVICE double MCGIDI::Distributions::PairProductionGamma::angleBiasing | ( | LUPI_maybeUnused Reaction const * | a_reaction, |
| LUPI_maybeUnused double | a_temperature, | ||
| LUPI_maybeUnused double | a_energy_in, | ||
| LUPI_maybeUnused 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 1407 of file MCGIDI_headerSource.hpp.
| LUPI_HOST_DEVICE double MCGIDI::Distributions::PairProductionGamma::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 MCGIDI::Distributions::PairProductionGamma::sample | ( | double | a_X, |
| Sampling::Input & | a_input, | ||
| RNG && | a_rng ) const |
| LUPI_HOST_DEVICE void MCGIDI::Distributions::PairProductionGamma::sample | ( | LUPI_maybeUnused double | a_X, |
| Sampling::Input & | a_input, | ||
| RNG && | a_rng ) const |
This method samples the outgoing photon by assigning the electron rest mass energy as the photon's energy and, if m_firstSampled is true, randomly picking mu and phi. If m_firstSampled is false, the previous sampled particle that filled in a_input must be the other sampled photon, then, the mu and phi for the second-sampled photon is such that it is back-to-back with the other photon.
| 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 1378 of file MCGIDI_headerSource.hpp.
| LUPI_HOST_DEVICE void MCGIDI::Distributions::PairProductionGamma::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 1209 of file MCGIDI_distributions.cc.