src/FOL/ex/IffOracle.thy
author wenzelm
Wed, 09 Jun 2004 18:52:42 +0200
changeset 14898 a25550451b51
parent 3817 f20f193d42b4
child 16063 7dd4eb2c8055
permissions -rw-r--r--
Url.File;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
3817
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
     1
(*  Title:      FOL/ex/IffOracle.thy
1537
3f51f0945a3e Example of declaring oracles
paulson
parents:
diff changeset
     2
    ID:         $Id$
3f51f0945a3e Example of declaring oracles
paulson
parents:
diff changeset
     3
    Author:     Lawrence C Paulson, Cambridge University Computer Laboratory
3f51f0945a3e Example of declaring oracles
paulson
parents:
diff changeset
     4
    Copyright   1996  University of Cambridge
3f51f0945a3e Example of declaring oracles
paulson
parents:
diff changeset
     5
3f51f0945a3e Example of declaring oracles
paulson
parents:
diff changeset
     6
Example of how to declare an oracle
3f51f0945a3e Example of declaring oracles
paulson
parents:
diff changeset
     7
*)
3f51f0945a3e Example of declaring oracles
paulson
parents:
diff changeset
     8
3817
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
     9
IffOracle = FOL +
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    10
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    11
oracle
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    12
  iff = mk_iff_oracle
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    13
1537
3f51f0945a3e Example of declaring oracles
paulson
parents:
diff changeset
    14
end
3817
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    15
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    16
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    17
ML
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    18
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    19
local
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    20
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    21
(* internal syntactic declarations *)
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    22
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    23
val oT = Type("o",[]);
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    24
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    25
val iff = Const("op <->", [oT,oT]--->oT);
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    26
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    27
fun mk_iff 1 = Free("P", oT)
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    28
  | mk_iff n = iff $ Free("P", oT) $ mk_iff (n-1);
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    29
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    30
val Trueprop = Const("Trueprop",oT-->propT);
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    31
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    32
in
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    33
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    34
(*new exception constructor for passing arguments to the oracle*)
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    35
exception IffOracleExn of int;
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    36
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    37
(*oracle makes tautologies of the form "P <-> P <-> P <-> P"*)
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    38
fun mk_iff_oracle (sign, IffOracleExn n) =
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    39
  if n > 0 andalso n mod 2 = 0
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    40
  then Trueprop $ mk_iff n
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    41
  else raise IffOracleExn n;
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    42
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    43
end;