author | Christian Urban <urbanc@in.tum.de> |
Tue, 19 Jul 2011 09:40:46 +0100 | |
changeset 2978 | 967c55907ce1 |
parent 2765 | 7ac5e5c86c7d |
child 3045 | d0ad264f8c4f |
permissions | -rw-r--r-- |
2337
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
1 |
(* Title: nominal_dt_alpha.ML |
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
2 |
Author: Christian Urban |
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
3 |
Author: Cezary Kaliszyk |
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
4 |
|
2595
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
5 |
Performing quotient constructions, lifting theorems and |
2626
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
6 |
deriving support properties for the quotient types. |
2337
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
7 |
*) |
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
8 |
|
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
9 |
signature NOMINAL_DT_QUOT = |
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
10 |
sig |
2400
c6d30d5f5ba1
defined qperms and qsizes
Christian Urban <urbanc@in.tum.de>
parents:
2398
diff
changeset
|
11 |
val define_qtypes: (string list * binding * mixfix) list -> typ list -> term list -> |
2337
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
12 |
thm list -> local_theory -> Quotient_Info.quotdata_info list * local_theory |
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
13 |
|
2400
c6d30d5f5ba1
defined qperms and qsizes
Christian Urban <urbanc@in.tum.de>
parents:
2398
diff
changeset
|
14 |
val define_qconsts: typ list -> (string * term * mixfix) list -> local_theory -> |
2337
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
15 |
Quotient_Info.qconsts_info list * local_theory |
2346 | 16 |
|
2431
331873ebc5cd
can now deal with type variables in nominal datatype definitions
Christian Urban <urbanc@in.tum.de>
parents:
2430
diff
changeset
|
17 |
val define_qperms: typ list -> string list -> (string * sort) list -> |
331873ebc5cd
can now deal with type variables in nominal datatype definitions
Christian Urban <urbanc@in.tum.de>
parents:
2430
diff
changeset
|
18 |
(string * term * mixfix) list -> thm list -> local_theory -> local_theory |
2400
c6d30d5f5ba1
defined qperms and qsizes
Christian Urban <urbanc@in.tum.de>
parents:
2398
diff
changeset
|
19 |
|
2431
331873ebc5cd
can now deal with type variables in nominal datatype definitions
Christian Urban <urbanc@in.tum.de>
parents:
2430
diff
changeset
|
20 |
val define_qsizes: typ list -> string list -> (string * sort) list -> |
331873ebc5cd
can now deal with type variables in nominal datatype definitions
Christian Urban <urbanc@in.tum.de>
parents:
2430
diff
changeset
|
21 |
(string * term * mixfix) list -> local_theory -> local_theory |
2426
deb5be0115a7
moved lifting code from Lift.thy to nominal_dt_quot.ML
Christian Urban <urbanc@in.tum.de>
parents:
2401
diff
changeset
|
22 |
|
2434 | 23 |
val lift_thms: typ list -> thm list -> thm list -> Proof.context -> thm list * Proof.context |
2475
486d4647bb37
supp-proofs work except for CoreHaskell and Modules (induct is probably not finding the correct instance)
Christian Urban <urbanc@in.tum.de>
parents:
2434
diff
changeset
|
24 |
|
2595
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
25 |
val prove_supports: Proof.context -> thm list -> term list -> thm list |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
26 |
val prove_fsupp: Proof.context -> typ list -> thm -> thm list -> thm list |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
27 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
28 |
val fs_instance: typ list -> string list -> (string * sort) list -> thm list -> |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
29 |
local_theory -> local_theory |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
30 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
31 |
val prove_fv_supp: typ list -> term list -> term list -> term list -> term list -> thm list -> |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
32 |
thm list -> thm list -> thm list -> thm -> bclause list list -> Proof.context -> thm list |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
33 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
34 |
val prove_bns_finite: typ list -> term list -> thm -> thm list -> Proof.context -> thm list |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
35 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
36 |
val prove_perm_bn_alpha_thms: typ list -> term list -> term list -> thm -> thm list -> thm list -> |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
37 |
thm list -> Proof.context -> thm list |
2598
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
38 |
|
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
39 |
val prove_permute_bn_thms: typ list -> term list -> term list -> thm -> thm list -> thm list -> |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
40 |
thm list -> Proof.context -> thm list |
2626
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
41 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
42 |
val prove_strong_exhausts: Proof.context -> thm list -> bclause list list list -> thm list -> |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
43 |
thm list -> thm list -> thm list -> thm list -> thm list |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
44 |
|
2630
8268b277d240
automated all strong induction lemmas
Christian Urban <urbanc@in.tum.de>
parents:
2629
diff
changeset
|
45 |
val prove_strong_induct: Proof.context -> thm -> thm list -> thm list -> bclause list list list -> |
8268b277d240
automated all strong induction lemmas
Christian Urban <urbanc@in.tum.de>
parents:
2629
diff
changeset
|
46 |
thm list |
2337
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
47 |
end |
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
48 |
|
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
49 |
structure Nominal_Dt_Quot: NOMINAL_DT_QUOT = |
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
50 |
struct |
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
51 |
|
2765
7ac5e5c86c7d
introduced framework for finetuning eqvt-rules; this solves problem with permute_pure called in nominal_inductive
Christian Urban <urbanc@in.tum.de>
parents:
2637
diff
changeset
|
52 |
open Nominal_Permeq |
7ac5e5c86c7d
introduced framework for finetuning eqvt-rules; this solves problem with permute_pure called in nominal_inductive
Christian Urban <urbanc@in.tum.de>
parents:
2637
diff
changeset
|
53 |
|
2629
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
54 |
fun lookup xs x = the (AList.lookup (op=) xs x) |
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
55 |
|
2475
486d4647bb37
supp-proofs work except for CoreHaskell and Modules (induct is probably not finding the correct instance)
Christian Urban <urbanc@in.tum.de>
parents:
2434
diff
changeset
|
56 |
|
2337
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
57 |
(* defines the quotient types *) |
2400
c6d30d5f5ba1
defined qperms and qsizes
Christian Urban <urbanc@in.tum.de>
parents:
2398
diff
changeset
|
58 |
fun define_qtypes qtys_descr alpha_tys alpha_trms alpha_equivp_thms lthy = |
2476
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
59 |
let |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
60 |
val qty_args1 = map2 (fn ty => fn trm => (ty, trm, false)) alpha_tys alpha_trms |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
61 |
val qty_args2 = (qtys_descr ~~ qty_args1) ~~ alpha_equivp_thms |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
62 |
in |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
63 |
fold_map Quotient_Type.add_quotient_type qty_args2 lthy |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
64 |
end |
2337
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
65 |
|
2338 | 66 |
|
2337
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
67 |
(* defines quotient constants *) |
2400
c6d30d5f5ba1
defined qperms and qsizes
Christian Urban <urbanc@in.tum.de>
parents:
2398
diff
changeset
|
68 |
fun define_qconsts qtys consts_specs lthy = |
2476
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
69 |
let |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
70 |
val (qconst_infos, lthy') = |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
71 |
fold_map (Quotient_Def.lift_raw_const qtys) consts_specs lthy |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
72 |
val phi = ProofContext.export_morphism lthy' lthy |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
73 |
in |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
74 |
(map (Quotient_Info.transform_qconsts phi) qconst_infos, lthy') |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
75 |
end |
2337
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
76 |
|
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
77 |
|
2400
c6d30d5f5ba1
defined qperms and qsizes
Christian Urban <urbanc@in.tum.de>
parents:
2398
diff
changeset
|
78 |
(* defines the quotient permutations and proves pt-class *) |
2431
331873ebc5cd
can now deal with type variables in nominal datatype definitions
Christian Urban <urbanc@in.tum.de>
parents:
2430
diff
changeset
|
79 |
fun define_qperms qtys qfull_ty_names tvs perm_specs raw_perm_laws lthy = |
2476
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
80 |
let |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
81 |
val lthy1 = |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
82 |
lthy |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
83 |
|> Local_Theory.exit_global |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
84 |
|> Class.instantiation (qfull_ty_names, tvs, @{sort pt}) |
2398 | 85 |
|
2476
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
86 |
val (qs, lthy2) = define_qconsts qtys perm_specs lthy1 |
2431
331873ebc5cd
can now deal with type variables in nominal datatype definitions
Christian Urban <urbanc@in.tum.de>
parents:
2430
diff
changeset
|
87 |
|
2476
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
88 |
val ((_, raw_perm_laws'), lthy3) = Variable.importT raw_perm_laws lthy2 |
2398 | 89 |
|
2476
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
90 |
val lifted_perm_laws = |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
91 |
map (Quotient_Tacs.lifted lthy3 qtys []) raw_perm_laws' |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
92 |
|> Variable.exportT lthy3 lthy2 |
2398 | 93 |
|
2476
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
94 |
fun tac _ = |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
95 |
Class.intro_classes_tac [] THEN |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
96 |
(ALLGOALS (resolve_tac lifted_perm_laws)) |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
97 |
in |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
98 |
lthy2 |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
99 |
|> Class.prove_instantiation_exit tac |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
100 |
|> Named_Target.theory_init |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
101 |
end |
2346 | 102 |
|
2337
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
103 |
|
2400
c6d30d5f5ba1
defined qperms and qsizes
Christian Urban <urbanc@in.tum.de>
parents:
2398
diff
changeset
|
104 |
(* defines the size functions and proves size-class *) |
2431
331873ebc5cd
can now deal with type variables in nominal datatype definitions
Christian Urban <urbanc@in.tum.de>
parents:
2430
diff
changeset
|
105 |
fun define_qsizes qtys qfull_ty_names tvs size_specs lthy = |
2476
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
106 |
let |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
107 |
val tac = K (Class.intro_classes_tac []) |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
108 |
in |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
109 |
lthy |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
110 |
|> Local_Theory.exit_global |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
111 |
|> Class.instantiation (qfull_ty_names, tvs, @{sort size}) |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
112 |
|> snd o (define_qconsts qtys size_specs) |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
113 |
|> Class.prove_instantiation_exit tac |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
114 |
|> Named_Target.theory_init |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
115 |
end |
2400
c6d30d5f5ba1
defined qperms and qsizes
Christian Urban <urbanc@in.tum.de>
parents:
2398
diff
changeset
|
116 |
|
2426
deb5be0115a7
moved lifting code from Lift.thy to nominal_dt_quot.ML
Christian Urban <urbanc@in.tum.de>
parents:
2401
diff
changeset
|
117 |
|
2475
486d4647bb37
supp-proofs work except for CoreHaskell and Modules (induct is probably not finding the correct instance)
Christian Urban <urbanc@in.tum.de>
parents:
2434
diff
changeset
|
118 |
(* lifts a theorem and cleans all "_raw" parts |
2431
331873ebc5cd
can now deal with type variables in nominal datatype definitions
Christian Urban <urbanc@in.tum.de>
parents:
2430
diff
changeset
|
119 |
from variable names *) |
2426
deb5be0115a7
moved lifting code from Lift.thy to nominal_dt_quot.ML
Christian Urban <urbanc@in.tum.de>
parents:
2401
diff
changeset
|
120 |
|
2431
331873ebc5cd
can now deal with type variables in nominal datatype definitions
Christian Urban <urbanc@in.tum.de>
parents:
2430
diff
changeset
|
121 |
local |
331873ebc5cd
can now deal with type variables in nominal datatype definitions
Christian Urban <urbanc@in.tum.de>
parents:
2430
diff
changeset
|
122 |
val any = Scan.one (Symbol.not_eof) |
331873ebc5cd
can now deal with type variables in nominal datatype definitions
Christian Urban <urbanc@in.tum.de>
parents:
2430
diff
changeset
|
123 |
val raw = Scan.this_string "_raw" |
331873ebc5cd
can now deal with type variables in nominal datatype definitions
Christian Urban <urbanc@in.tum.de>
parents:
2430
diff
changeset
|
124 |
val exclude = |
331873ebc5cd
can now deal with type variables in nominal datatype definitions
Christian Urban <urbanc@in.tum.de>
parents:
2430
diff
changeset
|
125 |
Scan.repeat (Scan.unless raw any) --| raw >> implode |
331873ebc5cd
can now deal with type variables in nominal datatype definitions
Christian Urban <urbanc@in.tum.de>
parents:
2430
diff
changeset
|
126 |
val parser = Scan.repeat (exclude || any) |
331873ebc5cd
can now deal with type variables in nominal datatype definitions
Christian Urban <urbanc@in.tum.de>
parents:
2430
diff
changeset
|
127 |
in |
331873ebc5cd
can now deal with type variables in nominal datatype definitions
Christian Urban <urbanc@in.tum.de>
parents:
2430
diff
changeset
|
128 |
fun unraw_str s = |
2574 | 129 |
s |> raw_explode |
2476
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
130 |
|> Scan.finite Symbol.stopper parser >> implode |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
131 |
|> fst |
2431
331873ebc5cd
can now deal with type variables in nominal datatype definitions
Christian Urban <urbanc@in.tum.de>
parents:
2430
diff
changeset
|
132 |
end |
2426
deb5be0115a7
moved lifting code from Lift.thy to nominal_dt_quot.ML
Christian Urban <urbanc@in.tum.de>
parents:
2401
diff
changeset
|
133 |
|
deb5be0115a7
moved lifting code from Lift.thy to nominal_dt_quot.ML
Christian Urban <urbanc@in.tum.de>
parents:
2401
diff
changeset
|
134 |
fun unraw_vars_thm thm = |
2476
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
135 |
let |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
136 |
fun unraw_var_str ((s, i), T) = ((unraw_str s, i), T) |
2426
deb5be0115a7
moved lifting code from Lift.thy to nominal_dt_quot.ML
Christian Urban <urbanc@in.tum.de>
parents:
2401
diff
changeset
|
137 |
|
2476
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
138 |
val vars = Term.add_vars (prop_of thm) [] |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
139 |
val vars' = map (Var o unraw_var_str) vars |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
140 |
in |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
141 |
Thm.certify_instantiate ([], (vars ~~ vars')) thm |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
142 |
end |
2426
deb5be0115a7
moved lifting code from Lift.thy to nominal_dt_quot.ML
Christian Urban <urbanc@in.tum.de>
parents:
2401
diff
changeset
|
143 |
|
deb5be0115a7
moved lifting code from Lift.thy to nominal_dt_quot.ML
Christian Urban <urbanc@in.tum.de>
parents:
2401
diff
changeset
|
144 |
fun unraw_bounds_thm th = |
2476
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
145 |
let |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
146 |
val trm = Thm.prop_of th |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
147 |
val trm' = Term.map_abs_vars unraw_str trm |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
148 |
in |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
149 |
Thm.rename_boundvars trm trm' th |
8f8652a8107f
tuned (to conform with indentation policy of Markus)
Christian Urban <urbanc@in.tum.de>
parents:
2475
diff
changeset
|
150 |
end |
2426
deb5be0115a7
moved lifting code from Lift.thy to nominal_dt_quot.ML
Christian Urban <urbanc@in.tum.de>
parents:
2401
diff
changeset
|
151 |
|
2434 | 152 |
fun lift_thms qtys simps thms ctxt = |
153 |
(map (Quotient_Tacs.lifted ctxt qtys simps |
|
154 |
#> unraw_bounds_thm |
|
155 |
#> unraw_vars_thm |
|
156 |
#> Drule.zero_var_indexes) thms, ctxt) |
|
157 |
||
2595
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
158 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
159 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
160 |
fun mk_supports_goal ctxt qtrm = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
161 |
let |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
162 |
val vs = fresh_args ctxt qtrm |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
163 |
val rhs = list_comb (qtrm, vs) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
164 |
val lhs = fold (curry HOLogic.mk_prod) vs @{term "()"} |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
165 |
|> mk_supp |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
166 |
in |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
167 |
mk_supports lhs rhs |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
168 |
|> HOLogic.mk_Trueprop |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
169 |
end |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
170 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
171 |
fun supports_tac ctxt perm_simps = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
172 |
let |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
173 |
val ss1 = HOL_basic_ss addsimps @{thms supports_def fresh_def[symmetric]} |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
174 |
val ss2 = HOL_ss addsimps @{thms swap_fresh_fresh fresh_Pair} |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
175 |
in |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
176 |
EVERY' [ simp_tac ss1, |
2765
7ac5e5c86c7d
introduced framework for finetuning eqvt-rules; this solves problem with permute_pure called in nominal_inductive
Christian Urban <urbanc@in.tum.de>
parents:
2637
diff
changeset
|
177 |
eqvt_tac ctxt (eqvt_strict_config addpres perm_simps), |
2595
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
178 |
simp_tac ss2 ] |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
179 |
end |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
180 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
181 |
fun prove_supports_single ctxt perm_simps qtrm = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
182 |
let |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
183 |
val goal = mk_supports_goal ctxt qtrm |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
184 |
val ctxt' = Variable.auto_fixes goal ctxt |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
185 |
in |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
186 |
Goal.prove ctxt' [] [] goal |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
187 |
(K (HEADGOAL (supports_tac ctxt perm_simps))) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
188 |
|> singleton (ProofContext.export ctxt' ctxt) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
189 |
end |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
190 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
191 |
fun prove_supports ctxt perm_simps qtrms = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
192 |
map (prove_supports_single ctxt perm_simps) qtrms |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
193 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
194 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
195 |
(* finite supp lemmas for qtypes *) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
196 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
197 |
fun prove_fsupp ctxt qtys qinduct qsupports_thms = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
198 |
let |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
199 |
val (vs, ctxt') = Variable.variant_fixes (replicate (length qtys) "x") ctxt |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
200 |
val goals = vs ~~ qtys |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
201 |
|> map Free |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
202 |
|> map (mk_finite o mk_supp) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
203 |
|> foldr1 (HOLogic.mk_conj) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
204 |
|> HOLogic.mk_Trueprop |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
205 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
206 |
val tac = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
207 |
EVERY' [ rtac @{thm supports_finite}, |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
208 |
resolve_tac qsupports_thms, |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
209 |
asm_simp_tac (HOL_ss addsimps @{thms finite_supp supp_Pair finite_Un}) ] |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
210 |
in |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
211 |
Goal.prove ctxt' [] [] goals |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
212 |
(K (HEADGOAL (rtac qinduct THEN_ALL_NEW tac))) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
213 |
|> singleton (ProofContext.export ctxt' ctxt) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
214 |
|> Datatype_Aux.split_conj_thm |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
215 |
|> map zero_var_indexes |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
216 |
end |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
217 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
218 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
219 |
(* finite supp instances *) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
220 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
221 |
fun fs_instance qtys qfull_ty_names tvs qfsupp_thms lthy = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
222 |
let |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
223 |
val lthy1 = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
224 |
lthy |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
225 |
|> Local_Theory.exit_global |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
226 |
|> Class.instantiation (qfull_ty_names, tvs, @{sort fs}) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
227 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
228 |
fun tac _ = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
229 |
Class.intro_classes_tac [] THEN |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
230 |
(ALLGOALS (resolve_tac qfsupp_thms)) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
231 |
in |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
232 |
lthy1 |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
233 |
|> Class.prove_instantiation_exit tac |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
234 |
|> Named_Target.theory_init |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
235 |
end |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
236 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
237 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
238 |
(* proves that fv and fv_bn equals supp *) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
239 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
240 |
fun gen_mk_goals fv supp = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
241 |
let |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
242 |
val arg_ty = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
243 |
fastype_of fv |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
244 |
|> domain_type |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
245 |
in |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
246 |
(arg_ty, fn x => HOLogic.mk_eq (fv $ x, supp x)) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
247 |
end |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
248 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
249 |
fun mk_fvs_goals fv = gen_mk_goals fv mk_supp |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
250 |
fun mk_fv_bns_goals fv_bn alpha_bn = gen_mk_goals fv_bn (mk_supp_rel alpha_bn) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
251 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
252 |
fun add_ss thms = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
253 |
HOL_basic_ss addsimps thms |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
254 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
255 |
fun symmetric thms = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
256 |
map (fn thm => thm RS @{thm sym}) thms |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
257 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
258 |
val supp_Abs_set = @{thms supp_Abs(1)[symmetric]} |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
259 |
val supp_Abs_res = @{thms supp_Abs(2)[symmetric]} |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
260 |
val supp_Abs_lst = @{thms supp_Abs(3)[symmetric]} |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
261 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
262 |
fun mk_supp_abs ctxt (BC (Set, _, _)) = EqSubst.eqsubst_tac ctxt [1] supp_Abs_set |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
263 |
| mk_supp_abs ctxt (BC (Res, _, _)) = EqSubst.eqsubst_tac ctxt [1] supp_Abs_res |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
264 |
| mk_supp_abs ctxt (BC (Lst, _, _)) = EqSubst.eqsubst_tac ctxt [1] supp_Abs_lst |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
265 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
266 |
fun mk_supp_abs_tac ctxt [] = [] |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
267 |
| mk_supp_abs_tac ctxt (BC (_, [], _)::xs) = mk_supp_abs_tac ctxt xs |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
268 |
| mk_supp_abs_tac ctxt (bc::xs) = (DETERM o mk_supp_abs ctxt bc)::mk_supp_abs_tac ctxt xs |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
269 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
270 |
fun mk_bn_supp_abs_tac trm = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
271 |
trm |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
272 |
|> fastype_of |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
273 |
|> body_type |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
274 |
|> (fn ty => case ty of |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
275 |
@{typ "atom set"} => simp_tac (add_ss supp_Abs_set) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
276 |
| @{typ "atom list"} => simp_tac (add_ss supp_Abs_lst) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
277 |
| _ => raise TERM ("mk_bn_supp_abs_tac", [trm])) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
278 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
279 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
280 |
val thms1 = @{thms supp_Pair supp_eqvt[symmetric] Un_assoc conj_assoc} |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
281 |
val thms2 = @{thms de_Morgan_conj Collect_disj_eq finite_Un} |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
282 |
val thms3 = @{thms alphas prod_alpha_def prod_fv.simps prod_rel_def permute_prod_def |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
283 |
prod.recs prod.cases prod.inject not_True_eq_False empty_def[symmetric] finite.emptyI} |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
284 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
285 |
fun prove_fv_supp qtys qtrms fvs fv_bns alpha_bns fv_simps eq_iffs perm_simps |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
286 |
fv_bn_eqvts qinduct bclausess ctxt = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
287 |
let |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
288 |
val goals1 = map mk_fvs_goals fvs |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
289 |
val goals2 = map2 mk_fv_bns_goals fv_bns alpha_bns |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
290 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
291 |
fun tac ctxt = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
292 |
SUBGOAL (fn (goal, i) => |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
293 |
let |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
294 |
val (fv_fun, arg) = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
295 |
goal |> Envir.eta_contract |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
296 |
|> Logic.strip_assums_concl |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
297 |
|> HOLogic.dest_Trueprop |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
298 |
|> fst o HOLogic.dest_eq |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
299 |
|> dest_comb |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
300 |
val supp_abs_tac = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
301 |
case (AList.lookup (op=) (qtrms ~~ bclausess) (head_of arg)) of |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
302 |
SOME bclauses => EVERY' (mk_supp_abs_tac ctxt bclauses) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
303 |
| NONE => mk_bn_supp_abs_tac fv_fun |
2765
7ac5e5c86c7d
introduced framework for finetuning eqvt-rules; this solves problem with permute_pure called in nominal_inductive
Christian Urban <urbanc@in.tum.de>
parents:
2637
diff
changeset
|
304 |
val eqvt_rconfig = eqvt_relaxed_config addpres (perm_simps @ fv_bn_eqvts) |
2595
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
305 |
in |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
306 |
EVERY' [ TRY o asm_full_simp_tac (add_ss (@{thm supp_Pair[symmetric]}::fv_simps)), |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
307 |
TRY o supp_abs_tac, |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
308 |
TRY o simp_tac (add_ss @{thms supp_def supp_rel_def}), |
2765
7ac5e5c86c7d
introduced framework for finetuning eqvt-rules; this solves problem with permute_pure called in nominal_inductive
Christian Urban <urbanc@in.tum.de>
parents:
2637
diff
changeset
|
309 |
TRY o eqvt_tac ctxt eqvt_rconfig, |
2595
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
310 |
TRY o simp_tac (add_ss (@{thms Abs_eq_iff} @ eq_iffs)), |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
311 |
TRY o asm_full_simp_tac (add_ss thms3), |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
312 |
TRY o simp_tac (add_ss thms2), |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
313 |
TRY o asm_full_simp_tac (add_ss (thms1 @ (symmetric fv_bn_eqvts)))] i |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
314 |
end) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
315 |
in |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
316 |
induct_prove qtys (goals1 @ goals2) qinduct tac ctxt |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
317 |
|> map atomize |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
318 |
|> map (simplify (HOL_basic_ss addsimps @{thms fun_eq_iff[symmetric]})) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
319 |
end |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
320 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
321 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
322 |
fun prove_bns_finite qtys qbns qinduct qbn_simps ctxt = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
323 |
let |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
324 |
fun mk_goal qbn = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
325 |
let |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
326 |
val arg_ty = domain_type (fastype_of qbn) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
327 |
val finite = @{term "finite :: atom set => bool"} |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
328 |
in |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
329 |
(arg_ty, fn x => finite $ (to_set (qbn $ x))) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
330 |
end |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
331 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
332 |
val props = map mk_goal qbns |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
333 |
val ss_tac = asm_full_simp_tac (HOL_basic_ss addsimps (qbn_simps @ |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
334 |
@{thms set.simps set_append finite_insert finite.emptyI finite_Un})) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
335 |
in |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
336 |
induct_prove qtys props qinduct (K ss_tac) ctxt |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
337 |
end |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
338 |
|
2598
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
339 |
|
2595
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
340 |
fun prove_perm_bn_alpha_thms qtys qperm_bns alpha_bns qinduct qperm_bn_simps qeq_iffs qalpha_refls ctxt = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
341 |
let |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
342 |
val ([p], ctxt') = Variable.variant_fixes ["p"] ctxt |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
343 |
val p = Free (p, @{typ perm}) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
344 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
345 |
fun mk_goal qperm_bn alpha_bn = |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
346 |
let |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
347 |
val arg_ty = domain_type (fastype_of alpha_bn) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
348 |
in |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
349 |
(arg_ty, fn x => (mk_id (Abs ("", arg_ty, alpha_bn $ Bound 0 $ (qperm_bn $ p $ Bound 0)))) $ x) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
350 |
end |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
351 |
|
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
352 |
val props = map2 mk_goal qperm_bns alpha_bns |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
353 |
val ss = @{thm id_def}::qperm_bn_simps @ qeq_iffs @ qalpha_refls |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
354 |
val ss_tac = asm_full_simp_tac (HOL_ss addsimps ss) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
355 |
in |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
356 |
induct_prove qtys props qinduct (K ss_tac) ctxt' |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
357 |
|> ProofContext.export ctxt' ctxt |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
358 |
|> map (simplify (HOL_basic_ss addsimps @{thms id_def})) |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
359 |
end |
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
360 |
|
2598
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
361 |
fun prove_permute_bn_thms qtys qbns qperm_bns qinduct qperm_bn_simps qbn_defs qbn_eqvts ctxt = |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
362 |
let |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
363 |
val ([p], ctxt') = Variable.variant_fixes ["p"] ctxt |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
364 |
val p = Free (p, @{typ perm}) |
2595
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
365 |
|
2598
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
366 |
fun mk_goal qbn qperm_bn = |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
367 |
let |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
368 |
val arg_ty = domain_type (fastype_of qbn) |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
369 |
in |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
370 |
(arg_ty, fn x => |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
371 |
(mk_id (Abs ("", arg_ty, |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
372 |
HOLogic.mk_eq (mk_perm p (qbn $ Bound 0), qbn $ (qperm_bn $ p $ Bound 0)))) $ x)) |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
373 |
end |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
374 |
|
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
375 |
val props = map2 mk_goal qbns qperm_bns |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
376 |
val ss = @{thm id_def}::qperm_bn_simps @ qbn_defs |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
377 |
val ss_tac = |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
378 |
EVERY' [asm_full_simp_tac (HOL_basic_ss addsimps ss), |
2765
7ac5e5c86c7d
introduced framework for finetuning eqvt-rules; this solves problem with permute_pure called in nominal_inductive
Christian Urban <urbanc@in.tum.de>
parents:
2637
diff
changeset
|
379 |
TRY o eqvt_tac ctxt' (eqvt_strict_config addpres qbn_eqvts), |
2598
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
380 |
TRY o asm_full_simp_tac HOL_basic_ss] |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
381 |
in |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
382 |
induct_prove qtys props qinduct (K ss_tac) ctxt' |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
383 |
|> ProofContext.export ctxt' ctxt |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
384 |
|> map (simplify (HOL_basic_ss addsimps @{thms id_def})) |
b136721eedb2
automated permute_bn theorems
Christian Urban <urbanc@in.tum.de>
parents:
2595
diff
changeset
|
385 |
end |
2595
07f775729e90
moved code from nominal_dt_supp to nominal_dt_quot
Christian Urban <urbanc@in.tum.de>
parents:
2574
diff
changeset
|
386 |
|
2626
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
387 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
388 |
|
2629
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
389 |
(*** proves strong exhauts theorems ***) |
2626
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
390 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
391 |
(* fixme: move into nominal_library *) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
392 |
fun abs_const bmode ty = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
393 |
let |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
394 |
val (const_name, binder_ty, abs_ty) = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
395 |
case bmode of |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
396 |
Lst => (@{const_name "Abs_lst"}, @{typ "atom list"}, @{type_name abs_lst}) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
397 |
| Set => (@{const_name "Abs_set"}, @{typ "atom set"}, @{type_name abs_set}) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
398 |
| Res => (@{const_name "Abs_res"}, @{typ "atom set"}, @{type_name abs_res}) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
399 |
in |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
400 |
Const (const_name, [binder_ty, ty] ---> Type (abs_ty, [ty])) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
401 |
end |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
402 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
403 |
fun mk_abs bmode trm1 trm2 = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
404 |
abs_const bmode (fastype_of trm2) $ trm1 $ trm2 |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
405 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
406 |
fun is_abs_eq thm = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
407 |
let |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
408 |
fun is_abs trm = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
409 |
case (head_of trm) of |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
410 |
Const (@{const_name "Abs_set"}, _) => true |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
411 |
| Const (@{const_name "Abs_lst"}, _) => true |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
412 |
| Const (@{const_name "Abs_res"}, _) => true |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
413 |
| _ => false |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
414 |
in |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
415 |
thm |> prop_of |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
416 |
|> HOLogic.dest_Trueprop |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
417 |
|> HOLogic.dest_eq |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
418 |
|> fst |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
419 |
|> is_abs |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
420 |
end |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
421 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
422 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
423 |
(* adds a freshness condition to the assumptions *) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
424 |
fun mk_ecase_prems lthy c (params, prems, concl) bclauses = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
425 |
let |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
426 |
val tys = map snd params |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
427 |
val binders = get_all_binders bclauses |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
428 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
429 |
fun prep_binder (opt, i) = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
430 |
let |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
431 |
val t = Bound (length tys - i - 1) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
432 |
in |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
433 |
case opt of |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
434 |
NONE => setify_ty lthy (nth tys i) t |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
435 |
| SOME bn => to_set_ty (fastype_of1 (tys, bn $ t)) (bn $ t) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
436 |
end |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
437 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
438 |
val prems' = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
439 |
case binders of |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
440 |
[] => prems (* case: no binders *) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
441 |
| _ => binders (* case: binders *) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
442 |
|> map prep_binder |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
443 |
|> fold_union_env tys |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
444 |
|> (fn t => mk_fresh_star t c) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
445 |
|> (fn t => HOLogic.mk_Trueprop t :: prems) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
446 |
in |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
447 |
mk_full_horn params prems' concl |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
448 |
end |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
449 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
450 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
451 |
(* derives the freshness theorem that there exists a p, such that |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
452 |
(p o as) #* (c, t1,..., tn) *) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
453 |
fun fresh_thm ctxt c parms binders bn_finite_thms = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
454 |
let |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
455 |
fun prep_binder (opt, i) = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
456 |
case opt of |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
457 |
NONE => setify ctxt (nth parms i) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
458 |
| SOME bn => to_set (bn $ (nth parms i)) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
459 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
460 |
fun prep_binder2 (opt, i) = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
461 |
case opt of |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
462 |
NONE => atomify ctxt (nth parms i) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
463 |
| SOME bn => bn $ (nth parms i) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
464 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
465 |
val rhs = HOLogic.mk_tuple ([c] @ parms @ (map prep_binder2 binders)) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
466 |
val lhs = binders |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
467 |
|> map prep_binder |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
468 |
|> fold_union |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
469 |
|> mk_perm (Bound 0) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
470 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
471 |
val goal = mk_fresh_star lhs rhs |
2637
3890483c674f
final version of the ESOP paper; used set+ instead of res as requested by one reviewer
Christian Urban <urbanc@in.tum.de>
parents:
2635
diff
changeset
|
472 |
|> mk_exists ("p", @{typ perm}) |
2626
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
473 |
|> HOLogic.mk_Trueprop |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
474 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
475 |
val ss = bn_finite_thms @ @{thms supp_Pair finite_supp finite_sets_supp} |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
476 |
@ @{thms finite.intros finite_Un finite_set finite_fset} |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
477 |
in |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
478 |
Goal.prove ctxt [] [] goal |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
479 |
(K (HEADGOAL (rtac @{thm at_set_avoiding1} |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
480 |
THEN_ALL_NEW (simp_tac (HOL_ss addsimps ss))))) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
481 |
end |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
482 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
483 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
484 |
(* derives an abs_eq theorem of the form |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
485 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
486 |
Exists q. [as].x = [p o as].(q o x) for non-recursive binders |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
487 |
Exists q. [as].x = [q o as].(q o x) for recursive binders |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
488 |
*) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
489 |
fun abs_eq_thm ctxt fprops p parms bn_finite_thms bn_eqvt permute_bns |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
490 |
(bclause as (BC (bmode, binders, bodies))) = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
491 |
case binders of |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
492 |
[] => [] |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
493 |
| _ => |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
494 |
let |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
495 |
val rec_flag = is_recursive_binder bclause |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
496 |
val binder_trm = comb_binders ctxt bmode parms binders |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
497 |
val body_trm = foldl1 HOLogic.mk_prod (map (nth parms) bodies) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
498 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
499 |
val abs_lhs = mk_abs bmode binder_trm body_trm |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
500 |
val abs_rhs = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
501 |
if rec_flag |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
502 |
then mk_abs bmode (mk_perm (Bound 0) binder_trm) (mk_perm (Bound 0) body_trm) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
503 |
else mk_abs bmode (mk_perm p binder_trm) (mk_perm (Bound 0) body_trm) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
504 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
505 |
val abs_eq = HOLogic.mk_eq (abs_lhs, abs_rhs) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
506 |
val peq = HOLogic.mk_eq (mk_perm (Bound 0) binder_trm, mk_perm p binder_trm) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
507 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
508 |
val goal = HOLogic.mk_conj (abs_eq, peq) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
509 |
|> (fn t => HOLogic.mk_exists ("q", @{typ "perm"}, t)) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
510 |
|> HOLogic.mk_Trueprop |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
511 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
512 |
val ss = fprops @ bn_finite_thms @ @{thms set.simps set_append union_eqvt} |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
513 |
@ @{thms fresh_star_Un fresh_star_Pair fresh_star_list fresh_star_singleton fresh_star_fset |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
514 |
fresh_star_set} @ @{thms finite.intros finite_fset} |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
515 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
516 |
val tac1 = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
517 |
if rec_flag |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
518 |
then resolve_tac @{thms Abs_rename_set' Abs_rename_res' Abs_rename_lst'} |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
519 |
else resolve_tac @{thms Abs_rename_set Abs_rename_res Abs_rename_lst} |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
520 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
521 |
val tac2 = EVERY' [simp_tac (HOL_basic_ss addsimps ss), TRY o simp_tac HOL_ss] |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
522 |
in |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
523 |
[ Goal.prove ctxt [] [] goal (K (HEADGOAL (tac1 THEN_ALL_NEW tac2))) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
524 |
|> (if rec_flag |
2765
7ac5e5c86c7d
introduced framework for finetuning eqvt-rules; this solves problem with permute_pure called in nominal_inductive
Christian Urban <urbanc@in.tum.de>
parents:
2637
diff
changeset
|
525 |
then eqvt_rule ctxt (eqvt_strict_config addpres bn_eqvt) |
7ac5e5c86c7d
introduced framework for finetuning eqvt-rules; this solves problem with permute_pure called in nominal_inductive
Christian Urban <urbanc@in.tum.de>
parents:
2637
diff
changeset
|
526 |
else eqvt_rule ctxt (eqvt_strict_config addpres permute_bns)) ] |
2626
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
527 |
end |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
528 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
529 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
530 |
val setify = @{lemma "xs = ys ==> set xs = set ys" by simp} |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
531 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
532 |
fun case_tac ctxt c bn_finite_thms eq_iff_thms bn_eqvt permute_bns perm_bn_alphas |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
533 |
prems bclausess qexhaust_thm = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
534 |
let |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
535 |
fun aux_tac prem bclauses = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
536 |
case (get_all_binders bclauses) of |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
537 |
[] => EVERY' [rtac prem, atac] |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
538 |
| binders => Subgoal.SUBPROOF (fn {params, prems, concl, context = ctxt, ...} => |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
539 |
let |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
540 |
val parms = map (term_of o snd) params |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
541 |
val fthm = fresh_thm ctxt c parms binders bn_finite_thms |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
542 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
543 |
val ss = @{thms fresh_star_Pair union_eqvt fresh_star_Un} |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
544 |
val (([(_, fperm)], fprops), ctxt') = Obtain.result |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
545 |
(K (EVERY1 [etac exE, |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
546 |
full_simp_tac (HOL_basic_ss addsimps ss), |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
547 |
REPEAT o (etac @{thm conjE})])) [fthm] ctxt |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
548 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
549 |
val abs_eq_thms = flat |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
550 |
(map (abs_eq_thm ctxt fprops (term_of fperm) parms bn_finite_thms bn_eqvt permute_bns) bclauses) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
551 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
552 |
val ((_, eqs), ctxt'') = Obtain.result |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
553 |
(K (EVERY1 |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
554 |
[ REPEAT o (etac @{thm exE}), |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
555 |
REPEAT o (etac @{thm conjE}), |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
556 |
REPEAT o (dtac setify), |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
557 |
full_simp_tac (HOL_basic_ss addsimps @{thms set_append set.simps})])) abs_eq_thms ctxt' |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
558 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
559 |
val (abs_eqs, peqs) = split_filter is_abs_eq eqs |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
560 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
561 |
val fprops' = |
2765
7ac5e5c86c7d
introduced framework for finetuning eqvt-rules; this solves problem with permute_pure called in nominal_inductive
Christian Urban <urbanc@in.tum.de>
parents:
2637
diff
changeset
|
562 |
map (eqvt_rule ctxt (eqvt_strict_config addpres permute_bns)) fprops |
7ac5e5c86c7d
introduced framework for finetuning eqvt-rules; this solves problem with permute_pure called in nominal_inductive
Christian Urban <urbanc@in.tum.de>
parents:
2637
diff
changeset
|
563 |
@ map (eqvt_rule ctxt (eqvt_strict_config addpres bn_eqvt)) fprops |
2626
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
564 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
565 |
(* for freshness conditions *) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
566 |
val tac1 = SOLVED' (EVERY' |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
567 |
[ simp_tac (HOL_basic_ss addsimps peqs), |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
568 |
rewrite_goal_tac (@{thms fresh_star_Un[THEN eq_reflection]}), |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
569 |
conj_tac (DETERM o resolve_tac fprops') ]) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
570 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
571 |
(* for equalities between constructors *) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
572 |
val tac2 = SOLVED' (EVERY' |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
573 |
[ rtac (@{thm ssubst} OF prems), |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
574 |
rewrite_goal_tac (map safe_mk_equiv eq_iff_thms), |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
575 |
rewrite_goal_tac (map safe_mk_equiv abs_eqs), |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
576 |
conj_tac (DETERM o resolve_tac (@{thms refl} @ perm_bn_alphas)) ]) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
577 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
578 |
(* proves goal "P" *) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
579 |
val side_thm = Goal.prove ctxt'' [] [] (term_of concl) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
580 |
(K (EVERY1 [ rtac prem, RANGE [tac1, tac2] ])) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
581 |
|> singleton (ProofContext.export ctxt'' ctxt) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
582 |
in |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
583 |
rtac side_thm 1 |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
584 |
end) ctxt |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
585 |
in |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
586 |
EVERY1 [rtac qexhaust_thm, RANGE (map2 aux_tac prems bclausess)] |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
587 |
end |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
588 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
589 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
590 |
fun prove_strong_exhausts lthy exhausts bclausesss bn_finite_thms eq_iff_thms bn_eqvt permute_bns |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
591 |
perm_bn_alphas = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
592 |
let |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
593 |
val ((_, exhausts'), lthy') = Variable.import true exhausts lthy |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
594 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
595 |
val ([c, a], lthy'') = Variable.variant_fixes ["c", "'a"] lthy' |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
596 |
val c = Free (c, TFree (a, @{sort fs})) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
597 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
598 |
val (ecases, main_concls) = exhausts' (* ecases are of the form (params, prems, concl) *) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
599 |
|> map prop_of |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
600 |
|> map Logic.strip_horn |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
601 |
|> split_list |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
602 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
603 |
val ecases' = (map o map) strip_full_horn ecases |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
604 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
605 |
val premss = (map2 o map2) (mk_ecase_prems lthy'' c) ecases' bclausesss |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
606 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
607 |
fun tac bclausess exhaust {prems, context} = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
608 |
case_tac context c bn_finite_thms eq_iff_thms bn_eqvt permute_bns perm_bn_alphas |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
609 |
prems bclausess exhaust |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
610 |
|
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
611 |
fun prove prems bclausess exhaust concl = |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
612 |
Goal.prove lthy'' [] prems concl (tac bclausess exhaust) |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
613 |
in |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
614 |
map4 prove premss bclausesss exhausts' main_concls |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
615 |
|> ProofContext.export lthy'' lthy |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
616 |
end |
d1bdc281be2b
moved all strong_exhaust code to nominal_dt_quot; tuned examples
Christian Urban <urbanc@in.tum.de>
parents:
2598
diff
changeset
|
617 |
|
2628
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
618 |
|
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
619 |
|
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
620 |
(** strong induction theorems **) |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
621 |
|
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
622 |
fun add_c_prop c c_ty trm = |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
623 |
let |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
624 |
val (P, arg) = dest_comb trm |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
625 |
val (P_name, P_ty) = dest_Free P |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
626 |
val (ty_args, bool) = strip_type P_ty |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
627 |
in |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
628 |
Free (P_name, (c_ty :: ty_args) ---> bool) $ c $ arg |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
629 |
end |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
630 |
|
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
631 |
fun add_qnt_c_prop c_name c_ty trm = |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
632 |
trm |> HOLogic.dest_Trueprop |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
633 |
|> incr_boundvars 1 |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
634 |
|> add_c_prop (Bound 0) c_ty |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
635 |
|> HOLogic.mk_Trueprop |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
636 |
|> mk_all (c_name, c_ty) |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
637 |
|
2629
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
638 |
fun prep_prem lthy c c_name c_ty bclauses (params, prems, concl) = |
2628
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
639 |
let |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
640 |
val tys = map snd params |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
641 |
val binders = get_all_binders bclauses |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
642 |
|
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
643 |
fun prep_binder (opt, i) = |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
644 |
let |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
645 |
val t = Bound (length tys - i - 1) |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
646 |
in |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
647 |
case opt of |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
648 |
NONE => setify_ty lthy (nth tys i) t |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
649 |
| SOME bn => to_set_ty (fastype_of1 (tys, bn $ t)) (bn $ t) |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
650 |
end |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
651 |
|
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
652 |
val prems' = prems |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
653 |
|> map (incr_boundvars 1) |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
654 |
|> map (add_qnt_c_prop c_name c_ty) |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
655 |
|
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
656 |
val prems'' = |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
657 |
case binders of |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
658 |
[] => prems' (* case: no binders *) |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
659 |
| _ => binders (* case: binders *) |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
660 |
|> map prep_binder |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
661 |
|> fold_union_env tys |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
662 |
|> incr_boundvars 1 |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
663 |
|> (fn t => mk_fresh_star_ty c_ty t (Bound 0)) |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
664 |
|> (fn t => HOLogic.mk_Trueprop t :: prems') |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
665 |
|
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
666 |
val concl' = concl |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
667 |
|> HOLogic.dest_Trueprop |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
668 |
|> incr_boundvars 1 |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
669 |
|> add_c_prop (Bound 0) c_ty |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
670 |
|> HOLogic.mk_Trueprop |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
671 |
in |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
672 |
mk_full_horn (params @ [(c_name, c_ty)]) prems'' concl' |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
673 |
end |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
674 |
|
2630
8268b277d240
automated all strong induction lemmas
Christian Urban <urbanc@in.tum.de>
parents:
2629
diff
changeset
|
675 |
fun prove_strong_induct lthy induct exhausts size_thms bclausesss = |
2628
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
676 |
let |
2635
64b4cb2c2bf8
simple cases for string rule inductions
Christian Urban <urbanc@in.tum.de>
parents:
2630
diff
changeset
|
677 |
val ((_, [induct']), lthy') = Variable.import true [induct] lthy |
2628
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
678 |
|
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
679 |
val ([c_name, a], lthy'') = Variable.variant_fixes ["c", "'a"] lthy' |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
680 |
val c_ty = TFree (a, @{sort fs}) |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
681 |
val c = Free (c_name, c_ty) |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
682 |
|
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
683 |
val (prems, concl) = induct' |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
684 |
|> prop_of |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
685 |
|> Logic.strip_horn |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
686 |
|
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
687 |
val concls = concl |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
688 |
|> HOLogic.dest_Trueprop |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
689 |
|> HOLogic.dest_conj |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
690 |
|> map (add_c_prop c c_ty) |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
691 |
|> map HOLogic.mk_Trueprop |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
692 |
|
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
693 |
val prems' = prems |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
694 |
|> map strip_full_horn |
2629
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
695 |
|> map2 (prep_prem lthy'' c c_name c_ty) (flat bclausesss) |
2628
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
696 |
|
2629
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
697 |
fun pat_tac ctxt thm = |
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
698 |
Subgoal.FOCUS (fn {params, context, ...} => |
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
699 |
let |
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
700 |
val thy = ProofContext.theory_of context |
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
701 |
val ty_parms = map (fn (_, ct) => (fastype_of (term_of ct), ct)) params |
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
702 |
val vs = Term.add_vars (prop_of thm) [] |
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
703 |
val vs_tys = map (Type.legacy_freeze_type o snd) vs |
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
704 |
val vs_ctrms = map (cterm_of thy o Var) vs |
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
705 |
val assigns = map (lookup ty_parms) vs_tys |
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
706 |
|
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
707 |
val thm' = cterm_instantiate (vs_ctrms ~~ assigns) thm |
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
708 |
in |
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
709 |
rtac thm' 1 |
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
710 |
end) ctxt |
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
711 |
THEN_ALL_NEW asm_full_simp_tac HOL_basic_ss |
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
712 |
|
2630
8268b277d240
automated all strong induction lemmas
Christian Urban <urbanc@in.tum.de>
parents:
2629
diff
changeset
|
713 |
val size_simp_tac = |
8268b277d240
automated all strong induction lemmas
Christian Urban <urbanc@in.tum.de>
parents:
2629
diff
changeset
|
714 |
simp_tac (size_simpset addsimps (@{thms comp_def snd_conv} @ size_thms)) |
8268b277d240
automated all strong induction lemmas
Christian Urban <urbanc@in.tum.de>
parents:
2629
diff
changeset
|
715 |
in |
8268b277d240
automated all strong induction lemmas
Christian Urban <urbanc@in.tum.de>
parents:
2629
diff
changeset
|
716 |
Goal.prove_multi lthy'' [] prems' concls |
2629
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
717 |
(fn {prems, context} => |
2630
8268b277d240
automated all strong induction lemmas
Christian Urban <urbanc@in.tum.de>
parents:
2629
diff
changeset
|
718 |
Induction_Schema.induction_schema_tac context prems |
2629
ffb5a181844b
proper application of induction_schema and strong_exhaust rules; needs local fix in induction_schema.ML
Christian Urban <urbanc@in.tum.de>
parents:
2628
diff
changeset
|
719 |
THEN RANGE (map (pat_tac context) exhausts) 1 |
2630
8268b277d240
automated all strong induction lemmas
Christian Urban <urbanc@in.tum.de>
parents:
2629
diff
changeset
|
720 |
THEN prove_termination_ind context 1 |
8268b277d240
automated all strong induction lemmas
Christian Urban <urbanc@in.tum.de>
parents:
2629
diff
changeset
|
721 |
THEN ALLGOALS size_simp_tac) |
8268b277d240
automated all strong induction lemmas
Christian Urban <urbanc@in.tum.de>
parents:
2629
diff
changeset
|
722 |
|> ProofContext.export lthy'' lthy |
2628
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
723 |
end |
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
724 |
|
16ffbc8442ca
generated goals for strong induction theorems.
Christian Urban <urbanc@in.tum.de>
parents:
2626
diff
changeset
|
725 |
|
2337
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
726 |
end (* structure *) |
b151399bd2c3
fixed according to changes in quotient
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
727 |