Nominal/ExCoreHaskell.thy
author Cezary Kaliszyk <kaliszyk@in.tum.de>
Thu, 25 Mar 2010 12:04:38 +0100
changeset 1646 733bac87d5bf
parent 1645 bde8da26093e
child 1647 032649a694d2
permissions -rw-r--r--
Solved all boring subgoals, and looking at properly defning permute_bv
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1601
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
     1
theory ExCoreHaskell
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
     2
imports "Parser"
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
     3
begin
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
     4
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
     5
(* core haskell *)
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
     6
1624
91ab98dd9999 Experiments with Core Haskell support.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1621
diff changeset
     7
ML {* val _ = recursive := false *}
91ab98dd9999 Experiments with Core Haskell support.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1621
diff changeset
     8
ML {* val _ = cheat_bn_eqvt := true *}
91ab98dd9999 Experiments with Core Haskell support.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1621
diff changeset
     9
ML {* val _ = cheat_bn_rsp := true *}
91ab98dd9999 Experiments with Core Haskell support.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1621
diff changeset
    10
ML {* val _ = cheat_const_rsp := true *}
91ab98dd9999 Experiments with Core Haskell support.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1621
diff changeset
    11
ML {* val _ = cheat_alpha_bn_rsp := true *}
1601
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    12
atom_decl var
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    13
atom_decl tvar
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    14
1606
75403378068b Initial list unfoldings in Core Haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1601
diff changeset
    15
(* there are types, coercion types and regular types list-data-structure *)
1609
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    16
1601
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    17
nominal_datatype tkind =
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    18
  KStar
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    19
| KFun "tkind" "tkind"
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    20
and ckind =
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    21
  CKEq "ty" "ty"
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    22
and ty =
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    23
  TVar "tvar"
1609
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    24
| TC "char"
1601
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    25
| TApp "ty" "ty"
1609
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    26
| TFun "char" "ty_lst"
1601
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    27
| TAll tv::"tvar" "tkind" T::"ty"  bind tv in T
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    28
| TEq "ty" "ty" "ty"
1606
75403378068b Initial list unfoldings in Core Haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1601
diff changeset
    29
and ty_lst =
75403378068b Initial list unfoldings in Core Haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1601
diff changeset
    30
  TsNil
75403378068b Initial list unfoldings in Core Haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1601
diff changeset
    31
| TsCons "ty" "ty_lst"
1601
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    32
and co =
1609
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    33
  CC "char"
1601
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    34
| CApp "co" "co"
1609
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    35
| CFun "char" "co_lst"
1601
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    36
| CAll tv::"tvar" "ckind" C::"co"  bind tv in C
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    37
| CEq "co" "co" "co"
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    38
| CSym "co"
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    39
| CCir "co" "co"
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    40
| CLeft "co"
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    41
| CRight "co"
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    42
| CSim "co"
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    43
| CRightc "co"
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    44
| CLeftc "co"
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    45
| CCoe "co" "co"
1606
75403378068b Initial list unfoldings in Core Haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1601
diff changeset
    46
and co_lst =
75403378068b Initial list unfoldings in Core Haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1601
diff changeset
    47
  CsNil
75403378068b Initial list unfoldings in Core Haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1601
diff changeset
    48
| CsCons "co" "co_lst"
1609
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    49
and trm =
1601
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    50
  Var "var"
1609
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    51
| C "char"
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    52
| LAMT tv::"tvar" "tkind" t::"trm" bind tv in t
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    53
| LAMC tv::"tvar" "ckind" t::"trm" bind tv in t
1601
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    54
| APP "trm" "ty"
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    55
| Lam v::"var" "ty" t::"trm"       bind v in t
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    56
| App "trm" "trm"
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    57
| Let x::"var" "ty" "trm" t::"trm" bind x in t
1609
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    58
| Case "trm" "assoc_lst"
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    59
| Cast "trm" "ty"                  --"ty is supposed to be a coercion type only"
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    60
and assoc_lst =
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    61
  ANil
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    62
| ACons p::"pat" t::"trm" "assoc_lst" bind "bv p" in t
1601
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    63
and pat =
1609
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    64
  K "char" "tvtk_lst" "tvck_lst" "vt_lst"
1621
a40dbea68d0b Core Haskell experiments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1615
diff changeset
    65
and vt_lst =
a40dbea68d0b Core Haskell experiments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1615
diff changeset
    66
  VTNil
a40dbea68d0b Core Haskell experiments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1615
diff changeset
    67
| VTCons "var" "ty" "vt_lst"
1609
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    68
and tvtk_lst =
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    69
  TVTKNil
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    70
| TVTKCons "tvar" "tkind" "tvtk_lst"
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    71
and tvck_lst =
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    72
  TVCKNil
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    73
| TVCKCons "tvar" "ckind" "tvck_lst"
1601
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    74
binder
1609
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    75
    bv :: "pat \<Rightarrow> atom set"
1621
a40dbea68d0b Core Haskell experiments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1615
diff changeset
    76
and bv_vt :: "vt_lst \<Rightarrow> atom set"
1609
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    77
and bv_tvtk :: "tvtk_lst \<Rightarrow> atom set"
1621
a40dbea68d0b Core Haskell experiments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1615
diff changeset
    78
