// Copyright 2022 Hans Dembinski // // Distributed under the Boost Software License, Version 1.0. // (See accompanying file LICENSE_1_0.txt // or copy at http://www.boost.org/LICENSE_1_0.txt) #include #include #include #include #include "is_close.hpp" #include "throw_exception.hpp" using namespace boost::histogram::utility; using namespace boost::histogram::accumulators; int main() { const double atol = std::numeric_limits::epsilon(); wald_interval<> iv(deviation{1}); { const auto x = iv(0, 1); BOOST_TEST_IS_CLOSE(x.first, 0.0, atol); BOOST_TEST_IS_CLOSE(x.second, 0.0, atol); fraction<> f(0, 1); const auto y = iv(f); BOOST_TEST_IS_CLOSE(y.first, 0.0, atol); BOOST_TEST_IS_CLOSE(y.second, 0.0, atol); } { const auto x = iv(1, 0); BOOST_TEST_IS_CLOSE(x.first, 1.0, atol); BOOST_TEST_IS_CLOSE(x.second, 1.0, atol); fraction<> f(1, 0); const auto y = iv(f); BOOST_TEST_IS_CLOSE(y.first, 1.0, atol); BOOST_TEST_IS_CLOSE(y.second, 1.0, atol); } { const auto x = iv(5, 5); BOOST_TEST_IS_CLOSE(x.first, 0.341886116991581, atol); BOOST_TEST_IS_CLOSE(x.second, 0.658113883008419, atol); } { const auto x = iv(1, 9); BOOST_TEST_IS_CLOSE(x.first, 0.005131670194948618, atol); BOOST_TEST_IS_CLOSE(x.second, 0.1948683298050514, atol); } { const auto x = iv(9, 1); BOOST_TEST_IS_CLOSE(x.first, 0.8051316701949487, atol); BOOST_TEST_IS_CLOSE(x.second, 0.9948683298050514, atol); } return boost::report_errors(); }