From e707ee6348d1e7df6e1b6173f6d49ee81996bc19 Mon Sep 17 00:00:00 2001 From: jjenista Date: Sat, 2 Apr 2011 15:06:07 +0000 Subject: [PATCH] modified algorithm for dfj style parallelism --- .../DelaunayRefinement/DirectedEdgeGraph.java | 33 +-- .../oooJava/DelaunayRefinement/Node.java | 5 + .../SerialDelaunayRefinement.java | 191 +++++++++++------- .../oooJava/DelaunayRefinement/Subgraph.java | 11 + 4 files changed, 152 insertions(+), 88 deletions(-) diff --git a/Robust/src/Benchmarks/oooJava/DelaunayRefinement/DirectedEdgeGraph.java b/Robust/src/Benchmarks/oooJava/DelaunayRefinement/DirectedEdgeGraph.java index 9bc02ff0..05c8057f 100644 --- a/Robust/src/Benchmarks/oooJava/DelaunayRefinement/DirectedEdgeGraph.java +++ b/Robust/src/Benchmarks/oooJava/DelaunayRefinement/DirectedEdgeGraph.java @@ -1,8 +1,8 @@ public class DirectedEdgeGraph implements EdgeGraph { - HashSet nodes; + public DirectedEdgeGraph() { // nodes = Collections.synchronizedSet(new HashSet()); - nodes = new HashSet(); + // nodes = new HashSet(); } public boolean addEdge(Edge_d e) { @@ -90,16 +90,18 @@ public class DirectedEdgeGraph implements EdgeGraph { return retval; } - public Iterator iterator() { - return nodes.iterator(); - } + //public Iterator iterator() { + // return nodes.iterator(); + //} public boolean addNode(Node n) { - return nodes.add((EdgeGraphNode) n); + boolean notInAlready = !n.inGraph; + n.inGraph = true; + return notInAlready; } public boolean containsNode(Node n) { - return nodes.contains(n); + return n.inGraph; } public Object getNodeData(Node n) { @@ -107,14 +109,14 @@ public class DirectedEdgeGraph implements EdgeGraph { return egn.data; } - public int getNumNodes() { - return nodes.size(); - } + //public int getNumNodes() { + // return nodes.size(); + //} - public Node getRandom() { - // return (Node)Sets.getAny(nodes); - return (Node) nodes.iterator().next(); - } + //public Node getRandom() { + // // return (Node)Sets.getAny(nodes); + // return (Node) nodes.iterator().next(); + //} public boolean hasNeighbor(Node src, Node dest) { EdgeGraphNode esrc = (EdgeGraphNode) src; @@ -123,8 +125,9 @@ public class DirectedEdgeGraph implements EdgeGraph { } public boolean removeNode(Node n) { + boolean wasIn = n.inGraph; removeConnectingEdges((EdgeGraphNode) n); - return nodes.remove(n); + return wasIn; } protected void removeConnectingEdges(EdgeGraphNode n) { diff --git a/Robust/src/Benchmarks/oooJava/DelaunayRefinement/Node.java b/Robust/src/Benchmarks/oooJava/DelaunayRefinement/Node.java index 5f71f4f8..68ac2f06 100644 --- a/Robust/src/Benchmarks/oooJava/DelaunayRefinement/Node.java +++ b/Robust/src/Benchmarks/oooJava/DelaunayRefinement/Node.java @@ -1,5 +1,10 @@ public class Node { + public boolean inGraph; + public Node() { + inGraph = false; + } + //None of the program actually uses getData/setData so I use leave Node as a //wrapper interface. // public abstract Object getData(); diff --git a/Robust/src/Benchmarks/oooJava/DelaunayRefinement/SerialDelaunayRefinement.java b/Robust/src/Benchmarks/oooJava/DelaunayRefinement/SerialDelaunayRefinement.java index 97be45cc..67d2eee4 100644 --- a/Robust/src/Benchmarks/oooJava/DelaunayRefinement/SerialDelaunayRefinement.java +++ b/Robust/src/Benchmarks/oooJava/DelaunayRefinement/SerialDelaunayRefinement.java @@ -44,7 +44,9 @@ public class SerialDelaunayRefinement { if (runtime < mintime) { mintime = runtime; } + System.out.println( "Post-run garbage collection started..." ); System.gc(); + System.out.println( "done gc" ); } System.out.println("minimum runtime: " + mintime + " ms"); @@ -65,8 +67,8 @@ public class SerialDelaunayRefinement { System.out.println("http://iss.ices.utexas.edu/lonestar/delaunayrefinement.html"); System.out.println(); } - if (args.length < 1) { - System.out.println("Arguments: [verify]"); + if (args.length < 2) { + System.out.println("Arguments: [verify]"); System.exit(-1); } @@ -75,115 +77,158 @@ public class SerialDelaunayRefinement { Mesh m = new Mesh(); m.read(mesh, args[0]); - //treat LinkedList as a stack + int numWorkers = Integer.parseInt( args[1] ); + Stack worklist = new Stack(); - // LinkedList worklist = new LinkedList(); - // worklist.addAll(Mesh.getBad(mesh)); + // REPLACE worklist.addAll(Mesh.getBad(mesh)); WITH... HashMapIterator it = m.getBad(mesh).iterator(); while (it.hasNext()) { worklist.push(it.next()); } if (isFirstRun) { - System.out.println("configuration: " + mesh.getNumNodes() + " total triangles, " + worklist.size() + " bad triangles"); + System.out.println("configuration: " + + mesh.getNumNodes() + " total triangles, " + + worklist.size() + " bad triangles"); System.out.println(); } + System.out.println( "Post-config garbage collection started..." ); System.gc(); + System.out.println( "done gc" ); + -// long id = Time.getNewTimeId(); + // long id = Time.getNewTimeId(); long startTime = System.currentTimeMillis(); while (!worklist.isEmpty()) { - - Node[] bad_elements = new Node[23]; - for(int i=0;i<23;i++) { + + // Phase 1, grab enough work from list for + // each worker in the parent + Node[] nodesForBadTris = new Node[numWorkers]; + for(int i=0;i 1) { + //TODO verify is outside timing, do it each time + // since we MIGHT compute something different when + // we have a bug + if (//isFirstRun && + args.length > 2) { verify(mesh); } isFirstRun = false; return time; } - private void end(EdgeGraph mesh, Stack worklist, Node bad_element, Cavity cavity) { - HashMapIterator it2 = cavity.getPost().newBad(mesh).iterator(); - while (it2.hasNext()) { - worklist.push((Node)it2.next()); - } - - if (mesh.containsNode(bad_element)) { - worklist.push((Node) bad_element); - } - } - - private void middle(EdgeGraph mesh, Cavity cavity) { - //remove old data - Node node; - - //Takes up 8.9% of runtime - for (Iterator iterator = cavity.getPre().getNodes().iterator(); iterator.hasNext();) { - node = (Node) iterator.next(); - mesh.removeNode(node); - } - - //add new data - //Takes up 1.7% of runtime - for (Iterator iterator1 = cavity.getPost().getNodes().iterator(); iterator1.hasNext();) { - node = (Node) iterator1.next(); - mesh.addNode(node); - } - - - //Takes up 7.8% of runtime - Edge_d edge; - for (Iterator iterator2 = cavity.getPost().getEdges().iterator(); iterator2.hasNext();) { - edge = (Edge_d) iterator2.next(); - mesh.addEdge(edge); - } - } public void verify(EdgeGraph result) { //Put in cuz of static issues. diff --git a/Robust/src/Benchmarks/oooJava/DelaunayRefinement/Subgraph.java b/Robust/src/Benchmarks/oooJava/DelaunayRefinement/Subgraph.java index 01e90903..4c55e61e 100644 --- a/Robust/src/Benchmarks/oooJava/DelaunayRefinement/Subgraph.java +++ b/Robust/src/Benchmarks/oooJava/DelaunayRefinement/Subgraph.java @@ -49,6 +49,17 @@ public class Subgraph { edges.clear(); } + + public boolean allNodesStillInCompleteGraph() { + for( Iterator i = nodes.iterator(); i.hasNext(); ) { + Node node = (Node) i.next(); + if( !node.inGraph ) { + return false; + } + } + return true; + } + public HashSet newBad(EdgeGraph mesh) { HashSet ret = new HashSet(); for (Iterator iter = nodes.iterator(); iter.hasNext();) { -- 2.34.1