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 3767 - (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 :     (* return functions for methods *)
66 :     | S_Active
67 :     | S_Stabilize
68 :     | S_Die
69 :    
70 :     and exp
71 :     = E_Global of global_var
72 :     | E_State of state_var
73 :     | E_Var of var
74 :     | E_Lit of Literal.t
75 :     | E_Op of Op.rator * exp list
76 : jhr 3753 | E_Cons of exp list * Ty.ty
77 :     | E_Seq of exp list * Ty.ty
78 : jhr 3767 | E_Pack of exp list (* pack vector pieces into composite vector value *)
79 : jhr 3691
80 :     and global_var = GV of {
81 :     name : string, (* name (should be unique) *)
82 :     ty : Ty.ty, (* type *)
83 :     input : bool (* is an input variable *)
84 :     }
85 :    
86 :     and state_var = SV of {
87 :     name : string, (* name (should be unique) *)
88 :     ty : Ty.ty, (* type *)
89 :     varying : bool, (* varies over the lifetime of the strand *)
90 :     output : bool (* is the output value of the strand *)
91 :     }
92 :    
93 :     and var = V of {
94 :     name : string, (* name (should be unique) *)
95 :     id : Stamp.stamp, (* unique ID *)
96 :     ty : Ty.ty (* type *)
97 :     }
98 :    
99 :     withtype input = global_var Inputs.input
100 :    
101 :     structure GlobalVar : sig
102 :     val name : global_var -> string
103 :     val ty : global_var -> Ty.ty
104 :     val isInput : global_var -> bool
105 :     val toString : global_var -> string
106 :     end = struct
107 :     fun name (GV{name, ...}) = name
108 :     fun ty (GV{ty, ...}) = ty
109 :     fun isInput (GV{input, ...}) = input
110 :     fun toString (GV{name, ...}) = "globals." ^ name
111 :     end
112 :    
113 :     structure StateVar : sig
114 :     val name : state_var -> string
115 :     val ty : state_var -> Ty.ty
116 :     val isOutput : state_var -> bool
117 :     val isVarying : state_var -> bool
118 :     val toString : state_var -> string
119 :     end = struct
120 :     fun name (SV{name, ...}) = name
121 :     fun ty (SV{ty, ...}) = ty
122 :     fun isOutput (SV{output, ...}) = output
123 :     fun isVarying (SV{varying, ...}) = varying
124 :     fun toString (SV{name, ...}) = "self." ^ name
125 :     end
126 :    
127 :     structure Var : sig
128 :    
129 :     val new : string * Ty.ty -> var
130 :     val name : var -> string
131 :     val toString : var -> string
132 :     val ty : var -> Ty.ty
133 :    
134 : jhr 3754 structure Set : ORD_SET where type Key.ord_key = var
135 : jhr 3691 structure Map : ORD_MAP where type Key.ord_key = var
136 :    
137 :     end = struct
138 :     fun new (name, ty) = V{
139 :     name = name,
140 :     id = Stamp.new(),
141 :     ty = ty
142 :     }
143 :     fun name (V{name, ...}) = name
144 :     fun toString (V{name, id, ...}) = concat[name, "$", Stamp.toString id]
145 :     fun ty (V{ty, ...}) = ty
146 :     local
147 :     structure VarOrd =
148 :     struct
149 :     type ord_key = var
150 :     fun compare (V{id=a, ...}, V{id=b, ...}) = Stamp.compare(a, b)
151 :     end
152 :     in
153 : jhr 3754 structure Set = RedBlackSetFn (VarOrd)
154 : jhr 3691 structure Map = RedBlackMapFn (VarOrd)
155 :     end (* local *)
156 :     end
157 :    
158 :     end

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