src/FOL/ex/IffOracle.thy
author haftmann
Thu, 16 Jun 2005 10:30:26 +0200
changeset 16406 4f393b8f84b7
parent 16063 7dd4eb2c8055
child 16417 9bc16273c2d4
permissions -rw-r--r--
isa-migrate ++
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
16063
7dd4eb2c8055 oracle example converted to Isar
paulson
parents: 3817
diff changeset
     7
header{*Example of Declaring an Oracle*}
7dd4eb2c8055 oracle example converted to Isar
paulson
parents: 3817
diff changeset
     8
7dd4eb2c8055 oracle example converted to Isar
paulson
parents: 3817
diff changeset
     9
theory IffOracle = FOL:
3817
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    10
16063
7dd4eb2c8055 oracle example converted to Isar
paulson
parents: 3817
diff changeset
    11
text{*This oracle makes tautologies of the form "P <-> P <-> P <-> P".
7dd4eb2c8055 oracle example converted to Isar
paulson
parents: 3817
diff changeset
    12
The length is specified by an integer, which is checked to be even and 
7dd4eb2c8055 oracle example converted to Isar
paulson
parents: 3817
diff changeset
    13
positive.*}
3817
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    14
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    15
ML
16063
7dd4eb2c8055 oracle example converted to Isar
paulson
parents: 3817
diff changeset
    16
{*
3817
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    17
local
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    18
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    19
(* internal syntactic declarations *)
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    20
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    21
val oT = Type("o",[]);
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    22
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    23
val iff = Const("op <->", [oT,oT]--->oT);
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    24
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    25
fun mk_iff 1 = Free("P", oT)
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    26
  | mk_iff n = iff $ Free("P", oT) $ mk_iff (n-1);
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    27
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    28
val Trueprop = Const("Trueprop",oT-->propT);
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    29
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    30
in
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    31
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    32
(*new exception constructor for passing arguments to the oracle*)
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    33
exception IffOracleExn of int;
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    34
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    35
fun mk_iff_oracle (sign, IffOracleExn n) =
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    36
  if n > 0 andalso n mod 2 = 0
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    37
  then Trueprop $ mk_iff n
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    38
  else raise IffOracleExn n;
f20f193d42b4 removed declIffOracle;
wenzelm
parents: 1537
diff changeset
    39
16063
7dd4eb2c8055 oracle example converted to Isar
paulson
parents: 3817
diff changeset
    40
end
7dd4eb2c8055 oracle example converted to Isar
paulson
parents: 3817
diff changeset
    41
*}
7dd4eb2c8055 oracle example converted to Isar
paulson
parents: 3817
diff changeset
    42
7dd4eb2c8055 oracle example converted to Isar
paulson
parents: 3817
diff changeset
    43
oracle
7dd4eb2c8055 oracle example converted to Isar
paulson
parents: 3817
diff changeset
    44
  iff = mk_iff_oracle
7dd4eb2c8055 oracle example converted to Isar
paulson
parents: 3817
diff changeset
    45
7dd4eb2c8055 oracle example converted to Isar
paulson
parents: 3817
diff changeset
    46
end
7dd4eb2c8055 oracle example converted to Isar
paulson
parents: 3817
diff changeset
    47
7dd4eb2c8055 oracle example converted to Isar
paulson
parents: 3817
diff changeset
    48