and bv_tvck :: "tvck_lst \<Rightarrow> atom set"
1601
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
    79
where
1621
a40dbea68d0b Core Haskell experiments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1615
diff changeset
    80
  "bv (K s tvts tvcs vs) = (bv_tvtk tvts) \<union> (bv_tvck tvcs) \<union> (bv_vt vs)"
a40dbea68d0b Core Haskell experiments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1615
diff changeset
    81
| "bv_vt VTNil = {}"
1609
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    82
| "bv_vt (VTCons v k t) = {atom v} \<union> bv_vt t"
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    83
| "bv_tvtk TVTKNil = {}"
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    84
| "bv_tvtk (TVTKCons v k t) = {atom v} \<union> bv_tvtk t"
c9bc3b61046c Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1606
diff changeset
    85
| "bv_tvck TVCKNil = {}"
1621
a40dbea68d0b Core Haskell experiments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1615
diff changeset
    86
| "bv_tvck (TVCKCons v k t) = {atom v} \<union> bv_tvck t"
a40dbea68d0b Core Haskell experiments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1615
diff changeset
    87
1626
0d7d0b8adca5 Showed support of Core Haskell
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1624
diff changeset
    88
lemmas fv_supp=tkind_ckind_ty_ty_lst_co_co_lst_trm_assoc_lst_pat_vt_lst_tvtk_lst_tvck_lst.supp(1-9,11,13,15)
0d7d0b8adca5 Showed support of Core Haskell
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1624
diff changeset
    89
lemmas supp=tkind_ckind_ty_ty_lst_co_co_lst_trm_assoc_lst_pat_vt_lst_tvtk_lst_tvck_lst.fv[simplified fv_supp]
1634
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
    90
lemmas perm=tkind_ckind_ty_ty_lst_co_co_lst_trm_assoc_lst_pat_vt_lst_tvtk_lst_tvck_lst.perm
1635
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
    91
lemmas eq_iff=tkind_ckind_ty_ty_lst_co_co_lst_trm_assoc_lst_pat_vt_lst_tvtk_lst_tvck_lst.eq_iff
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
    92
lemmas inducts=tkind_ckind_ty_ty_lst_co_co_lst_trm_assoc_lst_pat_vt_lst_tvtk_lst_tvck_lst.inducts
1634
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
    93
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
    94
lemma fresh_star_minus_perm: "as \<sharp>* - p = as \<sharp>* (p :: perm)"
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
    95
  unfolding fresh_star_def Ball_def
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
    96
  by auto (simp_all add: fresh_minus_perm)
1615
0ea578c6dae3 Parsing bn functions that call other bn functions and transmitting this information to fv/alpha.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1609
diff changeset
    97
1646
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
    98
(*primrec
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
    99
  permute_bv_raw
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   100
where
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   101
  "permute_bv_raw p (K c l1 l2 l3) = K c (permute_.. l1) ...
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   102
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   103
(permute_bv p (K (q \<bullet> char) (q \<bullet> tvtk_lst) (q \<bullet> tvck_lst) (q \<bullet> vt_lst)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   104
*)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   105
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   106
consts
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   107
  permute_bv :: "perm \<Rightarrow> pat \<Rightarrow> pat"
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   108
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   109
lemma ACons_subst:
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   110
  "supp (Abs (bv pat) trm) \<sharp>* q \<Longrightarrow> (ACons pat trm al) = ACons (permute_bv q pat) (q \<bullet> trm) al"
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   111
sorry
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   112
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   113
lemma perm_bv:
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   114
  "p \<bullet> bv l = bv (permute_bv p l)"
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   115
  sorry
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   116
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   117
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   118
1635
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   119
lemma fv_alpha1: "fv_bv_tvtk x \<sharp>* pa \<Longrightarrow> alpha_bv_tvtk (pa \<bullet> x) x"
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   120
apply (induct x rule: inducts(11))
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   121
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *})
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   122
apply (simp_all add: eq_iff fresh_star_union)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   123
apply (subst supp_perm_eq)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   124
apply (simp_all add: fv_supp)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   125
done
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   126
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   127
lemma fv_alpha2: "fv_bv_tvck x \<sharp>* pa \<Longrightarrow> alpha_bv_tvck (pa \<bullet> x) x"
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   128
apply (induct x rule: inducts(12))
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   129
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *})
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   130
apply (simp_all add: eq_iff fresh_star_union)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   131
apply (subst supp_perm_eq)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   132
apply (simp_all add: fv_supp)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   133
done
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   134
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   135
lemma fv_alpha3: "fv_bv_vt x \<sharp>* pa \<Longrightarrow> alpha_bv_vt (pa \<bullet> x) x"
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   136
apply (induct x rule: inducts(10))
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   137
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *})
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   138
apply (simp_all add: eq_iff fresh_star_union)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   139
apply (subst supp_perm_eq)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   140
apply (simp_all add: fv_supp)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   141
done
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   142
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   143
lemma fv_alpha: "fv_bv x \<sharp>* pa \<Longrightarrow> alpha_bv (pa \<bullet> x) x"
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   144
apply (induct x rule: inducts(9))
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   145
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *})
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   146
apply (simp_all add: eq_iff fresh_star_union)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   147
apply (simp add: fv_alpha1 fv_alpha2 fv_alpha3)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   148
apply (simp add: eqvts)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   149
done
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   150
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   151
lemma fin1: "finite (fv_bv_tvtk x)"
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   152
apply (induct x rule: inducts(11))
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   153
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *})
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   154
apply (simp_all add: fv_supp finite_supp)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   155
done
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   156
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   157
lemma fin2: "finite (fv_bv_tvck x)"
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   158
apply (induct x rule: inducts(12))
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   159
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *})
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   160
apply (simp_all add: fv_supp finite_supp)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   161
done
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   162
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   163
lemma fin3: "finite (fv_bv_vt x)"
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   164
apply (induct x rule: inducts(10))
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   165
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *})
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   166
apply (simp_all add: fv_supp finite_supp)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   167
done
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   168
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   169
lemma fin_fv_bv: "finite (fv_bv x)"
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   170
apply (induct x rule: inducts(9))
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   171
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *})
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   172
apply (simp add: fin1 fin2 fin3)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   173
done
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   174
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   175
lemma finb1: "finite (bv_tvtk x)"
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   176
apply (induct x rule: inducts(11))
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   177
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *})
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   178
apply (simp_all add: fv_supp finite_supp)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   179
done
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   180
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   181
lemma finb2: "finite (bv_tvck x)"
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   182
apply (induct x rule: inducts(12))
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   183
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *})
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   184
apply (simp_all add: fv_supp finite_supp)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   185
done
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   186
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   187
lemma finb3: "finite (bv_vt x)"
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   188
apply (induct x rule: inducts(10))
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   189
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *})
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   190
apply (simp_all add: fv_supp finite_supp)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   191
done
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   192
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   193
lemma fin_bv: "finite (bv x)"
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   194
apply (induct x rule: inducts(9))
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   195
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *})
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   196
apply (simp add: finb1 finb2 finb3)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   197
done
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   198
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   199
lemma "bv x \<sharp>* fv_bv x"
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   200
apply (induct x rule: inducts(9))
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   201
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *})
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   202
apply (simp)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   203
oops
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   204
1630
b295a928c56b Working on stating induct.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1626
diff changeset
   205
