simultaneous mapping of strongly connected components
authorhaftmann
Fri, 21 Feb 2014 19:20:26 +0100
changeset 55658 d696adf157e6
parent 55657 d5ad50aea356
child 55664 bab10fb557c2
simultaneous mapping of strongly connected components
src/Pure/General/graph.ML
--- a/src/Pure/General/graph.ML	Fri Feb 21 19:20:24 2014 +0100
+++ b/src/Pure/General/graph.ML	Fri Feb 21 19:20:26 2014 +0100
@@ -35,6 +35,7 @@
   val all_preds: 'a T -> key list -> key list
   val all_succs: 'a T -> key list -> key list
   val strong_conn: 'a T -> key list list
+  val map_strong_conn: ((key * 'a) list -> 'b list) -> 'a T -> 'b T
   val minimals: 'a T -> key list
   val maximals: 'a T -> key list
   val is_minimal: 'a T -> key -> bool
@@ -159,6 +160,15 @@
 fun strong_conn G =
   rev (filter_out null (#1 (reachable (imm_preds G) (all_succs G (keys G)))));
 
+fun map_strong_conn f G =
+  let
+    val xss = strong_conn G;
+    fun map' xs =
+      fold2 (curry Table.update) xs (f (AList.make (get_node G) xs));
+    val tab' = Table.empty
+      |> fold map' xss;
+  in map_nodes (fn x => fn _ => the (Table.lookup tab' x)) G end;
+
 
 (* minimal and maximal elements *)