From 3a76d5a768351a51fd51cac4ecf1fbbdbd0392fc Mon Sep 17 00:00:00 2001 From: Brian Ward Date: Fri, 29 Nov 2024 10:54:40 -0500 Subject: [PATCH] Also catch exceptions in MAD calculation --- src/stan/mcmc/chainset.hpp | 6 +++++- src/test/unit/mcmc/chainset_test.cpp | 4 ++++ 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/src/stan/mcmc/chainset.hpp b/src/stan/mcmc/chainset.hpp index 68256b6c0d..5da70fd924 100644 --- a/src/stan/mcmc/chainset.hpp +++ b/src/stan/mcmc/chainset.hpp @@ -268,7 +268,11 @@ class chainset { auto center = median(index); Eigen::MatrixXd abs_dev = (draws.array() - center).abs(); Eigen::Map map(abs_dev.data(), abs_dev.size()); - return 1.4826 * stan::math::quantile(map, 0.5); + try { + return 1.4826 * stan::math::quantile(map, 0.5); + } catch (const std::logic_error& e) { + return std::numeric_limits::quiet_NaN(); + } } /** diff --git a/src/test/unit/mcmc/chainset_test.cpp b/src/test/unit/mcmc/chainset_test.cpp index b7ed38baa0..1c61c2c3c8 100644 --- a/src/test/unit/mcmc/chainset_test.cpp +++ b/src/test/unit/mcmc/chainset_test.cpp @@ -225,6 +225,9 @@ TEST_F(McmcChains, quantile_tests) { EXPECT_TRUE(std::isnan(stepsize_quantiles(i))); } + double stepsize_MAD = datagen_chains.med_abs_deviation("stepsize__"); + EXPECT_TRUE(std::isnan(stepsize_MAD)); + Eigen::VectorXd bad_probs(3); bad_probs << 5, 50, 95; Eigen::VectorXd y_sim_quantiles @@ -232,4 +235,5 @@ TEST_F(McmcChains, quantile_tests) { for (size_t i = 0; i < bad_probs.size(); ++i) { EXPECT_TRUE(std::isnan(y_sim_quantiles(i))); } + }