lemma 
1631
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   206
  assumes a01: "\<And>b. P1 b KStar"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   207
  and a02: "\<And>tkind1 tkind2 b. \<lbrakk>\<And>c. P1 c tkind1; \<And>c. P1 c tkind2\<rbrakk> \<Longrightarrow> P1 b (KFun tkind1 tkind2)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   208
  and a03: "\<And>ty1 ty2 b. \<lbrakk>\<And>c. P3 c ty1; \<And>c. P3 c ty2\<rbrakk> \<Longrightarrow> P2 b (CKEq ty1 ty2)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   209
  and a04: "\<And>tvar b. P3 b (TVar tvar)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   210
  and a05: "\<And>char b. P3 b (TC char)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   211
  and a06: "\<And>ty1 ty2 b. \<lbrakk>\<And>c. P3 c ty1; \<And>c. P3 c ty2\<rbrakk> \<Longrightarrow> P3 b (TApp ty1 ty2)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   212
  and a07: "\<And>char ty_lst b. \<lbrakk>\<And>c. P4 c ty_lst\<rbrakk> \<Longrightarrow> P3 b (TFun char ty_lst)"
1632
68c8666453f7 Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1631
diff changeset
   213
  and a08: "\<And>tvar tkind ty b. \<lbrakk>\<And>c. P1 c tkind; \<And>c. P3 c ty; atom tvar \<sharp> b\<rbrakk>
68c8666453f7 Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1631
diff changeset
   214
    \<Longrightarrow> P3 b (TAll tvar tkind ty)"
1631
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   215
  and a09: "\<And>ty1 ty2 ty3 b. \<lbrakk>\<And>c. P3 c ty1; \<And>c. P3 c ty2; \<And>c. P3 c ty3\<rbrakk> \<Longrightarrow> P3 b (TEq ty1 ty2 ty3)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   216
  and a10: "\<And>b. P4 b TsNil"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   217
  and a11: "\<And>ty ty_lst b. \<lbrakk>\<And>c. P3 c ty; \<And>c. P4 c ty_lst\<rbrakk> \<Longrightarrow> P4 b (TsCons ty ty_lst)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   218
  and a12: "\<And>char b. P5 b (CC char)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   219
  and a13: "\<And>co1 co2 b. \<lbrakk>\<And>c. P5 c co1; \<And>c. P5 c co2\<rbrakk> \<Longrightarrow> P5 b (CApp co1 co2)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   220
  and a14: "\<And>char co_lst b. \<lbrakk>\<And>c. P6 c co_lst\<rbrakk> \<Longrightarrow> P5 b (CFun char co_lst)"
1632
68c8666453f7 Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1631
diff changeset
   221
  and a15: "\<And>tvar ckind co b. \<lbrakk>\<And>c. P2 c ckind; \<And>c. P5 c co; atom tvar \<sharp> b\<rbrakk>
68c8666453f7 Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1631
diff changeset
   222
    \<Longrightarrow> P5 b (CAll tvar ckind co)"
