math/test/git_issue_826.cpp
Nicholas McKibben 7ad016f34b
short-circuit overflow protection for M1 Mac clang (#827)
xref scipy/scipy#14901

Splits single if statement into two to avoid apparent clang short-circuit bug on M1 Mac platforms.

Co-authored-by: Matt Borland <matt@mattborland.com>
2022-10-12 15:03:13 -07:00

32 lines
979 B
C++

// Copyright Nicholas McKibben, 2022
// Use, modification and distribution are subject to the
// Boost Software License, Version 1.0. (See accompanying file
// LICENSE or copy at http://www.boost.org/LICENSE_1_0.txt)
#include <cfenv>
#include <iostream>
#include <boost/math/distributions/beta.hpp>
#include "math_unit_test.hpp"
#pragma STDC FENV_ACCESS ON
int main() {
constexpr double q {0.999995};
constexpr double a {2};
constexpr double b {99999};
std::feclearexcept(FE_ALL_EXCEPT);
boost::math::beta_distribution<double> d {a, b};
const auto ans = boost::math::quantile(d, q);
if(std::fetestexcept(FE_OVERFLOW)) {
std::cout << "overflow reported" << std::endl;
} else {
std::cout << "overflow not reported" << std::endl;
}
std::cout << std::setprecision(16) << "Ans is: " << ans << std::endl;
return 0;
CHECK_ULP_CLOSE(ans, 0.000149761910560502, 1);
}
// overflow reported
// Ans is: 0.000149761910560502