File: INDUCT_TAC.doc

package info (click to toggle)
hol-light 20170109-1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 36,568 kB
  • ctags: 8,549
  • sloc: ml: 540,018; cpp: 439; lisp: 286; java: 279; makefile: 262; sh: 229; yacc: 108; perl: 78; ansic: 57; sed: 39
file content (60 lines) | stat: -rw-r--r-- 1,870 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
\DOC INDUCT_TAC

\TYPE {INDUCT_TAC : tactic}

\SYNOPSIS
Performs tactical proof by mathematical induction on the natural numbers.

\KEYWORDS
tactic, induction.

\DESCRIBE
{INDUCT_TAC} reduces a goal {A ?- !n. P[n]}, where {n} has type {num}, to two
subgoals corresponding to the base and step cases in a proof by mathematical
induction on {n}. The induction hypothesis appears among the assumptions of the
subgoal for the step case.  The specification of {INDUCT_TAC} is:
{
                A ?- !n. P
    ========================================  INDUCT_TAC
     A ?- P[0/n]     A u {{P}} ?- P[SUC n'/n]
}
\noindent where {n'} is a primed variant of {n} that does not appear free in
the assumptions {A} (usually, {n'} is just {n}).

\FAILURE
{INDUCT_TAC g} fails unless the conclusion of the goal {g} has the form
{`!n. t`}, where the variable {n} has type {num}.

\EXAMPLE
Suppose we want to prove the classic `sum of the first {n} integers' theorem:
{
  # g `!n. nsum(1..n) (\i. i) = (n * (n + 1)) DIV 2`;;
}
\noindent This is a classic example of an inductive proof. If we apply
induction, we get two subgoals:
{
  # e INDUCT_TAC;;
  val it : goalstack = 2 subgoals (2 total)

   0 [`nsum (1 .. n) (\i. i) = (n * (n + 1)) DIV 2`]

  `nsum (1 .. SUC n) (\i. i) = (SUC n * (SUC n + 1)) DIV 2`

  `nsum (1 .. 0) (\i. i) = (0 * (0 + 1)) DIV 2`
}
\noindent each of which can be solved by just:
{
  # e(ASM_REWRITE_TAC[NSUM_CLAUSES_NUMSEG] THEN ARITH_TAC);;
}

\COMMENTS
Essentially the same effect can be had by {MATCH_MP_TAC num_INDUCTION}. This
does not subsequently break down the goal in such a convenient way, but gives
more control over choice of variable. You can also equally well use it for
other kinds of induction, e.g. use {MATCH_MP_TAC num_WF} for wellfounded
(complete, noetherian) induction.

\SEEALSO
LIST_INDUCT_TAC, MATCH_MP_TAC, WF_INDUCT_TAC.

\ENDDOC