From f6d10e26151194b25ef36a71cc079c5d252e6d0f Mon Sep 17 00:00:00 2001 From: Dmitry Ivanov <32366373+DIvanov503@users.noreply.github.com> Date: Mon, 26 Aug 2024 11:32:09 +0300 Subject: [PATCH] Compute missing tuples in transitive closure (#718) Co-authored-by: Dmitry Ivanov --- .../wmm/analysis/NativeRelationAnalysis.java | 33 +++++-------------- 1 file changed, 9 insertions(+), 24 deletions(-) diff --git a/dartagnan/src/main/java/com/dat3m/dartagnan/wmm/analysis/NativeRelationAnalysis.java b/dartagnan/src/main/java/com/dat3m/dartagnan/wmm/analysis/NativeRelationAnalysis.java index 1333ececf3..2f9ec76059 100644 --- a/dartagnan/src/main/java/com/dat3m/dartagnan/wmm/analysis/NativeRelationAnalysis.java +++ b/dartagnan/src/main/java/com/dat3m/dartagnan/wmm/analysis/NativeRelationAnalysis.java @@ -1064,7 +1064,7 @@ private Map computeViltualAddressMap() { program.getThreadEvents(MemoryCoreEvent.class).forEach(e -> { Set s = e.getAddress().getMemoryObjects().stream() .filter(VirtualMemoryObject.class::isInstance) - .map(o -> (VirtualMemoryObject)o) + .map(o -> (VirtualMemoryObject) o) .collect(Collectors.toSet()); if (s.size() > 1) { throw new UnsupportedOperationException( @@ -1622,30 +1622,15 @@ public Delta visitTransitiveClosure(TransitiveClosure trans) { } private EventGraph computeTransitiveClosure(EventGraph oldOuter, EventGraph inner, boolean isMay) { - EventGraph next; EventGraph outer = new EventGraph(oldOuter); - outer.addAll(inner); - for (EventGraph current = inner; !current.isEmpty(); current = next) { - next = new EventGraph(); - for (Event e1 : current.getDomain()) { - Set update = new HashSet<>(); - for (Event e2 : current.getRange(e1)) { - if (isMay) { - update.addAll(outer.getRange(e2)); - } else { - boolean implies = exec.isImplied(e1, e2); - update.addAll(outer.getRange(e2).stream() - .filter(e -> implies || exec.isImplied(e, e2)) - .toList()); - } - } - Set known = outer.getRange(e1); - update.removeIf(e -> known.contains(e) || exec.areMutuallyExclusive(e1, e)); - if (!update.isEmpty()) { - next.addRange(e1, update); - } - } - outer.addAll(next); + EventGraph update = inner.filter(outer::add); + EventGraph updateComposition = new EventGraph(); + computeComposition(updateComposition, inner, oldOuter, isMay); + update.addAll(updateComposition.filter(outer::add)); + while (!update.isEmpty()) { + EventGraph t = new EventGraph(); + computeComposition(t, inner, update, isMay); + update = t.filter(outer::add); } return outer; }