|
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 | AngularTwoBody () |
| LUPI_HOST | AngularTwoBody (GIDI::Distributions::AngularTwoBody const &a_angularTwoBody, SetupInfo &a_setupInfo) |
| LUPI_HOST_DEVICE | ~AngularTwoBody () |
| LUPI_HOST_DEVICE double | residualMass () const |
| LUPI_HOST_DEVICE double | Q () const |
| LUPI_HOST_DEVICE Probabilities::ProbabilityBase2d_d1 * | angular () 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) |
| LUPI_HOST_DEVICE bool | Upscatter () const |
| LUPI_HOST void | setModelDBRC_data2 (Sampling::Upscatter::ModelDBRC_data *a_modelDBRC_data) |
| 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 product for a two-body interaction.
Definition at line 66 of file MCGIDI_distributions.hpp.
| LUPI_HOST_DEVICE MCGIDI::Distributions::AngularTwoBody::AngularTwoBody | ( | ) |
Base contructor.
Definition at line 120 of file MCGIDI_distributions.cc.
| LUPI_HOST MCGIDI::Distributions::AngularTwoBody::AngularTwoBody | ( | GIDI::Distributions::AngularTwoBody const & | a_angularTwoBody, |
| SetupInfo & | a_setupInfo ) |
| a_angularTwoBody | [in] The GIDI::Distributions::AngularTwoBody 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 135 of file MCGIDI_distributions.cc.
| LUPI_HOST_DEVICE MCGIDI::Distributions::AngularTwoBody::~AngularTwoBody | ( | ) |
Definition at line 152 of file MCGIDI_distributions.cc.
| LUPI_HOST_DEVICE double MCGIDI::Distributions::AngularTwoBody::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 | [out] The energy of the emitted outgoing particle. |
Definition at line 410 of file MCGIDI_headerSource.hpp.
| LUPI_HOST_DEVICE double MCGIDI::Distributions::AngularTwoBody::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_angular.
Definition at line 86 of file MCGIDI_distributions.hpp.
Referenced by AngularTwoBody().
|
inline |
Returns the value of the m_Q.
Definition at line 85 of file MCGIDI_distributions.hpp.
|
inline |
Returns the value of the m_residualMass.
Definition at line 84 of file MCGIDI_distributions.hpp.
| LUPI_HOST_DEVICE void MCGIDI::Distributions::AngularTwoBody::sample | ( | double | a_X, |
| Sampling::Input & | a_input, | ||
| RNG && | a_rng ) const |
This method samples the outgoing product data for the two outgoing particles in a two-body outgoing channel. First, is samples mu, the cosine of the product's outgoing angle, since this is for two-body interactions, mu is in the center-of-mass frame. It then calls kinetics_COMKineticEnergy2LabEnergyAndMomentum.
| a_X | [in] The energy of the projectile in the lab frame. |
| 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 366 of file MCGIDI_headerSource.hpp.
| LUPI_HOST_DEVICE void MCGIDI::Distributions::AngularTwoBody::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 166 of file MCGIDI_distributions.cc.
| LUPI_HOST void MCGIDI::Distributions::AngularTwoBody::setModelDBRC_data2 | ( | Sampling::Upscatter::ModelDBRC_data * | a_modelDBRC_data | ) |
This method sets this m_modelDBRC_data to a_modelDBRC_data. It also deletes the current m_modelDBRC_data member.
| a_modelDBRC_data | [in] The instance storing data needed to treat the DRRC upscatter mode. |
Definition at line 184 of file MCGIDI_distributions.cc.
|
inline |
Returns the value of the m_Upscatter.
Definition at line 93 of file MCGIDI_distributions.hpp.