BornAgain  1.19.0
Simulate and fit neutron and x-ray scattering at grazing incidence
Distribution2DGaussSampler Class Reference
Inheritance diagram for Distribution2DGaussSampler:
[legend]
Collaboration diagram for Distribution2DGaussSampler:
[legend]

Public Member Functions

 Distribution2DGaussSampler (double omega_x, double omega_y)
 
std::pair< double, double > randomSample () const final
 

Private Attributes

double m_omega_x
 
double m_omega_y
 

Detailed Description

Definition at line 45 of file IDistribution2DSampler.h.

Constructor & Destructor Documentation

◆ Distribution2DGaussSampler()

Distribution2DGaussSampler::Distribution2DGaussSampler ( double  omega_x,
double  omega_y 
)
inline

Definition at line 47 of file IDistribution2DSampler.h.

48  : m_omega_x(omega_x), m_omega_y(omega_y)
49  {
50  }

Member Function Documentation

◆ randomSample()

std::pair< double, double > Distribution2DGaussSampler::randomSample ( ) const
finalvirtual

Implements IDistribution2DSampler.

Definition at line 140 of file IDistribution2DSampler.cpp.

141 {
142  std::random_device rd; // random device class instance
143  std::mt19937 gen(rd()); // Standard mersenne_twister_engine seeded with rd()
144  std::uniform_real_distribution<double> uniformDist(0.0, 1.0);
145 
146  double cdf_value_phi = uniformDist(gen);
147 
148  // Use ITS and solve for phi from the cdf of radial (phi) distribution
149  double phi = std::sqrt(-2 * std::log(1 - cdf_value_phi));
150  double alpha = 2 * M_PI * uniformDist(gen);
151  return std::make_pair(m_omega_x * phi * std::cos(alpha), m_omega_y * phi * std::sin(alpha));
152 }
#define M_PI
Definition: Constants.h:44

References m_omega_x, m_omega_y, and M_PI.

Member Data Documentation

◆ m_omega_x

double Distribution2DGaussSampler::m_omega_x
private

Definition at line 54 of file IDistribution2DSampler.h.

Referenced by randomSample().

◆ m_omega_y

double Distribution2DGaussSampler::m_omega_y
private

Definition at line 54 of file IDistribution2DSampler.h.

Referenced by randomSample().


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