src/CTT/Bool.thy
author paulson
Wed, 08 May 1996 17:57:05 +0200
changeset 1736 fe0b459273f2
parent 1474 3f7d67927fe2
child 3837 d7f033c74b38
permissions -rw-r--r--
Predicates are now uncurried in both induction rules, regardless of how tuples are nested. Only returns mutual_induct if there is true mutual recursion.

(*  Title:      CTT/bool
    ID:         $Id$
    Author:     Lawrence C Paulson, Cambridge University Computer Laboratory
    Copyright   1991  University of Cambridge

The two-element type (booleans and conditionals)
*)

Bool = CTT +

consts Bool             :: "t"
       true,false       :: "i"
       cond             :: "[i,i,i]=>i"
rules
  Bool_def      "Bool == T+T"
  true_def      "true == inl(tt)"
  false_def     "false == inr(tt)"
  cond_def      "cond(a,b,c) == when(a, %u.b, %u.c)"
end