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

SCM Repository

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

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

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1993, Fri Sep 28 14:51:23 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
                         globalInit := S.S_Assign(x, e') :: !globalInit  
84                        end                        end
85                    | AST.D_Input(x, desc, SOME(AST.E_LoadNrrd(tvs, nrrd, ty))) => let                    | AST.D_Input(x, desc, SOME(AST.E_LoadNrrd(tvs, nrrd, ty))) => let
86                      (* load the nrrd prox here *)                      (* load the nrrd proxy here *)
87                        val info = NrrdInfo.getInfo nrrd                        val info = NrrdInfo.getInfo nrrd
88                        val stm = (case TypeUtil.pruneHead ty                        val (ty, init) = (case Var.monoTypeOf x
89                               of Ty.T_DynSequence _ => (* FIXME *) raise Fail "unimplemented"                               of ty as Ty.T_DynSequence _ => (ty, Inputs.DynSeq nrrd)
90                                | Ty.T_Image _ => (* FIXME *) raise Fail "unimplemented"                                | ty as Ty.T_Image{dim, shape} =>
91                                      (ty, Inputs.Proxy(nrrd, ImageInfo.fromNrrd(NrrdInfo.getInfo nrrd, ?, ?)))
92                                | _ => raise Fail "impossible"                                | _ => raise Fail "impossible"
93                              (* end case *))                              (* 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                        in
101                          globals := x :: !globals;                          inputs := (x, inp) :: !inputs
                         globalInit := stm :: !globalInit  
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 75  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 228  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              | AST.E_Coerce{srcTy, dstTy, e} => let
284                  val (stms, x) = simplifyExpToVar (e, stms)                  val (stms, x) = simplifyExpToVar (e, stms)
285                  val result = newTemp dstTy                  val result = newTemp dstTy

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

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