1631
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   223
  and a16: "\<And>co1 co2 co3 b. \<lbrakk>\<And>c. P5 c co1; \<And>c. P5 c co2; \<And>c. P5 c co3\<rbrakk> \<Longrightarrow> P5 b (CEq co1 co2 co3)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   224
  and a17: "\<And>co b. \<lbrakk>\<And>c. P5 c co\<rbrakk> \<Longrightarrow> P5 b (CSym co)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   225
  and a18: "\<And>co1 co2 b. \<lbrakk>\<And>c. P5 c co1; \<And>c. P5 c co2\<rbrakk> \<Longrightarrow> P5 b (CCir co1 co2)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   226
  and a19: "\<And>co b. \<lbrakk>\<And>c. P5 c co\<rbrakk> \<Longrightarrow> P5 b (CLeft co)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   227
  and a20: "\<And>co b. \<lbrakk>\<And>c. P5 c co\<rbrakk> \<Longrightarrow> P5 b (CRight co)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   228
  and a21: "\<And>co b. \<lbrakk>\<And>c. P5 c co\<rbrakk> \<Longrightarrow> P5 b (CSim co)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   229
  and a22: "\<And>co b. \<lbrakk>\<And>c. P5 c co\<rbrakk> \<Longrightarrow> P5 b (CRightc co)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   230
  and a23: "\<And>co b. \<lbrakk>\<And>c. P5 c co\<rbrakk> \<Longrightarrow> P5 b (CLeftc co)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   231
  and a24: "\<And>co1 co2 b. \<lbrakk>\<And>c. P5 c co1; \<And>c. P5 c co2\<rbrakk> \<Longrightarrow> P5 b (CCoe co1 co2)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   232
  and a25: "\<And>b. P6 b CsNil"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   233
  and a26: "\<And>co co_lst b. \<lbrakk>\<And>c. P5 c co; \<And>c. P6 c co_lst\<rbrakk> \<Longrightarrow> P6 b (CsCons co co_lst)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   234
  and a27: "\<And>var b. P7 b (Var var)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   235
  and a28: "\<And>char b. P7 b (C char)"
1632
68c8666453f7 Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1631
diff changeset
   236
  and a29: "\<And>tvar tkind trm b. \<lbrakk>\<And>c. P1 c tkind; \<And>c. P7 c trm; atom tvar \<sharp> b\<rbrakk>
68c8666453f7 Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1631
diff changeset
   237
    \<Longrightarrow> P7 b (LAMT tvar tkind trm)"
68c8666453f7 Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1631
diff changeset
   238
  and a30: "\<And>tvar ckind trm b. \<lbrakk>\<And>c. P2 c ckind; \<And>c. P7 c trm; atom tvar \<sharp> b\<rbrakk>
68c8666453f7 Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1631
diff changeset
   239
    \<Longrightarrow> P7 b (LAMC tvar ckind trm)"
1631
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   240
  and a31: "\<And>trm ty b. \<lbrakk>\<And>c. P7 c trm; \<And>c. P3 c ty\<rbrakk> \<Longrightarrow> P7 b (APP trm ty)"
1632
68c8666453f7 Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1631
diff changeset
   241
  and a32: "\<And>var ty trm b. \<lbrakk>\<And>c. P3 c ty; \<And>c. P7 c trm; atom var \<sharp> b\<rbrakk> \<Longrightarrow> P7 b (Lam var ty trm)"
1631
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   242
  and a33: "\<And>trm1 trm2 b. \<lbrakk>\<And>c. P7 c trm1; \<And>c. P7 c trm2\<rbrakk> \<Longrightarrow> P7 b (App trm1 trm2)"
1632
68c8666453f7 Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1631
diff changeset
   243
  and a34: "\<And>var ty trm1 trm2 b. \<lbrakk>\<And>c. P3 c ty; \<And>c. P7 c trm1; \<And>c. P7 c trm2; atom var \<sharp> b\<rbrakk>
1631
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   244
    \<Longrightarrow> P7 b (Let var ty trm1 trm2)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   245
  and a35: "\<And>trm assoc_lst b. \<lbrakk>\<And>c. P7 c trm; \<And>c. P8 c assoc_lst\<rbrakk> \<Longrightarrow> P7 b (Case trm assoc_lst)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   246
  and a36: "\<And>trm ty b. \<lbrakk>\<And>c. P7 c trm; \<And>c. P3 c ty\<rbrakk> \<Longrightarrow> P7 b (Cast trm ty)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   247
  and a37: "\<And>b. P8 b ANil"
1632
68c8666453f7 Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1631
diff changeset
   248
  and a38: "\<And>pat trm assoc_lst b. \<lbrakk>\<And>c. P9 c pat; \<And>c. P7 c trm; \<And>c. P8 c assoc_lst; bv(pat) \<sharp>* b\<rbrakk>
