summaryrefslogtreecommitdiff
path: root/src/especialize.sml
diff options
context:
space:
mode:
authorGravatar Adam Chlipala <adamc@hcoop.net>2008-11-08 14:42:52 -0500
committerGravatar Adam Chlipala <adamc@hcoop.net>2008-11-08 14:42:52 -0500
commitb4fbebde89c6ed5eeae8653004417ac6000cdf07 (patch)
treea7076475ba537b7e8b99d2133d5f0b6340e55e61 /src/especialize.sml
parent234118f1f5bebfb0b8f5b1d2e8b80cee74e140a6 (diff)
Broaden set of possible especializations
Diffstat (limited to 'src/especialize.sml')
-rw-r--r--src/especialize.sml70
1 files changed, 44 insertions, 26 deletions
diff --git a/src/especialize.sml b/src/especialize.sml
index 2c6799dd..adb444b5 100644
--- a/src/especialize.sml
+++ b/src/especialize.sml
@@ -32,39 +32,57 @@ open Core
structure E = CoreEnv
structure U = CoreUtil
-datatype skey =
- Named of int
- | App of skey * skey
+type skey = exp
structure K = struct
-type ord_key = skey list
-fun compare' (k1, k2) =
- case (k1, k2) of
- (Named n1, Named n2) => Int.compare (n1, n2)
- | (Named _, _) => LESS
- | (_, Named _) => GREATER
-
- | (App (x1, y1), App (x2, y2)) => Order.join (compare' (x1, x2), fn () => compare' (y1, y2))
-
-val compare = Order.joinL compare'
+type ord_key = exp list
+val compare = Order.joinL U.Exp.compare
end
structure KM = BinaryMapFn(K)
structure IM = IntBinaryMap
-fun skeyIn (e, _) =
+val sizeOf = U.Exp.fold {kind = fn (_, n) => n,
+ con = fn (_, n) => n,
+ exp = fn (_, n) => n + 1}
+ 0
+
+val isOpen = U.Exp.existsB {kind = fn _ => false,
+ con = fn ((nc, _), c) =>
+ case c of
+ CRel n => n >= nc
+ | _ => false,
+ exp = fn ((_, ne), e) =>
+ case e of
+ ERel n => n >= ne
+ | _ => false,
+ bind = fn ((nc, ne), b) =>
+ case b of
+ U.Exp.RelC _ => (nc + 1, ne)
+ | U.Exp.RelE _ => (nc, ne + 1)
+ | _ => (nc, ne)}
+ (0, 0)
+
+fun baseBad (e, _) =
case e of
- ENamed n => SOME (Named n)
- | EApp (e1, e2) =>
- (case (skeyIn e1, skeyIn e2) of
- (SOME k1, SOME k2) => SOME (App (k1, k2))
- | _ => NONE)
- | _ => NONE
-
-fun skeyOut (k, loc) =
- case k of
- Named n => (ENamed n, loc)
- | App (k1, k2) => (EApp (skeyOut (k1, loc), skeyOut (k2, loc)), loc)
+ EAbs (_, _, _, e) => sizeOf e > 20
+ | ENamed _ => false
+ | _ => true
+
+fun isBad e =
+ case e of
+ (ERecord xes, _) =>
+ length xes > 10
+ orelse List.exists (fn (_, e, _) => baseBad e) xes
+ | _ => baseBad e
+
+fun skeyIn e =
+ if isBad e orelse isOpen e then
+ NONE
+ else
+ SOME e
+
+fun skeyOut e = e
type func = {
name : string,
@@ -126,7 +144,7 @@ fun exp (e, st : state) =
(_, _, []) => SOME (body, typ)
| (EAbs (_, _, _, body'), TFun (_, typ'), x :: xs) =>
let
- val body'' = E.subExpInExp (0, skeyOut (x, #2 body)) body'
+ val body'' = E.subExpInExp (0, skeyOut x) body'
in
(*Print.prefaces "espec" [("body'", CorePrint.p_exp CoreEnv.empty body'),
("body''", CorePrint.p_exp CoreEnv.empty body'')];*)