Home My Page Projects Code Snippets Project Openings diderot

# SCM Repository

[diderot] Diff of /branches/vis12/src/compiler/simplify/simplify.sml
 [diderot] / branches / vis12 / src / compiler / simplify / simplify.sml

# Diff of /branches/vis12/src/compiler/simplify/simplify.sml

revision 1685, Sun Jan 22 15:23:36 2012 UTC revision 2012, Mon Oct 8 14:27:53 2012 UTC
# Line 24  Line 24
24    (* make a block out of a list of statements that are in reverse order *)    (* make a block out of a list of statements that are in reverse order *)
25      fun mkBlock stms = S.Block(List.rev stms)      fun mkBlock stms = S.Block(List.rev stms)
26
27      (* convert an AST expression to an input initialization.  Note that the Diderot grammar
28       * limits the forms of expression that we might encounter in this context.
29       *)
30        fun expToInit exp = (case exp
31               of AST.E_Lit(Literal.Int n) => Inputs.Int n
32                | AST.E_Lit(Literal.Float f) => Inputs.Real f
33                | AST.E_Lit(Literal.String s) => Inputs.String s
34                | AST.E_Lit(Bool b) => Inputs.Bool b
35                | AST.E_Tuple es => raise Fail "E_Tuple not yet implemented"
36                | AST.E_Cons es => let
37                    fun toReal (AST.E_Lit(Literal.Int n)) = FloatLit.fromInt n
38                      | toReal (AST.E_Lit(Literal.Float f)) = f
39                      | toReal (AST.E_Coerce{e, ...}) = toReal e
40                      | toReal _ = raise Fail "impossible"
41                    fun toTensor [e] = ??
42                      | toTensor (es as e1::_) = (case e1
43                           of AST.E_Cons _ => let
44                                val (shp, vs) = ??
45                                in
46                                  (List.length es :: shp, List.concat vs)
47                                end
48                            | _ => ([List.length es], List.map toReal (e1::es))
49                          (* end case *))
50                    in
51                      Inputs.Tensor(shp, Vector.fromList vs)
52                    end
53                | AST.E_Seq es => ??
54                | AST.E_Coerce{srcTy, dstTy, e} => ??
55                | _ => raise Fail "impossible initialization expression"
56              (* end case *))
57
58      fun simplifyProgram (AST.Program dcls) = let      fun simplifyProgram (AST.Program dcls) = let
59              val inputs = ref []
60            val globals = ref []            val globals = ref []
61            val globalInit = ref []            val globalInit = ref []
62            val initially = ref NONE            val initially = ref NONE
# Line 36  Line 68
68                  (* end case *))                  (* end case *))
69            fun simplifyDecl dcl = (case dcl            fun simplifyDecl dcl = (case dcl
70                   of AST.D_Input(x, desc, NONE) => let                   of AST.D_Input(x, desc, NONE) => let
71                        val e' = S.E_Input(Var.monoTypeOf x, Var.nameOf x, desc, NONE)                        val (ty, init) = (case Var.monoTypeOf x
72                                 of ty as Ty.T_Image{dim, shape} =>
73                                      (ty, SOME(Inputs.Image(ImageInfo.fromNrrd(NrrdInfo.getInfo nrrd, ?, ?))))
74                                  | ty => (ty, NONE)
75                                (* end case *))
76                          val inp = Inputs.INP{
77                                  ty = ty,
78                                  name = Var.nameOf x,
79                                  desc = desc,
80                                  init = init
81                                }
82                        in                        in
83                          globals := x :: !globals;                          inputs := (x, inp) :: !inputs
84                          globalInit := S.S_Assign(x, e') :: !globalInit                        end
85                      | AST.D_Input(x, desc, SOME(AST.E_LoadNrrd(tvs, nrrd, ty))) => let
86                        (* load the nrrd proxy here *)
87                          val info = NrrdInfo.getInfo nrrd
88                          val (ty, init) = (case Var.monoTypeOf x
89                                 of ty as Ty.T_DynSequence _ => (ty, Inputs.DynSeq nrrd)
90                                  | ty as Ty.T_Image{dim, shape} =>
91                                      (ty, Inputs.Proxy(nrrd, ImageInfo.fromNrrd(NrrdInfo.getInfo nrrd, ?, ?)))
92                                  | _ => raise Fail "impossible"
93                                (* end case *))
94                          val inp = Inputs.INP{
95                                  ty = ty,
96                                  name = Var.nameOf x,
97                                  desc = desc,
98                                  init = SOME init
99                                }
100                          in
101                            inputs := (x, inp) :: !inputs
102                        end                        end
103                    | AST.D_Input(x, desc, SOME e) => let                    | AST.D_Input(x, desc, SOME e) => let
104                        val (stms, x') = simplifyExpToVar (e, [])                        val inp = Inputs.INP{
105                        val e' = S.E_Input(Var.monoTypeOf x, Var.nameOf x, desc, SOME x')                                ty = Var.monoTypeOf x,
106                                  name = Var.nameOf x,
107                                  desc = desc,
108                                  init = SOME(expToInit e)
109                                }
110                        in                        in
111                          globals := x :: !globals;                          inputs := (x, inp) :: !inputs
globalInit := S.S_Assign(x, e') :: (stms @ !globalInit)
112                        end                        end
113                    | AST.D_Var(AST.VD_Decl(x, e)) => let                    | AST.D_Var(AST.VD_Decl(x, e)) => let
114                        val (stms, e') = simplifyExp (e, [])                        val (stms, e') = simplifyExp (e, [])
# Line 63  Line 125
125            in            in
126              List.app simplifyDecl dcls;              List.app simplifyDecl dcls;
127              S.Program{              S.Program{
128                    inputs = List.rev(!inputs),
129                  globals = List.rev(!globals),                  globals = List.rev(!globals),
130                  globalInit = mkBlock (!globalInit),                  globalInit = mkBlock (!globalInit),
131                  init = (case !initially                  init = (case !initially
# Line 184  Line 247
247                  in                  in
248                    (stms, S.E_Cons xs)                    (stms, S.E_Cons xs)
249                  end                  end
250                | AST.E_Seq es => let
251                    val (stms, xs) = simplifyExpsToVars (es, stms)
252                    in
253                      (stms, S.E_Seq xs)
254                    end
255              | AST.E_Slice(e, indices, ty) => let (* tensor slicing *)              | AST.E_Slice(e, indices, ty) => let (* tensor slicing *)
256                  val (stms, x) = simplifyExpToVar (e, stms)                  val (stms, x) = simplifyExpToVar (e, stms)
257                  fun f ([], ys, stms) = (stms, List.rev ys)                  fun f ([], ys, stms) = (stms, List.rev ys)
# Line 211  Line 279
279                  in                  in
280                    (S.S_IfThenElse(x, s1, s2) :: stms, S.E_Var result)                    (S.S_IfThenElse(x, s1, s2) :: stms, S.E_Var result)
281                  end                  end
282                | AST.E_LoadNrrd _ => raise Fail "unexpected E_LoadNrrd" (* should be handled by simplifyDecl *)
283                | AST.E_Coerce{srcTy, dstTy, e} => let
284                    val (stms, x) = simplifyExpToVar (e, stms)
285                    val result = newTemp dstTy
286                    in
287                      (S.S_Assign(result, S.E_Coerce{srcTy=srcTy, dstTy=dstTy, x=x})::stms, S.E_Var result)
288                    end
289            (* end case *))            (* end case *))
290
291      and simplifyExpToVar (exp, stms) = let      and simplifyExpToVar (exp, stms) = let
# Line 240  Line 315
315      fun transform (errStrm, ast) = let      fun transform (errStrm, ast) = let
316            val simple = simplifyProgram ast            val simple = simplifyProgram ast
317            val _ = SimplePP.output (Log.logFile(), simple)       (* DEBUG *)            val _ = SimplePP.output (Log.logFile(), simple)       (* DEBUG *)
318    (*
319            val simple = Lift.transform simple            val simple = Lift.transform simple
320                  handle Eval.Error msg => (Error.error(errStrm, msg); simple)                  handle Eval.Error msg => (Error.error(errStrm, msg); simple)
321    *)
322            in            in
323              simple              simple
324            end            end

Legend:
 Removed from v.1685 changed lines Added in v.2012