# HG changeset patch # User Christian Urban # Date 1304912998 -3600 # Node ID 2c6851248b3f8b9346d411700a4f4f1c80e4ad66 # Parent 3c769bf10e633940c2cc95d0343eeeb58c928781# Parent 8e0f0b2b51dd70bd31393283589b37ca5ee1ec1f merged diff -r 8e0f0b2b51dd -r 2c6851248b3f Nominal/Ex/Datatypes.thy --- a/Nominal/Ex/Datatypes.thy Mon May 09 04:46:43 2011 +0100 +++ b/Nominal/Ex/Datatypes.thy Mon May 09 04:49:58 2011 +0100 @@ -67,7 +67,29 @@ thm baz.fv_bn_eqvt thm baz.size_eqvt thm baz.supp + +(* + a nominal datatype with a set argument of + pure type +*) +nominal_datatype set_ty = + Set_ty "nat set" +| Fun "nat \ nat" +| Var "name" +| Lam x::"name" t::"set_ty" bind x in t + +thm set_ty.distinct +thm set_ty.induct +thm set_ty.exhaust +thm set_ty.strong_exhaust +thm set_ty.fv_defs +thm set_ty.bn_defs +thm set_ty.perm_simps +thm set_ty.eq_iff +thm set_ty.fv_bn_eqvt +thm set_ty.size_eqvt +thm set_ty.supp end diff -r 8e0f0b2b51dd -r 2c6851248b3f Nominal/Ex/LF.thy --- a/Nominal/Ex/LF.thy Mon May 09 04:46:43 2011 +0100 +++ b/Nominal/Ex/LF.thy Mon May 09 04:49:58 2011 +0100 @@ -17,7 +17,22 @@ Const "ident" | Var "name" | App "trm" "trm" - | Lam "ty" n::"name" t::"trm" bind n in t + | Lam' "ty" n::"name" t::"trm" bind n in t + +abbreviation + KPi_syn::"name \ ty \ kind \ kind" ("\[_:_]._" [100,100,100] 100) +where + "\[x:A].K \ KPi A x K" + +abbreviation + TPi_syn::"name \ ty \ ty \ ty" ("\[_:_]._" [100,100,100] 100) +where + "\[x:A1].A2 \ TPi A1 x A2" + +abbreviation + Lam_syn::"name \ ty \ trm \ trm" ("Lam [_:_]._" [100,100,100] 100) +where + "Lam [x:A].M \ Lam' A x M" thm lf.distinct thm lf.induct @@ -36,7 +51,110 @@ thm lf.fresh thm lf.fresh[simplified] +nominal_datatype sig_ass = + TC_ass "ident" "kind" + | C_ass "ident" "ty" +types Sig = "sig_ass list" +types Ctx = "(name \ ty) list" +types Subst = "(name \ trm) list" + +inductive + sig_valid :: "Sig \ bool" ("\ _ sig" [60] 60) +and ctx_valid :: "Sig \ Ctx \ bool" ("_ \ _ ctx" [60,60] 60) +and trm_valid :: "Sig \ Ctx \ trm \ ty \ bool" ("_,_ \ _ : _" [60,60,60,60] 60) +and ty_valid :: "Sig \ Ctx \ ty \ kind \ bool" ("_,_ \ _ : _" [60,60,60,60] 60) +and kind_valid :: "Sig \ Ctx \ kind \ bool" ("_,_ \ _ : Kind" [60,60,60] 60) +and trm_equiv :: "Sig \ Ctx \ trm \ trm \ ty \ bool" ("_,_ \ _ = _ : _" [60,60,60,60,60] 60) +and ty_equiv :: "Sig \ Ctx \ ty \ ty \ kind \ bool" ("_,_ \ _ = _ : _" [60,60,60,60,60] 60) +and kind_equiv :: "Sig \ Ctx \ kind \ kind \ bool" ("_,_ \ _ = _ : Kind" [60,60,60,60] 60) +where +(* Signatures *) + s1: "\ [] sig" +| s2: "\\ \ sig; \,[] \ K : Kind; atom a\\\ \ \ (TC_ass a K)#\ sig" +| s3: "\\ \ sig; \,[] \ A : Type; atom c\\\ \ \ (C_ass c A)#\ sig" + +(* Contexts *) +| c1: "\ \ sig \ \ \ [] ctx" +| c2: "\\ \ \ ctx; \,\ \ A : Type; atom x\\\ \ \ \ (x,A)#\ ctx" + +(* Typing Terms *) +| t1: "\\ \ \ ctx; (x,A) \ set \\ \ \,\ \ (Var x) : A" +| t2: "\\ \ \ ctx; C_ass c A \ set \\ \ \,\ \ (Const c) : A" +| t3: "\\,\ \ M1 : \[x:A2].A1; \,\ \ M2 : A2; atom x\\\ \ \,\ \ (App M1 M2) : A1" +| t4: "\\,\ \ A1 : Type; \,(x,A1)#\ \ M2 : A2; atom x\(\,A1)\ \ \,\ \ (Lam [x:A1].M2) : \[x:A1].A2" +| t5: "\\,\ \ M : A; \,\ \ A = B : Type\ \ \,\ \ M : B " + +(* Typing Types *) +| f1: "\\ \ \ ctx; TC_ass a K \ set \\ \ \,\ \ (TConst a) : K" +| f2: "\\,\ \ A : \[x:B].K; \,\ \ M : B; atom x\\\ \ \,\ \ (TApp A M) : K" +| f3: "\\,\ \ A1 : Type; \,(x,A1)#\ \ A2 : Type; atom x\(\,A1)\ \ \,\ \ (\[x:A1].A2) : Type" +| f4: "\\,\ \ A : K; \,\ \ K = L : Kind\ \ \,\ \ A : L" + +(* Typing Kinds *) +| k1: "\ \ \ ctx \ \,\ \ Type : Kind" +| k2: "\\,\ \ A : Type; \,(x,A)#\ \ K : Kind; atom x\(\,A)\ \ \,\ \ (\[x:A].K) : Kind" + +(* Simultaneous Congruence for Terms *) +| q1: "\\ \ \ ctx; (x,A) \ set \\ \ \,\ \ (Var x) = (Var x) : A" +| q2: "\\ \ \ ctx; C_ass c A \ set \\ \ \,\ \ (Const c) = (Const c): A" +| q3: "\\,\ \ M1 = N1 : \[x:A2].A1; \,\ \ M2 = N2 : A2; atom x\\\ + \ \,\ \ (App M1 M2) = (App N1 N2) : A1" +| q4: "\\,\ \ A1' = A1 : Type; \,\ \ A1'' = A1 : Type; \,\ \ A1 : Type; + \,(x,A1)#\ \ M2 = N2 : A2; atom x\\\ \ \,\ \ (Lam [x:A1'].M2) = (Lam [x:A1''].N2) : \[x:A1].A2" + +(* Extensionality *) +| ex: "\\,\ \ M : \[x:A1].A2; \,\ \ N : \[x:A1].A2; \,\ \ A1 : Type; + \,(x,A1)#\ \ App M (Var x) = App N (Var x) : A2; atom x\\\ \ \,\ \ M = N : \[x:A1].A2" + +(* Parallel Conversion *) +| pc: "\\,\ \ A1 : Type; \,(x,A1)#\ \ M2 = N2 : A2; \,\ \ M1 = N1 : A1; atom x\\\ + \ \,\ \ App (Lam [x:A1].M2) M1 = N2 : A2" + +(* Equivalence *) +| e1: "\,\ \ M = N : A \ \,\ \ N = M : (A::ty)" +| e2: "\\,\ \ M = N : A; \,\ \ N = P : A\ \ \,\ \ M = P : (A::ty)" +(*| e3: "\,\ \ M : A \ \,\ \ M = M : (A::ty)"*) + +(* Type conversion *) +| tc: "\\,\ \ M = N : A; \,\ \ A = B : Type\ \ \,\ \ M = N : B" + +(* Types Conruence *) +| ft1: "\\ \ \ ctx; TC_ass a K \ set \\ \ \,\ \ (TConst a) = (TConst a) : K" +| ft2: "\\,\ \ A = B : \[x:C].K; \,\ \ M = N : C; atom x\\\ \ \,\ \ (TApp A M) = (TApp B N) : K" +| ft3: "\\,\ \ A1 = B1 : Type; \,\ \ A1 : Type; \,(x,A1)#\ \ A2 = B2 : Type; atom x\\\ + \ \,\ \ \[x:A1].A2 = \[x:B1].B2 : Type" + +(* Types Equivalence *) +| fe1: "\,\ \ A = (B::ty) : (K::kind) \ \,\ \ B = A : K" +| fe2: "\\,\ \ A = B : K; \,\ \ B = C : K\ \ \,\ \ A = C : (K::kind)" +(*| fe3: "\,\ \ A : K \ \,\ \ A = A : (K::kind)"*) + +(* Kind Conversion *) +| kc: "\\,\ \ A = B : K; \,\ \ K = L : Kind\ \ \,\ \ A = B : (L::kind)" + +(* Kind Congruence *) +| kc1: "\ \ \ ctx \ \,\ \ Type = Type : Kind" +| kc2: "\\,\ \ A = B : Type; \,\ \ A : Type; \,(x,A)#\ \ K = L : Kind; atom x\\\ + \ \,\ \ \[x:A].K = \[x:B].L : Kind" + +(* Kind Equivalence *) +| ke1: "\,\ \ K = L : Kind \ \,\ \ L = K : Kind" +| ke2: "\\,\ \ K = L : Kind; \,\ \ L = L' : Kind\ \ \,\ \ K = L' : Kind" +(*| ke3: "\,\ \ K : Kind \ \,\ \ K = K : Kind"*) + +(* type extensionality - needed in order to get the soundness theorem through*) +| tex: "\\,\ \ A : \[x:C].K; \,\ \ B : \[x:C].K; \,\ \ C : Type; + \,(x,C)#\ \ TApp A (Var x) = TApp B (Var x) : K; atom x\\\ \ \,\ \ A = B : \[x:C].K" + +thm sig_valid_ctx_valid_trm_valid_ty_valid_kind_valid_trm_equiv_ty_equiv_kind_equiv_def +thm sig_valid_def +thm trm_valid_def +thm ty_valid_def +thm kind_valid_def +thm trm_equiv_def +thm kind_equiv_def +thm ty_equiv_def end diff -r 8e0f0b2b51dd -r 2c6851248b3f Nominal/Ex/Lambda.thy --- a/Nominal/Ex/Lambda.thy Mon May 09 04:46:43 2011 +0100 +++ b/Nominal/Ex/Lambda.thy Mon May 09 04:49:58 2011 +0100 @@ -2,6 +2,23 @@ imports "../Nominal2" begin +inductive + even :: "nat \ bool" and + odd :: "nat \ bool" +where + "even 0" +| "odd n \ even (Suc n)" +| "even n \ odd (Suc n)" + +thm even_odd_def + +lemma + shows "p \ (even n) = even (p \ n)" +unfolding even_def +unfolding even_odd_def +apply(perm_simp) +apply(rule refl) +done atom_decl name @@ -10,10 +27,26 @@ | App "lam" "lam" | Lam x::"name" l::"lam" bind x in l ("Lam [_]. _" [100, 100] 100) + inductive triv :: "lam \ nat \ bool" where Var: "triv (Var x) n" +| App: "\triv t1 n; triv t2 n\ \ triv (App t1 t2) n" + +lemma + "p \ (triv t x) = triv (p \ t) (p \ x)" +unfolding triv_def +apply(perm_simp) +apply(rule refl) +oops +(*apply(perm_simp)*) + +ML {* + Inductive.the_inductive @{context} "Lambda.triv" +*} + +thm triv_def equivariance triv nominal_inductive triv avoids Var: "{}::name set" diff -r 8e0f0b2b51dd -r 2c6851248b3f Nominal/Nominal2_Base.thy --- a/Nominal/Nominal2_Base.thy Mon May 09 04:46:43 2011 +0100 +++ b/Nominal/Nominal2_Base.thy Mon May 09 04:49:58 2011 +0100 @@ -789,7 +789,6 @@ unfolding permute_perm_def by (simp add: diff_minus minus_add add_assoc) - subsubsection {* Equivariance of Logical Operators *} lemma eq_eqvt [eqvt]: @@ -950,6 +949,12 @@ unfolding Union_eq by (perm_simp) (rule refl) +lemma Inter_eqvt [eqvt]: + shows "p \ (\ S) = \ (p \ S)" + unfolding Inter_eq + by (perm_simp) (rule refl) + + (* FIXME: eqvt attribute *) lemma Sigma_eqvt: shows "(p \ (X \ Y)) = (p \ X) \ (p \ Y)" @@ -957,9 +962,78 @@ unfolding UNION_eq_Union_image by (perm_simp) (rule refl) +text {* + In order to prove that lfp is equivariant we need two + auxiliary classes which specify that (op <=) and + Inf are equivariant. Instances for bool and fun are + given. +*} + +class le_eqvt = order + + assumes le_eqvt [eqvt]: "p \ (x \ y) = ((p \ x) \ (p \ (y::('a::{pt, order}))))" + +class inf_eqvt = complete_lattice + + assumes inf_eqvt [eqvt]: "p \ (Inf X) = Inf (p \ (X::('a::{pt, Inf}) set))" + +instantiation bool :: le_eqvt +begin + +instance +apply(default) +unfolding le_bool_def +apply(perm_simp) +apply(rule refl) +done + +end + +instantiation "fun" :: (pt, le_eqvt) le_eqvt +begin + +instance +apply(default) +unfolding le_fun_def +apply(perm_simp) +apply(rule refl) +done + +end + +instantiation bool :: inf_eqvt +begin + +instance +apply(default) +unfolding Inf_bool_def +apply(perm_simp) +apply(rule refl) +done + +end + +instantiation "fun" :: (pt, inf_eqvt) inf_eqvt +begin + +instance +apply(default) +unfolding Inf_fun_def +apply(perm_simp) +apply(rule refl) +done + +end + +lemma lfp_eqvt [eqvt]: + fixes F::"('a \ 'b) \ ('a::pt \ 'b::{inf_eqvt, le_eqvt})" + shows "p \ (lfp F) = lfp (p \ F)" +unfolding lfp_def +by (perm_simp) (rule refl) + lemma finite_eqvt [eqvt]: shows "p \ finite A = finite (p \ A)" - unfolding permute_finite permute_bool_def .. +unfolding finite_def +by (perm_simp) (rule refl) + subsubsection {* Equivariance for product operations *} diff -r 8e0f0b2b51dd -r 2c6851248b3f Nominal/nominal_eqvt.ML --- a/Nominal/nominal_eqvt.ML Mon May 09 04:46:43 2011 +0100 +++ b/Nominal/nominal_eqvt.ML Mon May 09 04:49:58 2011 +0100 @@ -8,9 +8,6 @@ signature NOMINAL_EQVT = sig - val eqvt_rel_tac: Proof.context -> string list -> term -> thm -> thm list -> int -> tactic - val eqvt_rel_single_case_tac: Proof.context -> string list -> term -> thm -> int -> tactic - val raw_equivariance: bool -> term list -> thm -> thm list -> Proof.context -> thm list * local_theory val equivariance: string -> Proof.context -> (thm list * local_theory) val equivariance_cmd: string -> Proof.context -> local_theory