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

SCM Repository

[diderot] Diff of /branches/charisee/src/compiler/translate/translate-basis.sml
ViewVC logotype

Diff of /branches/charisee/src/compiler/translate/translate-basis.sml

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

revision 3017, Mon Mar 9 15:52:22 2015 UTC revision 3048, Wed Mar 11 20:00:27 2015 UTC
# Line 199  Line 199 
199                                              [assignEin(y, mk.dotimes(d1, dd@[d2]),xs)]),                                              [assignEin(y, mk.dotimes(d1, dd@[d2]),xs)]),
200                  (BV.op_Ddot,         fn (y, [_, Ty.DIM d1,  Ty.SHAPE dd, Ty.DIM d2], xs) =>                  (BV.op_Ddot,         fn (y, [_, Ty.DIM d1,  Ty.SHAPE dd, Ty.DIM d2], xs) =>
201                                          [assignEin(y, mk.divergence(d1, dd),xs)] ),                                          [assignEin(y, mk.divergence(d1, dd),xs)] ),
202                  (BV.op_norm_t,            fn (y, [sv], xs) => let                  (BV.op_norm_t,            fn (y, [sv], xs) =>  assign(y, Op.Norm(shapeVarToTensor sv), xs)),
203                                              val ty=shapeVarToTensor sv                  (BV.op_norm_f,            fn (y, [ _,Ty.DIM d1, Ty.SHAPE dd], xs) =>
204                                              in (case shapeVarToTensor sv                                                      [assignEin(y, mk.magnitudeFF(d1, dd),xs@xs)]),
                                                 of DstTy.TensorTy[]     => assign(y, Op.Abs DstTy.realTy, xs)  
                                                 | DstTy.TensorTy [_]    => assign(y, Op.Norm ty, xs)  
                                                 | DstTy.TensorTy[_,_]   => assign(y, Op.Norm ty, xs)  
                                                 | DstTy.TensorTy[_,_,_] => assign(y, Op.Norm ty, xs)  
                                                 | _ => raise Fail"unsupported norm of TensorTy"  
                                                 (* end case *))  
                                             end),  
                 (BV.op_norm_f,            fn (y, [ _,Ty.DIM d1, Ty.SHAPE dd], xs) => (case dd  
                                             of []  =>  [assignEin(y, mk.magnitudeFF(d1, dd),xs)]  
                                             | [_]  =>  [assignEin(y, mk.magnitudeFF(d1, dd),xs@xs)]  
                                             | [_,_]  =>  [assignEin(y, mk.magnitudeFF(d1, dd),xs@xs)]  
                                             | _ => raise Fail"unsupported norm of fieldTy"  
                                             (* end case *))),  
205                  (BV.op_not,             simpleOp Op.Not),                  (BV.op_not,             simpleOp Op.Not),
206                  (BV.op_cross3_tt,           simpleEOp mk.cross3TT),                  (BV.op_cross3_tt,           simpleEOp mk.cross3TT),
207                  (BV.op_cross2_tt,          simpleEOp mk.cross2TT),                  (BV.op_cross2_tt,          simpleEOp mk.cross2TT),
# Line 283  Line 270 
270                  (BV.fn_normalize_f,             fn (y, [ _,Ty.DIM d1, Ty.SHAPE dd], xs) =>                  (BV.fn_normalize_f,             fn (y, [ _,Ty.DIM d1, Ty.SHAPE dd], xs) =>
271                      (case dd                      (case dd
272                          of [] => [assignEin(y, mk.normalizeFF(d1, []),xs)]                          of [] => [assignEin(y, mk.normalizeFF(d1, []),xs)]
273                          | [i] => [assignEin(y, mk.normalizeFF(d1, [i]),xs@xs)]                          | _     => [assignEin(y, mk.normalizeFF(d1, dd),xs@xs)]
                         | _ => raise Fail"unsupported normalized of fieldTy"  
274                      (* end case *))),                      (* end case *))),
275                  (BV.fn_principleEvec,   vectorOp Op.PrincipleEvec),                  (BV.fn_principleEvec,   vectorOp Op.PrincipleEvec),
276                  (BV.fn_trace_t,           fn (y, [Ty.DIM d], xs) =>                  (BV.fn_trace_t,           fn (y, [Ty.DIM d], xs) =>

Legend:
Removed from v.3017  
changed lines
  Added in v.3048

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