SCM Repository
[smlnj] / MLRISC / trunk / scheduling / wuhui.sml |
View of /MLRISC/trunk/scheduling/wuhui.sml
Parent Directory | Revision Log
Revision 2126 -
(download)
(annotate)
Thu Nov 2 16:11:29 2006 UTC (12 years, 11 months ago) by blume
File size: 1836 byte(s)
Thu Nov 2 16:11:29 2006 UTC (12 years, 11 months ago) by blume
File size: 1836 byte(s)
moved MLRISC to toplevel
(* * This is Wu Hui's example. *) structure WuHui = struct structure G = DirectedGraph fun makeDag nodes edges = let val dag as Graph.GRAPH G = G.graph("Test1",(),10) in app (#add_node G) nodes; app (#add_edge G) edges; dag end val dag as Graph.GRAPH G = makeDag [(1,(0,6)), (2,(0,6)), (3,(1,6)), (4,(1,6)), (5,(1,6)), (6,(3,6)) ] [(1,3,1), (1,4,1), (2,4,1), (2,5,1), (3,6,0), (4,6,1), (5,6,1) ] fun close dag = TransitiveClosure.acyclic_transitive_closure2 {+ = fn(i,j) => i+j+1, max = Int.max } dag fun leung (dag as Graph.GRAPH G) = let val dag' as Graph.GRAPH G' = G.graph("Tmp",(),10) val _ = #forall_nodes G (#add_node G') val _ = #forall_edges G (#add_edge G') in LeungPalemPnueli.rank {dag = dag', l = fn(_,_,l) => l, d = fn(_,(_,d)) => d, r = fn(_,(r,_)) => r, m = 1 } end structure View = GraphViewerFn(daVinci) structure L = GraphLayout fun view dag = View.view( L.makeLayout{node=fn(n,(r,d))=> [L.LABEL(Int.toString n^" r="^Int.toString r^ " d="^Int.toString d) ], edge=fn(i,j,l)=>[L.LABEL(Int.toString l),L.COLOR "red"], graph=fn _ =>[]} dag ) end
root@smlnj-gforge.cs.uchicago.edu | ViewVC Help |
Powered by ViewVC 1.0.0 |