src/FOLP/ex/Prolog.ML
author haftmann
Mon, 05 Jul 2010 15:12:20 +0200
changeset 37715 44b27ea94a16
parent 35762 af3ff2ba4c54
permissions -rw-r--r--
tuned proof
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
24584
01e83ffa6c54 fixed title
haftmann
parents: 5061
diff changeset
     1
(*  Title:      FOLP/ex/Prolog.ML
1459
d12da312eff4 expanded tabs
clasohm
parents: 0
diff changeset
     2
    Author:     Lawrence C Paulson, Cambridge University Computer Laboratory
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     3
    Copyright   1992  University of Cambridge
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     4
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     5
For ex/prolog.thy.  First-Order Logic: PROLOG examples
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     6
*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     7
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     8
open Prolog;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     9
5061
f947332d5465 isatool fixgoal;
wenzelm
parents: 1464
diff changeset
    10
Goal "app(a:b:c:Nil, d:e:Nil, ?x)";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    11
by (resolve_tac [appNil,appCons] 1);
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);
32091
30e2ffbba718 proper context for Display.pretty_thm etc. or old-style versions Display.pretty_thm_global, Display.pretty_thm_without_context etc.;
wenzelm
parents: 24584
diff changeset
    15
result();
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    16
5061
f947332d5465 isatool fixgoal;
wenzelm
parents: 1464
diff changeset
    17
Goal "app(?x, c:d:Nil, a:b:c:d:Nil)";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    18
by (REPEAT (resolve_tac [appNil,appCons] 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    19
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    20
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    21
5061
f947332d5465 isatool fixgoal;
wenzelm
parents: 1464
diff changeset
    22
Goal "app(?x, ?y, a:b:c:d:Nil)";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    23
by (REPEAT (resolve_tac [appNil,appCons] 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    24
back();
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
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    29
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    30
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    31
(*app([x1,...,xn], y, ?z) requires (n+1) inferences*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    32
(*rev([x1,...,xn], ?y) requires (n+1)(n+2)/2 inferences*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    33
5061
f947332d5465 isatool fixgoal;
wenzelm
parents: 1464
diff changeset
    34
Goal "rev(a:b:c:d:Nil, ?x)";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    35
val rules = [appNil,appCons,revNil,revCons];
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    36
by (REPEAT (resolve_tac rules 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    37
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    38
5061
f947332d5465 isatool fixgoal;
wenzelm
parents: 1464
diff changeset
    39
Goal "rev(a:b:c:d:e:f:g:h:i:j:k:l:m:n:Nil, ?w)";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    40
by (REPEAT (resolve_tac rules 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    41
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    42
5061
f947332d5465 isatool fixgoal;
wenzelm
parents: 1464
diff changeset
    43
Goal "rev(?x, a:b:c:Nil)";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    44
by (REPEAT (resolve_tac rules 1)); (*does not solve it directly!*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    45
back();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    46
back();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    47
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    48
(*backtracking version*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    49
val prolog_tac = DEPTH_FIRST (has_fewer_prems 1) (resolve_tac rules 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    50
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    51
choplev 0;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    52
by prolog_tac;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    53
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    54
5061
f947332d5465 isatool fixgoal;
wenzelm
parents: 1464
diff changeset
    55
Goal "rev(a:?x:c:?y:Nil, d:?z:b:?u)";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    56
by prolog_tac;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    57
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    58
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    59
(*rev([a..p], ?w) requires 153 inferences *)
5061
f947332d5465 isatool fixgoal;
wenzelm
parents: 1464
diff changeset
    60
Goal "rev(a:b:c:d:e:f:g:h:i:j:k:l:m:n:o:p:Nil, ?w)";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    61
by (DEPTH_SOLVE (resolve_tac ([refl,conjI]@rules) 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    62
(*Poly/ML: 4 secs >> 38 lips*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    63
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    64
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    65
(*?x has 16, ?y has 32;  rev(?y,?w) requires 561 (rather large) inferences;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    66
  total inferences = 2 + 1 + 17 + 561 = 581*)
5061
f947332d5465 isatool fixgoal;
wenzelm
parents: 1464
diff changeset
    67
Goal
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    68
    "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
    69
by (DEPTH_SOLVE (resolve_tac ([refl,conjI]@rules) 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    70
(*Poly/ML: 29 secs >> 20 lips*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    71
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    72
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    73
writeln"Reached end of file.";