src/CCL/Trancl.thy
author wenzelm
Sat, 11 Feb 2006 17:17:47 +0100
changeset 19012 2577ac76cdc6
parent 17456 bcf7544875b2
child 20140 98acc6d0fab6
permissions -rw-r--r--
tuned;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
17456
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
     1
(*  Title:      CCL/Trancl.thy
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     2
    ID:         $Id$
1474
3f7d67927fe2 expanded tabs
clasohm
parents: 0
diff changeset
     3
    Author:     Martin Coen, Cambridge University Computer Laboratory
0
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
17456
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
     7
header {* Transitive closure of a relation *}
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
     8
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
     9
theory Trancl
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
    10
imports CCL
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
    11
begin
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    12
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    13
consts
17456
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
    14
  trans   :: "i set => o"                   (*transitivity predicate*)
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
    15
  id      :: "i set"
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
    16
  rtrancl :: "i set => i set"               ("(_^*)" [100] 100)
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
    17
  trancl  :: "i set => i set"               ("(_^+)" [100] 100)
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
    18
  O       :: "[i set,i set] => i set"       (infixr 60)
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    19
17456
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
    20
axioms
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
    21
  trans_def:       "trans(r) == (ALL x y z. <x,y>:r --> <y,z>:r --> <x,z>:r)"
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
    22
  comp_def:        (*composition of relations*)
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
    23
                   "r O s == {xz. EX x y z. xz = <x,z> & <x,y>:s & <y,z>:r}"
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
    24
  id_def:          (*the identity relation*)
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
    25
                   "id == {p. EX x. p = <x,x>}"
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
    26
  rtrancl_def:     "r^* == lfp(%s. id Un (r O s))"
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
    27
  trancl_def:      "r^+ == r O rtrancl(r)"
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
    28
bcf7544875b2 converted to Isar theory format;
wenzelm
parents: 1474
diff changeset
    29
ML {* use_legacy_bindings (the_context ()) *}
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    30
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    31
end