Nominal/Ex/Shallow.thy
author Cezary Kaliszyk <cezarykaliszyk@gmail.com>
Mon, 26 Mar 2012 13:10:51 +0200
changeset 3138 b47301ebb3ca
parent 2950 0911cb7bf696
permissions -rw-r--r--
Defining nominal functions without FCB

theory Shallow
imports "../Nominal2" 
begin

(* 
  Various shallow binders
*)

atom_decl name

text {* binding lists of names *}

nominal_datatype trm1 =
  Var1 "name"
| App1 "trm1" "trm1"
| Lam1 xs::"name list" t::"trm1" binds xs in t

thm trm1.strong_exhaust


text {* binding a finite set of names *}

nominal_datatype trm2 =
  Var2 "name"
| App2 "trm2" "trm2"
| Lam2 xs::"name fset" t::"trm2" binds (set) xs in t

thm trm2.strong_exhaust

text {* restricting a finite set of names *}

nominal_datatype trm3 =
  Var3 "name"
| App3 "trm3" "trm3"
| Lam3 xs::"name fset" t::"trm3" binds (set+) xs in t

thm trm3.eq_iff

end