From a3b1c2bbb98f8b054e99adb519eaa5d31ac3d34f Mon Sep 17 00:00:00 2001 From: Daniel Weindl Date: Mon, 18 Dec 2023 16:51:20 +0100 Subject: [PATCH] Proper error message in case of unsupported state-dependent sigmas (#2239) State-dependent sigmas are currently not supported and result in compiler errors. Catch them before compilation and quit with a more informative error message. Closes #919 --- python/sdist/amici/de_export.py | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/python/sdist/amici/de_export.py b/python/sdist/amici/de_export.py index 2694f753ad..63c9c05072 100644 --- a/python/sdist/amici/de_export.py +++ b/python/sdist/amici/de_export.py @@ -2232,6 +2232,23 @@ def _compute_equation(self, name: str) -> None: else: raise ValueError(f"Unknown equation {name}") + if name in ("sigmay", "sigmaz"): + # check for states in sigma{y,z}, which is currently not supported + syms_x = self.sym("x") + syms_yz = self.sym(name.removeprefix("sigma")) + xs_in_sigma = {} + for sym_yz, eq_yz in zip(syms_yz, self._eqs[name]): + yz_free_syms = eq_yz.free_symbols + if tmp := {x for x in syms_x if x in yz_free_syms}: + xs_in_sigma[sym_yz] = tmp + if xs_in_sigma: + msg = ", ".join( + [f"{yz} depends on {xs}" for yz, xs in xs_in_sigma.items()] + ) + raise NotImplementedError( + f"State-dependent observables are not supported, but {msg}." + ) + if name == "root": # Events are processed after the model has been set up. # Equations are there, but symbols for roots must be added