src/ZF/ex/BT.ML
author clasohm
Fri, 15 Jul 1994 13:34:31 +0200
changeset 477 53fc8ad84b33
parent 445 7b6d8b8d4580
child 515 abcc438e7c27
permissions -rw-r--r--
added thy_name to Datatype_Fun's parameter
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     1
(*  Title: 	ZF/ex/bt.ML
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     2
    ID:         $Id$
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     3
    Author: 	Lawrence C Paulson, Cambridge University Computer Laboratory
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     4
    Copyright   1993  University of Cambridge
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     5
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     6
Datatype definition of binary trees
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     7
*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     8
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     9
structure BT = Datatype_Fun
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    10
 (val thy = Univ.thy;
477
53fc8ad84b33 added thy_name to Datatype_Fun's parameter
clasohm
parents: 445
diff changeset
    11
  val thy_name = "BT";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    12
  val rec_specs = 
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    13
      [("bt", "univ(A)",
445
7b6d8b8d4580 changed syntax of datatype declaration
clasohm
parents: 71
diff changeset
    14
	  [(["Lf"],"i",NoSyn), 
7b6d8b8d4580 changed syntax of datatype declaration
clasohm
parents: 71
diff changeset
    15
           (["Br"],"[i,i,i]=>i", NoSyn)])];
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    16
  val rec_styp = "i=>i";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    17
  val sintrs = 
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    18
	  ["Lf : bt(A)",
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    19
	   "[| a: A;  t1: bt(A);  t2: bt(A) |] ==> Br(a,t1,t2) : bt(A)"];
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    20
  val monos = [];
71
729fe026c5f3 sample datatype defs now use datatype_intrs, datatype_elims
lcp
parents: 56
diff changeset
    21
  val type_intrs = datatype_intrs
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    22
  val type_elims = []);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    23
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    24
val [LfI, BrI] = BT.intrs;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    25
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    26
(*Perform induction on l, then prove the major premise using prems. *)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    27
fun bt_ind_tac a prems i = 
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    28
    EVERY [res_inst_tac [("x",a)] BT.induct i,
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    29
	   rename_last_tac a ["1","2"] (i+2),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    30
	   ares_tac prems i];
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    31
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    32
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    33
(**  Lemmas to justify using "bt" in other recursive type definitions **)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    34
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    35
goalw BT.thy BT.defs "!!A B. A<=B ==> bt(A) <= bt(B)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    36
by (rtac lfp_mono 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    37
by (REPEAT (rtac BT.bnd_mono 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    38
by (REPEAT (ares_tac (univ_mono::basic_monos) 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    39
val bt_mono = result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    40
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    41
goalw BT.thy (BT.defs@BT.con_defs) "bt(univ(A)) <= univ(A)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    42
by (rtac lfp_lowerbound 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    43
by (rtac (A_subset_univ RS univ_mono) 2);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    44
by (fast_tac (ZF_cs addSIs [zero_in_univ, Inl_in_univ, Inr_in_univ,
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    45
			    Pair_in_univ]) 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    46
val bt_univ = result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    47
56
2caa6f49f06e ZF/ex/tf/tree,forest_unfold: streamlined the proofs
lcp
parents: 0
diff changeset
    48
val bt_subset_univ = standard ([bt_mono, bt_univ] MRS subset_trans);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    49