author | wenzelm |
Fri, 05 May 2023 12:17:29 +0200 | |
changeset 77968 | 8ce2425a7c94 |
parent 70520 | 11d8517d9384 |
child 78883 | 5de1c19ccd92 |
permissions | -rw-r--r-- |
59931 | 1 |
(* Title: Tools/induction.ML |
2 |
Author: Tobias Nipkow, TU Muenchen |
|
3 |
||
4 |
Alternative proof method "induction" that gives induction hypotheses the |
|
5 |
name "IH". |
|
6 |
*) |
|
7 |
||
45014
0e847655b2d8
New proof method "induction" that gives induction hypotheses the name IH.
nipkow
parents:
diff
changeset
|
8 |
signature INDUCTION = |
0e847655b2d8
New proof method "induction" that gives induction hypotheses the name IH.
nipkow
parents:
diff
changeset
|
9 |
sig |
61844 | 10 |
val induction_context_tactic: bool -> (binding option * (term * bool)) option list list -> |
45014
0e847655b2d8
New proof method "induction" that gives induction hypotheses the name IH.
nipkow
parents:
diff
changeset
|
11 |
(string * typ) list list -> term option list -> thm list option -> |
61841
4d3527b94f2a
more general types Proof.method / context_tactic;
wenzelm
parents:
59970
diff
changeset
|
12 |
thm list -> int -> context_tactic |
61844 | 13 |
val induction_tac: Proof.context -> bool -> (binding option * (term * bool)) option list list -> |
14 |
(string * typ) list list -> term option list -> thm list option -> |
|
15 |
thm list -> int -> tactic |
|
45014
0e847655b2d8
New proof method "induction" that gives induction hypotheses the name IH.
nipkow
parents:
diff
changeset
|
16 |
end |
0e847655b2d8
New proof method "induction" that gives induction hypotheses the name IH.
nipkow
parents:
diff
changeset
|
17 |
|
0e847655b2d8
New proof method "induction" that gives induction hypotheses the name IH.
nipkow
parents:
diff
changeset
|
18 |
structure Induction: INDUCTION = |
0e847655b2d8
New proof method "induction" that gives induction hypotheses the name IH.
nipkow
parents:
diff
changeset
|
19 |
struct |
0e847655b2d8
New proof method "induction" that gives induction hypotheses the name IH.
nipkow
parents:
diff
changeset
|
20 |
|
0e847655b2d8
New proof method "induction" that gives induction hypotheses the name IH.
nipkow
parents:
diff
changeset
|
21 |
val ind_hypsN = "IH"; |
0e847655b2d8
New proof method "induction" that gives induction hypotheses the name IH.
nipkow
parents:
diff
changeset
|
22 |
|
0e847655b2d8
New proof method "induction" that gives induction hypotheses the name IH.
nipkow
parents:
diff
changeset
|
23 |
fun preds_of t = |
59931 | 24 |
(case strip_comb t of |
45014
0e847655b2d8
New proof method "induction" that gives induction hypotheses the name IH.
nipkow
parents:
diff
changeset
|
25 |
(p as Var _, _) => [p] |
0e847655b2d8
New proof method "induction" that gives induction hypotheses the name IH.
nipkow
parents:
diff
changeset
|
26 |
| (p as Free _, _) => [p] |
59931 | 27 |
| (_, ts) => maps preds_of ts); |
45014
0e847655b2d8
New proof method "induction" that gives induction hypotheses the name IH.
nipkow
parents:
diff
changeset
|
28 |
|
61844 | 29 |
val induction_context_tactic = |
30 |
Induct.gen_induct_context_tactic (fn arg as ((cases, consumes), th) => |
|
31 |
if not (forall (null o #2 o #1) cases) then arg |
|
32 |
else |
|
33 |
let |
|
34 |
val (prems, concl) = Logic.strip_horn (Thm.prop_of th); |
|
35 |
val prems' = drop consumes prems; |
|
36 |
val ps = preds_of concl; |
|
37 |
||
38 |
fun hname_of t = |
|
39 |
if exists_subterm (member (op aconv) ps) t |
|
40 |
then ind_hypsN else Rule_Cases.case_hypsN; |
|
41 |
||
42 |
val hnamess = map (map hname_of o Logic.strip_assums_hyp) prems'; |
|
43 |
val n = Int.min (length hnamess, length cases); |
|
44 |
val cases' = |
|
45 |
map (fn (((cn, _), concls), hns) => ((cn, hns), concls)) |
|
46 |
(take n cases ~~ take n hnamess); |
|
47 |
in ((cases', consumes), th) end); |
|
45014
0e847655b2d8
New proof method "induction" that gives induction hypotheses the name IH.
nipkow
parents:
diff
changeset
|
48 |
|
61844 | 49 |
fun induction_tac ctxt x1 x2 x3 x4 x5 x6 x7 = |
70520 | 50 |
NO_CONTEXT_TACTIC ctxt (induction_context_tactic x1 x2 x3 x4 x5 x6 x7); |
45014
0e847655b2d8
New proof method "induction" that gives induction hypotheses the name IH.
nipkow
parents:
diff
changeset
|
51 |
|
61844 | 52 |
val _ = |
67149 | 53 |
Theory.local_setup (Induct.gen_induct_setup \<^binding>\<open>induction\<close> induction_context_tactic); |
45014
0e847655b2d8
New proof method "induction" that gives induction hypotheses the name IH.
nipkow
parents:
diff
changeset
|
54 |
|
0e847655b2d8
New proof method "induction" that gives induction hypotheses the name IH.
nipkow
parents:
diff
changeset
|
55 |
end |