setup‹
Document_Output.antiquotation_pretty_source_embedded 🍋‹const_typ›
(Scan.lift Parse.embedded_inner_syntax)
(fn ctxt => fn c => let val tc = Proof_Context.read_const {proper = false, strict = false} ctxt c in
Pretty.block [Document_Output.pretty_term ctxt tc, Pretty.str " ::",
Pretty.brk 1, Syntax.pretty_typ ctxt (fastype_of tc)] end) ›
setup‹ let fun dummy_pats (wrap $ (eq $ lhs $ rhs)) = let
val rhs_vars = Term.add_vars rhs []; fun dummy (v as Var (ixn as (_, T))) = if member ((=) ) rhs_vars ixn then v else Const (🍋‹DUMMY›, T)
| dummy (t $ u) = dummy t $ dummy u
| dummy (Abs (n, T, b)) = Abs (n, T, dummy b)
| dummy t = t; in wrap $ (eq $ dummy lhs $ rhs) end in
Term_Style.setup🍋‹dummy_pats› (Scan.succeed (K dummy_pats)) end ›
setup‹ let
fun eta_expand Ts t xs = case t of
Abs(x,T,t) => let val (t', xs') = eta_expand (T::Ts) t xs in (Abs (x, T, t'), xs') end
| _ => let
val (a,ts) = strip_comb t (* assume a atomic *)
val (ts',xs') = fold_map (eta_expand Ts) ts xs
val t' = list_comb (a, ts');
val Bs = binder_types (fastype_of1 (Ts,t));
val n = Int.min (length Bs, length xs');
val bs = map Bound ((n - 1) downto 0);
val xBs = ListPair.zip (xs',Bs);
val xs'' = drop n xs';
val t'' = fold_rev Term.abs xBs (list_comb(t', bs)) in (t'', xs'') end
val style_eta_expand =
(Scan.repeat Args.name) >> (fn xs => fn ctxt => fn t => fst (eta_expand [] t xs))
in Term_Style.setup🍋‹eta_expand› style_eta_expand end ›
end (*>*)
Messung V0.5
¤ Dauer der Verarbeitung: 0.14 Sekunden
(vorverarbeitet)
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.