src/FOL/ex/Prolog.ML
author wenzelm
Sat, 15 Oct 2005 00:08:00 +0200
changeset 17851 2fa4f9b54761
parent 17245 1c519a3cca59
permissions -rw-r--r--
tuned comments;
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
5050
e925308df78b isatool fixgoal;
wenzelm
parents: 1459
diff changeset
     7
Goal "app(a:b:c:Nil, d:e:Nil, ?x)";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     8
by (resolve_tac [appNil,appCons] 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     9
by (resolve_tac [appNil,appCons] 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    10
by (resolve_tac [appNil,appCons] 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    11
by (resolve_tac [appNil,appCons] 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    12
prth (result());
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    13
5050
e925308df78b isatool fixgoal;
wenzelm
parents: 1459
diff changeset
    14
Goal "app(?x, c:d:Nil, a:b:c:d:Nil)";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    15
by (REPEAT (resolve_tac [appNil,appCons] 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    16
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    17
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    18
5050
e925308df78b isatool fixgoal;
wenzelm
parents: 1459
diff changeset
    19
Goal "app(?x, ?y, a:b:c:d:Nil)";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    20
by (REPEAT (resolve_tac [appNil,appCons] 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    21
back();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    22
back();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    23
back();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    24
back();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    25
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    26
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    27
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    28
(*app([x1,...,xn], y, ?z) requires (n+1) inferences*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    29
(*rev([x1,...,xn], ?y) requires (n+1)(n+2)/2 inferences*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    30
5050
e925308df78b isatool fixgoal;
wenzelm
parents: 1459
diff changeset
    31
Goal "rev(a:b:c:d:Nil, ?x)";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    32
val rules = [appNil,appCons,revNil,revCons];
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    33
by (REPEAT (resolve_tac rules 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    34
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    35
5050
e925308df78b isatool fixgoal;
wenzelm
parents: 1459
diff changeset
    36
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
    37
by (REPEAT (resolve_tac rules 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    38
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    39
5050
e925308df78b isatool fixgoal;
wenzelm
parents: 1459
diff changeset
    40
Goal "rev(?x, a:b:c:Nil)";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    41
by (REPEAT (resolve_tac rules 1)); (*does not solve it directly!*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    42
back();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    43
back();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    44
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    45
(*backtracking version*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    46
val prolog_tac = DEPTH_FIRST (has_fewer_prems 1) (resolve_tac rules 1);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    47
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    48
choplev 0;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    49
by prolog_tac;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    50
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    51
5050
e925308df78b isatool fixgoal;
wenzelm
parents: 1459
diff changeset
    52
Goal "rev(a:?x:c:?y:Nil, d:?z:b:?u)";
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
(*rev([a..p], ?w) requires 153 inferences *)
5050
e925308df78b isatool fixgoal;
wenzelm
parents: 1459
diff changeset
    57
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
    58
by (DEPTH_SOLVE (resolve_tac ([refl,conjI]@rules) 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    59
(*Poly/ML: 4 secs >> 38 lips*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    60
result();
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    61
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    62
(*?x has 16, ?y has 32;  rev(?y,?w) requires 561 (rather large) inferences;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    63
  total inferences = 2 + 1 + 17 + 561 = 581*)
5050
e925308df78b isatool fixgoal;
wenzelm
parents: 1459
diff changeset
    64
Goal
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    65
    "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
    66
by (DEPTH_SOLVE (resolve_tac ([refl,conjI]@rules) 1));
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    67
(*Poly/ML: 29 secs >> 20 lips*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    68
result();