1631
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   249
    \<Longrightarrow> P8 b (ACons pat trm assoc_lst)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   250
  and a39: "\<And>char tvtk_lst tvck_lst vt_lst b. \<lbrakk>\<And>c. P11 c tvtk_lst; \<And>c. P12 c tvck_lst; \<And>c. P10 c vt_lst\<rbrakk>
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   251
    \<Longrightarrow> P9 b (K char tvtk_lst tvck_lst vt_lst)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   252
  and a40: "\<And>b. P10 b VTNil"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   253
  and a41: "\<And>var ty vt_lst b. \<lbrakk>\<And>c. P3 c ty; \<And>c. P10 c vt_lst\<rbrakk> \<Longrightarrow> P10 b (VTCons var ty vt_lst)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   254
  and a42: "\<And>b. P11 b TVTKNil"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   255
  and a43: "\<And>tvar tkind tvtk_lst b. \<lbrakk>\<And>c. P1 c tkind; \<And>c. P11 c tvtk_lst\<rbrakk>
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   256
    \<Longrightarrow> P11 b (TVTKCons tvar tkind tvtk_lst)"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   257
  and a44: "\<And>b. P12 b TVCKNil"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   258
  and a45: "\<And>tvar ckind tvck_lst b. \<lbrakk>\<And>c. P2 c ckind; \<And>c. P12 c tvck_lst\<rbrakk>
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   259
    \<Longrightarrow> P12 b (TVCKCons tvar ckind tvck_lst)"
1632
68c8666453f7 Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1631
diff changeset
   260
  shows "P1 (a :: 'a :: pt) tkind \<and>
