src/LCF/ex/Ex2.thy
author wenzelm
Sat, 03 Sep 2005 17:54:10 +0200
changeset 17248 81bf91654e73
parent 4905 be73ddff6c5a
child 19755 90f80de04c46
permissions -rw-r--r--
converted to Isar theory format;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
4905
be73ddff6c5a proper thy files;
wenzelm
parents:
diff changeset
     1
17248
81bf91654e73 converted to Isar theory format;
wenzelm
parents: 4905
diff changeset
     2
(* $Id$ *)
81bf91654e73 converted to Isar theory format;
wenzelm
parents: 4905
diff changeset
     3
81bf91654e73 converted to Isar theory format;
wenzelm
parents: 4905
diff changeset
     4
header {* Example 3.8 *}
4905
be73ddff6c5a proper thy files;
wenzelm
parents:
diff changeset
     5
17248
81bf91654e73 converted to Isar theory format;
wenzelm
parents: 4905
diff changeset
     6
theory Ex2
81bf91654e73 converted to Isar theory format;
wenzelm
parents: 4905
diff changeset
     7
imports LCF
81bf91654e73 converted to Isar theory format;
wenzelm
parents: 4905
diff changeset
     8
begin
4905
be73ddff6c5a proper thy files;
wenzelm
parents:
diff changeset
     9
be73ddff6c5a proper thy files;
wenzelm
parents:
diff changeset
    10
consts
17248
81bf91654e73 converted to Isar theory format;
wenzelm
parents: 4905
diff changeset
    11
  P     :: "'a => tr"
81bf91654e73 converted to Isar theory format;
wenzelm
parents: 4905
diff changeset
    12
  F     :: "'a => 'a"
81bf91654e73 converted to Isar theory format;
wenzelm
parents: 4905
diff changeset
    13
  G     :: "'a => 'a"
81bf91654e73 converted to Isar theory format;
wenzelm
parents: 4905
diff changeset
    14
  H     :: "'a => 'b => 'b"
81bf91654e73 converted to Isar theory format;
wenzelm
parents: 4905
diff changeset
    15
  K     :: "('a => 'b => 'b) => ('a => 'b => 'b)"
4905
be73ddff6c5a proper thy files;
wenzelm
parents:
diff changeset
    16
17248
81bf91654e73 converted to Isar theory format;
wenzelm
parents: 4905
diff changeset
    17
axioms
81bf91654e73 converted to Isar theory format;
wenzelm
parents: 4905
diff changeset
    18
  F_strict:     "F(UU) = UU"
81bf91654e73 converted to Isar theory format;
wenzelm
parents: 4905
diff changeset
    19
  K:            "K = (%h x y. P(x) => y | F(h(G(x),y)))"
81bf91654e73 converted to Isar theory format;
wenzelm
parents: 4905
diff changeset
    20
  H:            "H = FIX(K)"
81bf91654e73 converted to Isar theory format;
wenzelm
parents: 4905
diff changeset
    21
81bf91654e73 converted to Isar theory format;
wenzelm
parents: 4905
diff changeset
    22
ML {* use_legacy_bindings (the_context ()) *}
4905
be73ddff6c5a proper thy files;
wenzelm
parents:
diff changeset
    23
be73ddff6c5a proper thy files;
wenzelm
parents:
diff changeset
    24
end