Nominal/Ex/Ex1.thy
author Christian Urban <urbanc@in.tum.de>
Sat, 25 Jun 2011 22:51:43 +0100
changeset 2901 754aa24006c8
parent 2625 478c5648e73f
child 2950 0911cb7bf696
permissions -rw-r--r--
did all cases, except the multiple binder case

theory Ex1
imports "../Nominal2"
begin

(* free names in bar are bound in foo *)

atom_decl name

thm finite_sets_supp

nominal_datatype foo =
  Foo0 "name"
| Foo1 b::"bar" f::"foo" bind (set) "bv b" in f
and bar =
  Bar0 "name"
| Bar1 "name" s::"name" b::"bar" bind (set) s in b
binder
  bv
where
  "bv (Bar0 x) = {}"
| "bv (Bar1 v x b) = {atom v}"

thm foo_bar.perm_bn_alpha
thm foo_bar.perm_bn_simps
thm foo_bar.bn_finite

thm foo_bar.eq_iff
thm foo_bar.distinct
thm foo_bar.induct
thm foo_bar.inducts
thm foo_bar.exhaust
thm foo_bar.fv_defs
thm foo_bar.bn_defs
thm foo_bar.perm_simps
thm foo_bar.eq_iff
thm foo_bar.fv_bn_eqvt
thm foo_bar.size_eqvt
thm foo_bar.supports
thm foo_bar.fsupp
thm foo_bar.supp

lemma
  "supp (Foo1 (Bar1 v x (Bar0 x)) (Foo0 v)) = {}"
apply(simp only: foo_bar.supp)
apply(simp only: foo_bar.bn_defs)
apply(simp only: supp_at_base)
apply(simp)
done

end