From ac532566e73ac3f2ca3dedb69fb4ecd2dee1a42e Mon Sep 17 00:00:00 2001 From: George Bisbas Date: Wed, 17 May 2023 16:28:09 +0100 Subject: [PATCH] compiler: Switch to alternative solution --- devito/ir/clusters/algorithms.py | 10 ++-------- tests/test_subdomains.py | 6 +++--- 2 files changed, 5 insertions(+), 11 deletions(-) diff --git a/devito/ir/clusters/algorithms.py b/devito/ir/clusters/algorithms.py index a860a77bc37..af8eee97cf1 100644 --- a/devito/ir/clusters/algorithms.py +++ b/devito/ir/clusters/algorithms.py @@ -238,14 +238,8 @@ def guard(clusters): if cd._factor is not None: k = d else: - dims = pull_dims(cd.condition) - # If `cd` uses more dimensions than the ispace, - # stay under parent - if (not dims.issubset(set(c.ispace.dimensions)) and - cd.parent in dims): - k = cd.parent - else: - k = max(dims, default=d, key=lambda i: c.ispace.index(i)) + dims = pull_dims(cd.condition, flag=False) + k = max(dims, default=d, key=lambda i: c.ispace.index(i)) # Pull `cd` from any expr condition = guards.setdefault(k, []) diff --git a/tests/test_subdomains.py b/tests/test_subdomains.py index 170b852a1aa..ef6dda9c3fd 100644 --- a/tests/test_subdomains.py +++ b/tests/test_subdomains.py @@ -697,7 +697,7 @@ class Dummy(SubDomainSet): class TestSubDomain_w_condition(object): - def test_condition_w_subdomain(self): + def test_condition_w_subdomain_v0(self): shape = (10, ) grid = Grid(shape=shape) @@ -728,7 +728,7 @@ def define(self, dimensions): assert_structure(op, ['i1x'], 'i1x') - def test_condition_w_subdomain_II(self): + def test_condition_w_subdomain_v1(self): shape = (10, 10) grid = Grid(shape=shape) @@ -760,7 +760,7 @@ def define(self, dimensions): assert_structure(op, ['xi1y'], 'xi1y') - def test_condition_w_subdomain_III(self): + def test_condition_w_subdomain_v2(self): shape = (10, 10) grid = Grid(shape=shape)