diff --git a/python/dune/perftool/pdelab/localoperator.py b/python/dune/perftool/pdelab/localoperator.py index 9cb31a248f39c3ce733bce3172a5ac50cea936ad..271432b5ffcc6ed63136ef2d2b1d258ab3b397bc 100644 --- a/python/dune/perftool/pdelab/localoperator.py +++ b/python/dune/perftool/pdelab/localoperator.py @@ -505,8 +505,16 @@ def extract_kernel_from_cache(tag, wrap_in_cgen=True): # Precompute all the substrules for sr in substrules: try: - kernel = lp.precompute(kernel, sr.name) - except: + tmpname = "precompute_{}".format(sr.name) + kernel = lp.precompute(kernel, + sr.name, + temporary_name=tmpname, + ) + # Vectorization strategies are actually very likely to eliminate the + # precomputation temporary. To avoid the temporary elimination warning + # we need to explicitly disable it. + kernel = kernel.copy(silenced_warnings=kernel.silenced_warnings + ["temp_to_write({})".format(tmpname)]) + except RunTimeError: pass from loopy import make_reduction_inames_unique