1631
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   261
         P2 (b :: 'b :: pt) ckind \<and>
1634
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   262
         P3 (c :: 'c :: {pt,fs}) ty \<and>
1631
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   263
         P4 (d :: 'd :: pt) ty_lst \<and>
1635
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   264
         P5 (e :: 'e :: {pt,fs}) co \<and>
1631
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   265
         P6 (f :: 'f :: pt) co_lst \<and>
1645
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   266
         P7 (g :: 'g :: {pt,fs}) trm \<and>
1635
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   267
         P8 (h :: 'h :: {pt,fs}) assoc_lst \<and>
1631
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   268
         P9 (i :: 'i :: pt) pat \<and>
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   269
         P10 (j :: 'j :: pt) vt_lst \<and>
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   270
         P11 (k :: 'k :: pt) tvtk_lst \<and>
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   271
         P12 (l :: 'l :: pt) tvck_lst"
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   272
proof -
1646
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   273
  have a: "(\<forall>p a. P1 a (p \<bullet> tkind)) \<and> (\<forall>p b. P2 b (p \<bullet> ckind)) \<and> (\<forall>p c. P3 c (p \<bullet> ty)) \<and> (\<forall>p d. P4 d (p \<bullet> ty_lst)) \<and> (\<forall>p e. P5 e (p \<bullet> co)) \<and> (\<forall>p f. P6 f (p \<bullet> co_lst)) \<and> (\<forall>p g. P7 g (p \<bullet> trm)) \<and> (\<forall>p h. P8 h (p \<bullet> assoc_lst)) \<and> (\<forall>p q i. P9 i (permute_bv p (q \<bullet> pat))) \<and> (\<forall>p j. P10 j (p \<bullet> vt_lst)) \<and> (\<forall>p k. P11 k (p \<bullet> tvtk_lst)) \<and> (\<forall>p l. P12 l (p \<bullet> tvck_lst))"
1631
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   274
    apply (rule tkind_ckind_ty_ty_lst_co_co_lst_trm_assoc_lst_pat_vt_lst_tvtk_lst_tvck_lst.induct)
1632
68c8666453f7 Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1631
diff changeset
   275
    apply (tactic {* ALLGOALS (REPEAT o rtac allI) *})
68c8666453f7 Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1631
diff changeset
   276
    apply (tactic {* ALLGOALS (TRY o SOLVED' (simp_tac @{simpset} THEN_ALL_NEW resolve_tac @{thms assms} THEN_ALL_NEW asm_full_simp_tac @{simpset})) *})
1635
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   277
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   278
(* GOAL1 *)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   279
    apply(subgoal_tac "\<exists>pa. ((pa \<bullet> (atom (p \<bullet> tvar))) \<sharp> c \<and>
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   280
                       supp (Abs (p \<bullet> {atom tvar}) (p \<bullet> ty)) \<sharp>* pa)")
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   281
    apply clarify
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   282
    apply (simp only: perm)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   283
    apply(rule_tac t="TAll (p \<bullet> tvar) (p \<bullet> tkind) (p \<bullet> ty)"
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   284
               and s="TAll (pa \<bullet> p \<bullet> tvar) (p \<bullet> tkind) (pa \<bullet> p \<bullet> ty)" in subst)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   285
    apply (simp only: eq_iff)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   286
    apply (rule_tac x="-pa" in exI)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   287
    apply (simp add: alphas eqvts eqvts_raw supp_Abs fv_supp)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   288
    apply (rule_tac t="supp (pa \<bullet> p \<bullet> ty) - {atom (pa \<bullet> p \<bullet> tvar)}"
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   289
                and s="pa \<bullet> (p \<bullet> supp ty - {p \<bullet> atom tvar})" in subst)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   290
    apply (simp add: eqvts)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   291
    apply (simp add: eqvts[symmetric])
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   292
    apply (rule conjI)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   293
    apply (rule supp_perm_eq)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   294
    apply (simp add: eqvts)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   295
    apply (subst supp_finite_atom_set)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   296
    apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   297
    apply (simp add: eqvts)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   298
    apply (simp add: eqvts)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   299
    apply (subst supp_perm_eq)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   300
    apply (subst supp_finite_atom_set)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   301
    apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   302
    apply (simp add: eqvts)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   303
    apply assumption
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   304
    apply (simp add: fresh_star_minus_perm)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   305
    apply (rule a08)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   306
    apply simp
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   307
    apply(rotate_tac 1)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   308
    apply(erule_tac x="(pa + p)" in allE)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   309
    apply simp
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   310
    apply (simp add: eqvts eqvts_raw)
1634
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   311
    apply (rule at_set_avoiding2_atom)
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   312
    apply (simp add: finite_supp)
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   313
    apply (simp add: finite_supp)
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   314
    apply (simp add: fresh_def)
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   315
    apply (simp only: supp_Abs eqvts)
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   316
    apply blast
1635
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   317
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   318
(* GOAL2 *)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   319
    apply(subgoal_tac "\<exists>pa. ((pa \<bullet> (atom (p \<bullet> tvar))) \<sharp> e \<and>
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   320
                       supp (Abs (p \<bullet> {atom tvar}) (p \<bullet> co)) \<sharp>* pa)")
1634
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   321
    apply clarify
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   322
    apply (simp only: perm)
1635
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   323
    apply(rule_tac t="CAll (p \<bullet> tvar) (p \<bullet> ckind) (p \<bullet> co)"
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   324
               and s="CAll (pa \<bullet> p \<bullet> tvar) (p \<bullet> ckind) (pa \<bullet> p \<bullet> co)" in subst)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   325
    apply (simp only: eq_iff)
1634
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   326
    apply (rule_tac x="-pa" in exI)
1635
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   327
    apply (simp add: alphas eqvts eqvts_raw supp_Abs fv_supp)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   328
    apply (rule_tac t="supp (pa \<bullet> p \<bullet> co) - {atom (pa \<bullet> p \<bullet> tvar)}"
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   329
                and s="pa \<bullet> (p \<bullet> supp co - {p \<bullet> atom tvar})" in subst)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   330
    apply (simp add: eqvts)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   331
    apply (simp add: eqvts[symmetric])
1634
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   332
    apply (rule conjI)
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   333
    apply (rule supp_perm_eq)
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   334
    apply (simp add: eqvts)
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   335
    apply (subst supp_finite_atom_set)
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   336
    apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp)
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   337
    apply (simp add: eqvts)
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   338
    apply (simp add: eqvts)
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   339
    apply (subst supp_perm_eq)
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   340
    apply (subst supp_finite_atom_set)
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   341
    apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp)
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   342
    apply (simp add: eqvts)
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   343
    apply assumption
b6656b707a8d Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1632
diff changeset
   344
    apply (simp add: fresh_star_minus_perm)
1635
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   345
    apply (rule a15)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   346
    apply simp
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   347
    apply(rotate_tac 1)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   348
    apply(erule_tac x="(pa + p)" in allE)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   349
    apply simp
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   350
    apply (simp add: eqvts eqvts_raw)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   351
    apply (rule at_set_avoiding2_atom)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   352
    apply (simp add: finite_supp)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   353
    apply (simp add: finite_supp)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   354
    apply (simp add: fresh_def)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   355
    apply (simp only: supp_Abs eqvts)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   356
    apply blast
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   357
1645
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   358
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   359
(* GOAL3 a copy-and-paste of Goal2 with consts and variable names changed *)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   360
    apply(subgoal_tac "\<exists>pa. ((pa \<bullet> (atom (p \<bullet> tvar))) \<sharp> g \<and>
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   361
                       supp (Abs (p \<bullet> {atom tvar}) (p \<bullet> trm)) \<sharp>* pa)")
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   362
    apply clarify
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   363
    apply (simp only: perm)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   364
    apply(rule_tac t="LAMT (p \<bullet> tvar) (p \<bullet> tkind) (p \<bullet> trm)"
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   365
               and s="LAMT (pa \<bullet> p \<bullet> tvar) (p \<bullet> tkind) (pa \<bullet> p \<bullet> trm)" in subst)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   366
    apply (simp only: eq_iff)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   367
    apply (rule_tac x="-pa" in exI)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   368
    apply (simp add: alphas eqvts eqvts_raw supp_Abs fv_supp)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   369
    apply (rule_tac t="supp (pa \<bullet> p \<bullet> trm) - {atom (pa \<bullet> p \<bullet> tvar)}"
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   370
                and s="pa \<bullet> (p \<bullet> supp trm - {p \<bullet> atom tvar})" in subst)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   371
    apply (simp add: eqvts)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   372
    apply (simp add: eqvts[symmetric])
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   373
    apply (rule conjI)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   374
    apply (rule supp_perm_eq)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   375
    apply (simp add: eqvts)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   376
    apply (subst supp_finite_atom_set)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   377
    apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   378
    apply (simp add: eqvts)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   379
    apply (simp add: eqvts)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   380
    apply (subst supp_perm_eq)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   381
    apply (subst supp_finite_atom_set)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   382
    apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   383
    apply (simp add: eqvts)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   384
    apply assumption
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   385
    apply (simp add: fresh_star_minus_perm)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   386
    apply (rule a29)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   387
    apply simp
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   388
    apply(rotate_tac 1)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   389
    apply(erule_tac x="(pa + p)" in allE)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   390
    apply simp
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   391
    apply (simp add: eqvts eqvts_raw)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   392
    apply (rule at_set_avoiding2_atom)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   393
    apply (simp add: finite_supp)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   394
    apply (simp add: finite_supp)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   395
    apply (simp add: fresh_def)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   396
    apply (simp only: supp_Abs eqvts)
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   397
    apply blast
bde8da26093e One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1635
diff changeset
   398
1646
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   399
(* GOAL4 a copy-and-paste *)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   400
    apply(subgoal_tac "\<exists>pa. ((pa \<bullet> (atom (p \<bullet> tvar))) \<sharp> g \<and>
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   401
                       supp (Abs (p \<bullet> {atom tvar}) (p \<bullet> trm)) \<sharp>* pa)")
1635
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   402
    apply clarify
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   403
    apply (simp only: perm)
1646
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   404
    apply(rule_tac t="LAMC (p \<bullet> tvar) (p \<bullet> ckind) (p \<bullet> trm)"
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   405
               and s="LAMC (pa \<bullet> p \<bullet> tvar) (p \<bullet> ckind) (pa \<bullet> p \<bullet> trm)" in subst)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   406
    apply (simp only: eq_iff)
1635
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   407
    apply (rule_tac x="-pa" in exI)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   408
    apply (simp add: alphas eqvts eqvts_raw supp_Abs fv_supp)
1646
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   409
    apply (rule_tac t="supp (pa \<bullet> p \<bullet> trm) - {atom (pa \<bullet> p \<bullet> tvar)}"
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   410
                and s="pa \<bullet> (p \<bullet> supp trm - {p \<bullet> atom tvar})" in subst)
1635
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   411
    apply (simp add: eqvts)
1646
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   412
    apply (simp add: eqvts[symmetric])
1635
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   413
    apply (rule conjI)
1646
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   414
    apply (rule supp_perm_eq)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   415
    apply (simp add: eqvts)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   416
    apply (subst supp_finite_atom_set)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   417
    apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   418
    apply (simp add: eqvts)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   419
    apply (simp add: eqvts)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   420
    apply (subst supp_perm_eq)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   421
    apply (subst supp_finite_atom_set)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   422
    apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   423
    apply (simp add: eqvts)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   424
    apply assumption
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   425
    apply (simp add: fresh_star_minus_perm)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   426
    apply (rule a30)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   427
    apply simp
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   428
    apply(rotate_tac 1)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   429
    apply(erule_tac x="(pa + p)" in allE)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   430
    apply simp
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   431
    apply (simp add: eqvts eqvts_raw)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   432
    apply (rule at_set_avoiding2_atom)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   433
    apply (simp add: finite_supp)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   434
    apply (simp add: finite_supp)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   435
    apply (simp add: fresh_def)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   436
    apply (simp only: supp_Abs eqvts)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   437
    apply blast
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   438
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   439
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   440
(* GOAL5 a copy-and-paste *)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   441
    apply(subgoal_tac "\<exists>pa. ((pa \<bullet> (atom (p \<bullet> var))) \<sharp> g \<and>
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   442
                       supp (Abs (p \<bullet> {atom var}) (p \<bullet> trm)) \<sharp>* pa)")
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   443
    apply clarify
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   444
    apply (simp only: perm)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   445
    apply(rule_tac t="Lam (p \<bullet> var) (p \<bullet> ty) (p \<bullet> trm)"
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   446
               and s="Lam (pa \<bullet> p \<bullet> var) (p \<bullet> ty) (pa \<bullet> p \<bullet> trm)" in subst)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   447
    apply (simp only: eq_iff)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   448
    apply (rule_tac x="-pa" in exI)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   449
    apply (simp add: alphas eqvts eqvts_raw supp_Abs fv_supp)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   450
    apply (rule_tac t="supp (pa \<bullet> p \<bullet> trm) - {atom (pa \<bullet> p \<bullet> var)}"
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   451
                and s="pa \<bullet> (p \<bullet> supp trm - {p \<bullet> atom var})" in subst)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   452
    apply (simp add: eqvts)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   453
    apply (simp add: eqvts[symmetric])
1635
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   454
    apply (rule conjI)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   455
    apply (rule supp_perm_eq)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   456
    apply (simp add: eqvts)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   457
    apply (subst supp_finite_atom_set)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   458
    apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   459
    apply (simp add: eqvts)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   460
    apply (simp add: eqvts)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   461
    apply (subst supp_perm_eq)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   462
    apply (subst supp_finite_atom_set)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   463
    apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   464
    apply (simp add: eqvts)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   465
    apply assumption
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   466
    apply (simp add: fresh_star_minus_perm)
1646
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   467
    apply (rule a32)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   468
    apply simp
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   469
    apply(rotate_tac 1)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   470
    apply(erule_tac x="(pa + p)" in allE)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   471
    apply simp
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   472
    apply (simp add: eqvts eqvts_raw)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   473
    apply (rule at_set_avoiding2_atom)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   474
    apply (simp add: finite_supp)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   475
    apply (simp add: finite_supp)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   476
    apply (simp add: fresh_def)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   477
    apply (simp only: supp_Abs eqvts)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   478
    apply blast
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   479
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   480
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   481
(* GOAL6 a copy-and-paste *)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   482
    apply(subgoal_tac "\<exists>pa. ((pa \<bullet> (atom (p \<bullet> var))) \<sharp> g \<and>
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   483
                       supp (Abs (p \<bullet> {atom var}) (p \<bullet> trm2)) \<sharp>* pa)")
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   484
    apply clarify
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   485
    apply (simp only: perm)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   486
    apply(rule_tac t="Let (p \<bullet> var) (p \<bullet> ty) (p \<bullet> trm1) (p \<bullet> trm2)"
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   487
               and s="Let (pa \<bullet> p \<bullet> var) (p \<bullet> ty) (p \<bullet> trm1) (pa \<bullet> p \<bullet> trm2)" in subst)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   488
    apply (simp only: eq_iff)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   489
    apply (rule_tac x="-pa" in exI)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   490
    apply (simp add: alphas eqvts eqvts_raw supp_Abs fv_supp)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   491
    apply (rule_tac t="supp (pa \<bullet> p \<bullet> trm2) - {atom (pa \<bullet> p \<bullet> var)}"
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   492
                and s="pa \<bullet> (p \<bullet> supp trm2 - {p \<bullet> atom var})" in subst)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   493
    apply (simp add: eqvts)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   494
    apply (simp add: eqvts[symmetric])
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   495
    apply (rule conjI)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   496
    apply (rule supp_perm_eq)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   497
    apply (simp add: eqvts)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   498
    apply (subst supp_finite_atom_set)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   499
    apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   500
    apply (simp add: eqvts)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   501
    apply (simp add: eqvts)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   502
    apply (subst supp_perm_eq)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   503
    apply (subst supp_finite_atom_set)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   504
    apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   505
    apply (simp add: eqvts)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   506
    apply assumption
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   507
    apply (simp add: fresh_star_minus_perm)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   508
    apply (rule a34)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   509
    apply simp
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   510
    apply simp
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   511
    apply(rotate_tac 2)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   512
    apply(erule_tac x="(pa + p)" in allE)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   513
    apply simp
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   514
    apply (simp add: eqvts eqvts_raw)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   515
    apply (rule at_set_avoiding2_atom)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   516
    apply (simp add: finite_supp)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   517
    apply (simp add: finite_supp)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   518
    apply (simp add: fresh_def)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   519
    apply (simp only: supp_Abs eqvts)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   520
    apply blast
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   521
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   522
(* MAIN ACons Goal *)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   523
    apply(subgoal_tac "\<exists>pa. ((pa \<bullet> (bv (p \<bullet> pat))) \<sharp>* h \<and>
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   524
                       supp (Abs (p \<bullet> (bv pat)) (p \<bullet> trm)) \<sharp>* pa)")
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   525
    apply clarify
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   526
    apply (simp only: perm eqvts)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   527
    apply (subst ACons_subst)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   528
    apply assumption
1635
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   529
    apply (rule a38)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   530
    apply simp
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   531
    apply(rotate_tac 1)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   532
    apply(erule_tac x="(pa + p)" in allE)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   533
    apply simp
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   534
    apply simp
1646
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   535
    apply (simp add: perm_bv[symmetric])
1635
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   536
    apply (simp add: eqvts eqvts_raw)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   537
    apply (rule at_set_avoiding2)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   538
    apply (simp add: fin_bv)
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   539
    apply (simp add: finite_supp)
1646
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   540
    apply (simp add: supp_Abs)
1635
8b4595cb5524 Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1634
diff changeset
   541
    apply (rule finite_Diff)
1646
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   542
    apply (simp add: finite_supp)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   543
    apply (simp add: fresh_star_def fresh_def supp_Abs eqvts)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   544
(* Goal for K *)
733bac87d5bf Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1645
diff changeset
   545
    apply (simp)
1631
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   546
    sorry
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   547
  have g1: "P1 a (0 \<bullet> tkind)" using a[THEN conjunct1] by blast
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   548
  have g2: "P2 b (0 \<bullet> ckind)" using a[THEN conjunct2,THEN conjunct1] by blast
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   549
  have g3: "P3 c (0 \<bullet> ty) \<and>
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   550
        P4 d (0 \<bullet> ty_lst) \<and> P5 e (0 \<bullet> co) \<and> P6 f (0 \<bullet> co_lst) \<and>
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   551
        P7 g (0 \<bullet> trm) \<and> P8 h (0 \<bullet> assoc_lst) \<and> P9 i (0 \<bullet> pat) \<and>
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   552
        P10 j (0 \<bullet> vt_lst) \<and> P11 k (0 \<bullet> tvtk_lst) \<and> P12 l (0 \<bullet> tvck_lst)" using a by blast
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   553
  show ?thesis using g1 g2 g3 by simp
e94bfef17bb8 stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1630
diff changeset
   554
qed
1615
0ea578c6dae3 Parsing bn functions that call other bn functions and transmitting this information to fv/alpha.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 1609
diff changeset
   555
1601
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
   556
end
5f0bb35114c3 Added missing file
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff changeset
   557