Functions | |
double | sample (double a, double x, Random *random) |
double | value (double a, double x) |
This namespace offers functions related to the Voigt profile, which is a probability distribution given by a convolution of a Cauchy-Lorentz distribution and a Gaussian distribution.
double VoigtProfile::sample | ( | double | a, |
double | x, | ||
Random * | random | ||
) |
This function samples a random value from the probability distribution
where
We use the method described by Zheng et al. 2002 (ApJ, 578, 33-42, appendix), a variation of which is also used by many other authors including Tasitsiomi 2006 (ApJ, 645, 792-813), Laursen et al. 2009 (ApJ, 696, 853-869), Smith et al. 2015 (MNRAS, 449, 4336–4362) and Michel-Dansac et al. 2020 (A&A). The method is based on the rejection technique for sampling from a probability distribution. One could use the comparison function
Because of the peculiar shape of
where
where
The acceptance fractions are required to be
Finally, for larger values of
double VoigtProfile::value | ( | double | a, |
double | x | ||
) |
This function returns (an approximation to) the value of the Voigt function
where
0.03 | 0.967029 |
0.01 | 0.988815 |
! 0.001 | 0.998873 |
! 0.0001 | 0.999887 |
We use the approximation provided by Smith et al. 2015 (MNRAS, 449, 4336–4362) in their Appendix A1 and Table A1. According to the authors and as confirmed in the analysis by Michel-Dansac et al. 2020 (A&A), this approximation is accurate to within 1 per cent for all