src/FOL/ex/list.ML
author paulson
Mon, 27 Oct 1997 10:34:17 +0100
changeset 4006 84a5efc95dcf
parent 0 a5a9c433f639
permissions -rw-r--r--
Deleted two needless theorems
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     1
(*  Title: 	FOL/ex/list
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     2
    ID:         $Id$
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     3
    Author: 	Tobias Nipkow
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     4
    Copyright   1991  University of Cambridge
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     5
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     6
For ex/list.thy.  Examples of simplification and induction on lists
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     7
*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     8
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     9
open List;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    10
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    11
val prems = goal List.thy "[| P([]);  !!x l. P(x.l) |] ==> All(P)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    12
by (rtac list_ind 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    13
by (REPEAT (resolve_tac (prems@[allI,impI]) 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    14
val list_exh = result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    15
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    16
val list_rew_thms = [list_distinct1,list_distinct2,app_nil,app_cons,
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    17
		     hd_eq,tl_eq,forall_nil,forall_cons,list_free,
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    18
		     len_nil,len_cons,at_0,at_succ];
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    19
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    20
val list_ss = nat_ss addsimps list_rew_thms;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    21
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    22
goal List.thy "~l=[] --> hd(l).tl(l) = l";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    23
by(IND_TAC list_exh (simp_tac list_ss) "l" 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    24
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    25
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    26
goal List.thy "(l1++l2)++l3 = l1++(l2++l3)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    27
by(IND_TAC list_ind (simp_tac list_ss) "l1" 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    28
val append_assoc = result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    29
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    30
goal List.thy "l++[] = l";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    31
by(IND_TAC list_ind (simp_tac list_ss) "l" 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    32
val app_nil_right = result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    33
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    34
goal List.thy "l1++l2=[] <-> l1=[] & l2=[]";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    35
by(IND_TAC list_exh (simp_tac list_ss) "l1" 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    36
val app_eq_nil_iff = result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    37
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    38
goal List.thy "forall(l++l',P) <-> forall(l,P) & forall(l',P)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    39
by(IND_TAC list_ind (simp_tac list_ss) "l" 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    40
val forall_app = result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    41
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    42
goal List.thy "forall(l,%x.P(x)&Q(x)) <-> forall(l,P) & forall(l,Q)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    43
by(IND_TAC list_ind (simp_tac list_ss) "l" 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    44
by(fast_tac FOL_cs 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    45
val forall_conj = result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    46
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    47
goal List.thy "~l=[] --> forall(l,P) <-> P(hd(l)) & forall(tl(l),P)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    48
by(IND_TAC list_ind (simp_tac list_ss) "l" 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    49
val forall_ne = result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    50
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    51
(*** Lists with natural numbers ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    52
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    53
goal List.thy "len(l1++l2) = len(l1)+len(l2)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    54
by (IND_TAC list_ind (simp_tac list_ss) "l1" 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    55
val len_app = result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    56
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    57
goal List.thy "i<len(l1) --> at(l1++l2,i) = at(l1,i)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    58
by (IND_TAC list_ind (simp_tac list_ss) "l1" 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    59
by (REPEAT (rtac allI 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    60
by (rtac impI 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    61
by (ALL_IND_TAC nat_exh (asm_simp_tac list_ss) 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    62
val at_app1 = result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    63
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    64
goal List.thy "at(l1++(x.l2), len(l1)) = x";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    65
by (IND_TAC list_ind (simp_tac list_ss) "l1" 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    66
val at_app_hd2 = result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    67