From 37ba5a4b026a244f8c12f7fb842beb2ed24dd8fd Mon Sep 17 00:00:00 2001 From: Ryan Date: Tue, 25 Jul 2023 15:08:04 -0400 Subject: [PATCH 1/4] change kolmogorov quantile Newton ub from max to 1 --- include/boost/math/distributions/kolmogorov_smirnov.hpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/include/boost/math/distributions/kolmogorov_smirnov.hpp b/include/boost/math/distributions/kolmogorov_smirnov.hpp index 0365b69838..6ae80632d3 100644 --- a/include/boost/math/distributions/kolmogorov_smirnov.hpp +++ b/include/boost/math/distributions/kolmogorov_smirnov.hpp @@ -382,7 +382,7 @@ inline RealType quantile(const kolmogorov_smirnov_distribution std::uintmax_t m = policies::get_max_root_iterations(); // and max iterations. return tools::newton_raphson_iterate(detail::kolmogorov_smirnov_quantile_functor(dist, p), - k, RealType(0), boost::math::tools::max_value(), get_digits, m); + k, RealType(0), RealType(1), get_digits, m); } // quantile template @@ -407,7 +407,7 @@ inline RealType quantile(const complemented2_type(dist, p), - k, RealType(0), boost::math::tools::max_value(), get_digits, m); + k, RealType(0), RealType(1), get_digits, m); } // quantile (complemented) template From b612afa2f6fa2c86abf13e44b68a650464b74bdd Mon Sep 17 00:00:00 2001 From: Ryan Date: Tue, 25 Jul 2023 15:09:37 -0400 Subject: [PATCH 2/4] remove no longer needed newton step size logic --- include/boost/math/tools/roots.hpp | 9 +-------- 1 file changed, 1 insertion(+), 8 deletions(-) diff --git a/include/boost/math/tools/roots.hpp b/include/boost/math/tools/roots.hpp index 9fd7bee488..791ec1a7e5 100644 --- a/include/boost/math/tools/roots.hpp +++ b/include/boost/math/tools/roots.hpp @@ -275,14 +275,7 @@ T newton_raphson_iterate(F f, T guess, T min, T max, int digits, std::uintmax_t& if (fabs(delta * 2) > fabs(delta2)) { // Last two steps haven't converged. - T shift = (delta > 0) ? (result - min) / 2 : (result - max) / 2; - if ((result != 0) && (fabs(shift) > fabs(result))) - { - delta = sign(delta) * fabs(result) * 1.1f; // Protect against huge jumps! - //delta = sign(delta) * result; // Protect against huge jumps! Failed for negative result. https://github.com/boostorg/math/issues/216 - } - else - delta = shift; + delta = (delta > 0) ? (result - min) / 2 : (result - max) / 2; // reset delta1/2 so we don't take this branch next time round: delta1 = 3 * delta; delta2 = 3 * delta; From 6bf51258904fc0b7e99e55adf353a44442a3f867 Mon Sep 17 00:00:00 2001 From: Ryan Date: Tue, 25 Jul 2023 18:44:42 -0400 Subject: [PATCH 3/4] add infinity skew test back --- test/test_roots.cpp | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/test/test_roots.cpp b/test/test_roots.cpp index dda14c2e6f..e4e68e24b8 100644 --- a/test/test_roots.cpp +++ b/test/test_roots.cpp @@ -654,6 +654,10 @@ BOOST_AUTO_TEST_CASE( test_main ) test_beta(0.1, "double"); + // bug reports: + boost::math::skew_normal_distribution<> dist(2.0, 1.0, -2.5); + BOOST_CHECK(boost::math::isfinite(quantile(dist, 0.075))); + #if !defined(BOOST_NO_CXX11_AUTO_DECLARATIONS) && !defined(BOOST_NO_CXX11_UNIFIED_INITIALIZATION_SYNTAX) && !defined(BOOST_NO_CXX11_LAMBDAS) test_complex_newton>(); test_complex_newton>(); From e7ada7f6fe30f777bf42af69ffbb6542b134e588 Mon Sep 17 00:00:00 2001 From: Ryan Date: Tue, 25 Jul 2023 18:45:20 -0400 Subject: [PATCH 4/4] do not use Inf for Newton Bounds --- include/boost/math/distributions/skew_normal.hpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/include/boost/math/distributions/skew_normal.hpp b/include/boost/math/distributions/skew_normal.hpp index c2843fea1c..0f0ffea8a8 100644 --- a/include/boost/math/distributions/skew_normal.hpp +++ b/include/boost/math/distributions/skew_normal.hpp @@ -676,8 +676,8 @@ namespace boost{ namespace math{ // refine the result by numerically searching the root of (p-cdf) - const RealType search_min = range(dist).first; - const RealType search_max = range(dist).second; + const RealType search_min = support(dist).first; + const RealType search_max = support(dist).second; const int get_digits = policies::digits();// get digits from policy, std::uintmax_t m = policies::get_max_root_iterations(); // and max iterations.