Home My Page Projects Code Snippets Project Openings diderot
Summary Activity Tracker Tasks SCM

SCM Repository

[diderot] Annotation of /branches/vis15/src/compiler/tree-ir/tree-ir.sml
ViewVC logotype

Annotation of /branches/vis15/src/compiler/tree-ir/tree-ir.sml

Parent Directory Parent Directory | Revision Log Revision Log


Revision 3810 - (view) (download)

1 : jhr 3691 (* tree-ir.sml
2 :     *
3 :     * This code is part of the Diderot Project (http://diderot-language.cs.uchicago.edu)
4 :     *
5 :     * COPYRIGHT (c) 2016 The University of Chicago
6 :     * All rights reserved.
7 :     *
8 :     * This representation restores the block structure and nested expression syntax
9 :     * of the source language.
10 :     *)
11 :    
12 :     structure TreeIR =
13 :     struct
14 :    
15 : jhr 3757 structure Op = TreeOps
16 : jhr 3750 structure Ty = TreeTypes
17 : jhr 3691
18 :     datatype program = Program of {
19 :     props : Properties.t list,
20 :     consts : global_var list, (* large constant variables *)
21 :     inputs : input list, (* global input variables *)
22 :     constInit : block, (* code that initializes constants and inputs *)
23 :     globals : global_var list, (* other global variables *)
24 :     globalInit : block, (* CFG to initialize other globals (if any) *)
25 :     strand : strand, (* the strand definition *)
26 :     create : create, (* initial strand creation *)
27 :     update : block option (* optional update code. *)
28 :     }
29 :    
30 :     and strand = Strand of {
31 :     name : Atom.atom,
32 :     params : var list,
33 :     state : state_var list,
34 :     stateInit : block,
35 :     initM : block option,
36 :     updateM : block,
37 :     stabilizeM : block option
38 :     }
39 :    
40 :     and create = Create of {
41 :     dim : int option, (* grid dimension; NONE for collections *)
42 :     code : block (* the loop nest for creating the strands *)
43 :     }
44 :    
45 :     and block = Block of {
46 :     locals : var list,
47 :     body : stm list
48 :     }
49 :    
50 :     and stm
51 :     = S_Comment of string list
52 : jhr 3767 | S_Unpack of var list * exp (* unpack vector pieces into local variables *)
53 :     | S_Assign of var * exp
54 : jhr 3691 | S_GAssign of global_var * exp
55 :     | S_IfThen of exp * block
56 :     | S_IfThenElse of exp * block * block
57 :     | S_Foreach of var * exp * block
58 :     (* special Diderot forms *)
59 : jhr 3754 | S_LoadNrrd of var * string
60 : jhr 3691 | S_Input of global_var * string * string option * exp option (* get input *)
61 :     | S_InputNrrd of global_var * string * string option * string option (* get image/seq input *)
62 :     | S_New of Atom.atom * exp list (* new strand creation *)
63 : jhr 3767 | S_Save of state_var * exp (* save strand state *)
64 : jhr 3691 | S_Exit of exp list
65 : jhr 3810 | S_Print of Ty.t list * exp list
66 : jhr 3691 (* return functions for methods *)
67 :     | S_Active
68 :     | S_Stabilize
69 :     | S_Die
70 :    
71 :     and exp
72 :     = E_Global of global_var
73 :     | E_State of state_var
74 :     | E_Var of var
75 :     | E_Lit of Literal.t
76 :     | E_Op of Op.rator * exp list
77 : jhr 3810 | E_Cons of exp list * Ty.t
78 :     | E_Seq of exp list * Ty.t
79 : jhr 3767 | E_Pack of exp list (* pack vector pieces into composite vector value *)
80 : jhr 3691
81 :     and global_var = GV of {
82 :     name : string, (* name (should be unique) *)
83 : jhr 3810 ty : Ty.t, (* type *)
84 : jhr 3691 input : bool (* is an input variable *)
85 :     }
86 :    
87 :     and state_var = SV of {
88 :     name : string, (* name (should be unique) *)
89 : jhr 3810 ty : Ty.t, (* type *)
90 : jhr 3691 varying : bool, (* varies over the lifetime of the strand *)
91 :     output : bool (* is the output value of the strand *)
92 :     }
93 :    
94 :     and var = V of {
95 :     name : string, (* name (should be unique) *)
96 :     id : Stamp.stamp, (* unique ID *)
97 : jhr 3810 ty : Ty.t (* type *)
98 : jhr 3691 }
99 :    
100 :     withtype input = global_var Inputs.input
101 :    
102 :     structure GlobalVar : sig
103 :     val name : global_var -> string
104 : jhr 3810 val ty : global_var -> Ty.t
105 : jhr 3691 val isInput : global_var -> bool
106 :     val toString : global_var -> string
107 :     end = struct
108 :     fun name (GV{name, ...}) = name
109 :     fun ty (GV{ty, ...}) = ty
110 :     fun isInput (GV{input, ...}) = input
111 :     fun toString (GV{name, ...}) = "globals." ^ name
112 :     end
113 :    
114 :     structure StateVar : sig
115 :     val name : state_var -> string
116 : jhr 3810 val ty : state_var -> Ty.t
117 : jhr 3691 val isOutput : state_var -> bool
118 :     val isVarying : state_var -> bool
119 :     val toString : state_var -> string
120 :     end = struct
121 :     fun name (SV{name, ...}) = name
122 :     fun ty (SV{ty, ...}) = ty
123 :     fun isOutput (SV{output, ...}) = output
124 :     fun isVarying (SV{varying, ...}) = varying
125 :     fun toString (SV{name, ...}) = "self." ^ name
126 :     end
127 :    
128 :     structure Var : sig
129 :    
130 : jhr 3810 val new : string * Ty.t -> var
131 : jhr 3691 val name : var -> string
132 :     val toString : var -> string
133 : jhr 3810 val ty : var -> Ty.t
134 : jhr 3691
135 : jhr 3754 structure Set : ORD_SET where type Key.ord_key = var
136 : jhr 3691 structure Map : ORD_MAP where type Key.ord_key = var
137 :    
138 :     end = struct
139 :     fun new (name, ty) = V{
140 :     name = name,
141 :     id = Stamp.new(),
142 :     ty = ty
143 :     }
144 :     fun name (V{name, ...}) = name
145 :     fun toString (V{name, id, ...}) = concat[name, "$", Stamp.toString id]
146 :     fun ty (V{ty, ...}) = ty
147 :     local
148 :     structure VarOrd =
149 :     struct
150 :     type ord_key = var
151 :     fun compare (V{id=a, ...}, V{id=b, ...}) = Stamp.compare(a, b)
152 :     end
153 :     in
154 : jhr 3754 structure Set = RedBlackSetFn (VarOrd)
155 : jhr 3691 structure Map = RedBlackMapFn (VarOrd)
156 :     end (* local *)
157 :     end
158 :    
159 :     end

root@smlnj-gforge.cs.uchicago.edu
ViewVC Help
Powered by ViewVC 1.0.0