Nominal/Ex/Ex1.thy
author Christian Urban <urbanc@in.tum.de>
Wed, 24 Nov 2010 02:36:21 +0000
changeset 2581 3696659358c8
parent 2561 7926f1cb45eb
child 2593 25dcb2b1329e
permissions -rw-r--r--
added example from the F-ing paper by Rossberg, Russo and Dreyer

theory Ex1
imports "../Nominal2"
begin

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

atom_decl name

declare [[STEPS = 100]]

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.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
  "fv_foo (Foo1 (Bar1 v x (Bar0 x)) (Foo0 v)) = {}"
apply(simp only: foo_bar.fv_defs)
apply(simp only: foo_bar.bn_defs)
apply(simp only: supp_at_base)
apply(simp)
done

end