// 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; template void test() { const T atol = 0.001; clopper_pearson_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.841, 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.841, atol); } { const auto x = iv(1, 0); BOOST_TEST_IS_CLOSE(x.first, 0.158, 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, 0.158, atol); BOOST_TEST_IS_CLOSE(y.second, 1.0, atol); } { const auto x = iv(5, 5); BOOST_TEST_IS_CLOSE(x.first, 0.304, atol); BOOST_TEST_IS_CLOSE(x.second, 0.695, atol); } { const auto x = iv(1, 9); BOOST_TEST_IS_CLOSE(x.first, 0.017, atol); BOOST_TEST_IS_CLOSE(x.second, 0.294, atol); } { const auto x = iv(9, 1); BOOST_TEST_IS_CLOSE(x.first, 0.705, atol); BOOST_TEST_IS_CLOSE(x.second, 0.982, atol); } } int main() { test(); test(); return boost::report_errors(); }