Author: ruschein
Date: 2010-11-29 08:23:29 -0800 (Mon, 29 Nov 2010)
New Revision: 23025
Added:
core3/misc-util/trunk/src/main/java/org/cytoscape/util/TopologicalSort.java
Log:
Carried over from Cytoscape 2.8.
Copied:
core3/misc-util/trunk/src/main/java/org/cytoscape/util/TopologicalSort.java
(from rev 22823,
cytoscape/trunk/application/src/main/java/cytoscape/util/TopologicalSort.java)
===================================================================
--- core3/misc-util/trunk/src/main/java/org/cytoscape/util/TopologicalSort.java
(rev 0)
+++ core3/misc-util/trunk/src/main/java/org/cytoscape/util/TopologicalSort.java
2010-11-29 16:23:29 UTC (rev 23025)
@@ -0,0 +1,86 @@
+/*
+ File: TopologicalSort.java
+
+ Copyright (c) 2010, The Cytoscape Consortium (www.cytoscape.org)
+
+ This library is free software; you can redistribute it and/or modify it
+ under the terms of the GNU Lesser General Public License as published
+ by the Free Software Foundation; either version 2.1 of the License, or
+ any later version.
+
+ This library is distributed in the hope that it will be useful, but
+ WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF
+ MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. The software and
+ documentation provided hereunder is on an "as is" basis, and the
+ Institute for Systems Biology and the Whitehead Institute
+ have no obligations to provide maintenance, support,
+ updates, enhancements or modifications. In no event shall the
+ Institute for Systems Biology and the Whitehead Institute
+ be liable to any party for direct, indirect, special,
+ incidental or consequential damages, including lost profits, arising
+ out of the use of this software and its documentation, even if the
+ Institute for Systems Biology and the Whitehead Institute
+ have been advised of the possibility of such damage. See
+ the GNU Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public License
+ along with this library; if not, write to the Free Software Foundation,
+ Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
+*/
+package cytoscape.util;
+
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Set;
+import java.util.Stack;
+
+
+/**
+ * Implements topological sorting of nodes in a graph.
+ * See for example http://en.wikipedia.org/wiki/Topological_sorting (the
Tarjan algorithm)
+ */
+public class TopologicalSort {
+ /**
+ * @param nodes the list of all nodes
+ * @param edges the edges that connect the nodes that need to be
sorted.
+ * @return the topological order
+ * @throws IllegalStateException if a cycle has been detected
+ * N.B. it might be a good idea to make sure that whatever the
concrete type of the nodes in
+ * "nodes" are has a toString() method that returns the name of a node
since this method
+ * will be used if a cycle has been detected to report one of the
nodes in the cycle.
+ */
+ public static List<TopoGraphNode> sort(final Collection<TopoGraphNode>
nodes)
+ throws IllegalStateException
+ {
+ final List<TopoGraphNode> order = new
ArrayList<TopoGraphNode>();
+ final Set<TopoGraphNode> visited = new HashSet<TopoGraphNode>();
+
+ final Set<TopoGraphNode> alreadySeen = new
HashSet<TopoGraphNode>();
+ for (final TopoGraphNode n : nodes) {
+ alreadySeen.clear();
+ visit(n, alreadySeen, visited, order);
+ }
+
+ return order;
+ }
+
+ private static void visit(final TopoGraphNode n, final
Set<TopoGraphNode> alreadySeen,
+ final Set<TopoGraphNode> visited, final
List<TopoGraphNode> order)
+ {
+ if (alreadySeen.contains(n))
+ throw new IllegalStateException("cycle containing " + n
+ " found!");
+ alreadySeen.add(n);
+
+ if (!visited.contains(n)) {
+ visited.add(n);
+ for (final TopoGraphNode m : n.getDependents())
+ visit(m, alreadySeen, visited, order);
+ order.add(n);
+ }
+
+ alreadySeen.remove(n);
+ }
+}
--
You received this message because you are subscribed to the Google Groups
"cytoscape-cvs" group.
To post to this group, send email to [email protected].
To unsubscribe from this group, send email to
[email protected].
For more options, visit this group at
http://groups.google.com/group/cytoscape-cvs?hl=en.