src/FOL/ex/Prolog.ML
author paulson
Thu, 21 Mar 1996 13:02:26 +0100
changeset 1601 0ef6ea27ab15
parent 1459 d12da312eff4
child 5050 e925308df78b
permissions -rw-r--r--
Changes required by removal of the theory argument of Theorem
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1459
d12da312eff4 expanded tabs
clasohm
parents: 0
diff changeset
     1
(*  Title:      FOL/ex/prolog.ML
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     2
    ID:         $Id$
1459
d12da312eff4 expanded tabs
clasohm
parents: 0
diff changeset
     3
    Author:     Lawrence C Paulson, Cambridge University Computer Laboratory
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     4
    Copyright   1992  University of Cambridge
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     5
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     6
For ex/prolog.thy.  First-Order Logic: PROLOG examples
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     7
*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     8
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     9
open Prolog;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    10
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    11
goal Prolog.thy "app(a:b:c:Nil, d:e:Nil, ?x)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    12
by (resolve_tac [appNil,appCons] 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    13
by (resolve_tac [appNil,appCons] 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    14
by (resolve_tac [appNil,appCons] 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    15
by (resolve_tac [appNil,appCons] 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    16
prth (result());
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    17
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    18
goal Prolog.thy "app(?x, c:d:Nil, a:b:c:d:Nil)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    19
by (REPEAT (resolve_tac [appNil,appCons] 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    20
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    21
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    22
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    23
goal Prolog.thy "app(?x, ?y, a:b:c:d:Nil)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    24
by (REPEAT (resolve_tac [appNil,appCons] 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    25
back();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    26
back();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    27
back();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    28
back();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    29
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    30
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    31
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    32
(*app([x1,...,xn], y, ?z) requires (n+1) inferences*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    33
(*rev([x1,...,xn], ?y) requires (n+1)(n+2)/2 inferences*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    34
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    35
goal Prolog.thy "rev(a:b:c:d:Nil, ?x)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    36
val rules = [appNil,appCons,revNil,revCons];
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    37
by (REPEAT (resolve_tac rules 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    38
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    39
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    40
goal Prolog.thy "rev(a:b:c:d:e:f:g:h:i:j:k:l:m:n:Nil, ?w)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    41
by (REPEAT (resolve_tac rules 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    42
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    43
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    44
goal Prolog.thy "rev(?x, a:b:c:Nil)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    45
by (REPEAT (resolve_tac rules 1)); (*does not solve it directly!*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    46
back();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    47
back();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    48
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    49
(*backtracking version*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    50
val prolog_tac = DEPTH_FIRST (has_fewer_prems 1) (resolve_tac rules 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    51
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    52
choplev 0;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    53
by prolog_tac;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    54
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    55
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    56
goal Prolog.thy "rev(a:?x:c:?y:Nil, d:?z:b:?u)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    57
by prolog_tac;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    58
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    59
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    60
(*rev([a..p], ?w) requires 153 inferences *)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    61
goal Prolog.thy "rev(a:b:c:d:e:f:g:h:i:j:k:l:m:n:o:p:Nil, ?w)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    62
by (DEPTH_SOLVE (resolve_tac ([refl,conjI]@rules) 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    63
(*Poly/ML: 4 secs >> 38 lips*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    64
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    65
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    66
(*?x has 16, ?y has 32;  rev(?y,?w) requires 561 (rather large) inferences;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    67
  total inferences = 2 + 1 + 17 + 561 = 581*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    68
goal Prolog.thy
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    69
    "a:b:c:d:e:f:g:h:i:j:k:l:m:n:o:p:Nil = ?x & app(?x,?x,?y) & rev(?y,?w)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    70
by (DEPTH_SOLVE (resolve_tac ([refl,conjI]@rules) 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    71
(*Poly/ML: 29 secs >> 20 lips*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    72
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    73
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    74
writeln"Reached end of file.";