From 9828b47637e31fce4c682ec42e5a3016d866d378 Mon Sep 17 00:00:00 2001 From: Daniel Weindl Date: Fri, 25 Oct 2024 09:14:45 +0200 Subject: [PATCH] Fix problem ID and output in benchmark collection tests (#2570) * Reference value wasn't found for Fiedler_BMCSystBiol2016, because it was recently renamed * Print all rows from gradient check results --- tests/benchmark-models/benchmark_models.yaml | 2 +- .../benchmark-models/test_petab_benchmark.py | 29 +++++++++++++------ 2 files changed, 21 insertions(+), 10 deletions(-) diff --git a/tests/benchmark-models/benchmark_models.yaml b/tests/benchmark-models/benchmark_models.yaml index 8550c9ca38..2fed74cf3f 100644 --- a/tests/benchmark-models/benchmark_models.yaml +++ b/tests/benchmark-models/benchmark_models.yaml @@ -57,7 +57,7 @@ Elowitz_Nature2000: t_adj: 0.11 note: benchmark collection reference value matches up to sign when applying log10-correction +sum(log(meas*log(10))) / 2 -Fiedler_BMC2016: +Fiedler_BMCSystBiol2016: llh: 58.58390161681 t_sim: 0.005 t_fwd: 0.05 diff --git a/tests/benchmark-models/test_petab_benchmark.py b/tests/benchmark-models/test_petab_benchmark.py index b4e1f50e68..b055f8961f 100644 --- a/tests/benchmark-models/test_petab_benchmark.py +++ b/tests/benchmark-models/test_petab_benchmark.py @@ -35,11 +35,19 @@ from petab.v1.visualize import plot_problem -logger = get_logger(f"amici.{__name__}", logging.WARNING) +# Enable various debug output +debug = False + +logger = get_logger( + f"amici.{__name__}", logging.DEBUG if debug else logging.INFO +) script_dir = Path(__file__).parent.absolute() repo_root = script_dir.parent.parent benchmark_outdir = repo_root / "test_bmc" +debug_path = script_dir / "debug" +if debug: + debug_path.mkdir(exist_ok=True, parents=True) # reference values for simulation times and log-likelihoods references_yaml = script_dir / "benchmark_models.yaml" @@ -225,12 +233,6 @@ class GradientCheckSettings: ) -debug = False -if debug: - debug_path = Path(__file__).parent / "debug" - debug_path.mkdir(exist_ok=True, parents=True) - - @pytest.fixture(scope="session", params=problems, ids=problems) def benchmark_problem(request): """Fixture providing model and PEtab problem for a problem from @@ -570,9 +572,18 @@ def assert_gradient_check_success( df["rtol_success"] = df["rel_diff"] <= rtol max_adiff = df["abs_diff"].max() max_rdiff = df["rel_diff"].max() - with pd.option_context("display.max_columns", None, "display.width", None): + + success_fail = "succeeded" if check_result.success else "failed" + with pd.option_context( + "display.max_columns", + None, + "display.width", + None, + "display.max_rows", + None, + ): message = ( - f"Gradient check failed:\n{df}\n\n" + f"Gradient check {success_fail}:\n{df}\n\n" f"Maximum absolute difference: {max_adiff} (tolerance: {atol})\n" f"Maximum relative difference: {max_rdiff} (tolerance: {rtol})" )