src/FOL/ex/Prolog.thy
author blanchet
Tue, 26 Oct 2010 16:56:54 +0200
changeset 40200 870818d2b56b
parent 36319 8feb2c4bef1a
child 41779 a68f503805ed
permissions -rw-r--r--
remove needless context argument; prefer "Proof.context_of" to "#context o Proof.goal", since it considers any "using [[...]]"
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
31974
e81979a703a4 removed obsolete CVS Ids;
wenzelm
parents: 26287
diff changeset
     1
(*  Title:      FOL/ex/Prolog.thy
1473
e8d4606e6502 expanded tabs
clasohm
parents: 1322
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
17245
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
     6
header {* First-Order Logic: PROLOG examples *}
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
     7
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
     8
theory Prolog
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
     9
imports FOL
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
    10
begin
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
    11
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
    12
typedecl 'a list
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
    13
arities list :: ("term") "term"
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
    14
consts
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
    15
  Nil     :: "'a list"
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
    16
  Cons    :: "['a, 'a list]=> 'a list"    (infixr ":" 60)
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
    17
  app     :: "['a list, 'a list, 'a list] => o"
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
    18
  rev     :: "['a list, 'a list] => o"
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
    19
axioms
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
    20
  appNil:  "app(Nil,ys,ys)"
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
    21
  appCons: "app(xs,ys,zs) ==> app(x:xs, ys, x:zs)"
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
    22
  revNil:  "rev(Nil,Nil)"
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
    23
  revCons: "[| rev(xs,ys);  app(ys, x:Nil, zs) |] ==> rev(x:xs, zs)"
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
    24
36319
8feb2c4bef1a mark schematic statements explicitly;
wenzelm
parents: 31974
diff changeset
    25
schematic_lemma "app(a:b:c:Nil, d:e:Nil, ?x)"
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    26
apply (rule appNil appCons)
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    27
apply (rule appNil appCons)
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    28
apply (rule appNil appCons)
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    29
apply (rule appNil appCons)
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    30
done
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    31
36319
8feb2c4bef1a mark schematic statements explicitly;
wenzelm
parents: 31974
diff changeset
    32
schematic_lemma "app(?x, c:d:Nil, a:b:c:d:Nil)"
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    33
apply (rule appNil appCons)+
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    34
done
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    35
36319
8feb2c4bef1a mark schematic statements explicitly;
wenzelm
parents: 31974
diff changeset
    36
schematic_lemma "app(?x, ?y, a:b:c:d:Nil)"
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    37
apply (rule appNil appCons)+
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    38
back
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    39
back
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    40
back
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    41
back
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    42
done
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    43
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    44
(*app([x1,...,xn], y, ?z) requires (n+1) inferences*)
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    45
(*rev([x1,...,xn], ?y) requires (n+1)(n+2)/2 inferences*)
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    46
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    47
lemmas rules = appNil appCons revNil revCons
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    48
36319
8feb2c4bef1a mark schematic statements explicitly;
wenzelm
parents: 31974
diff changeset
    49
schematic_lemma "rev(a:b:c:d:Nil, ?x)"
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    50
apply (rule rules)+
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    51
done
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    52
36319
8feb2c4bef1a mark schematic statements explicitly;
wenzelm
parents: 31974
diff changeset
    53
schematic_lemma "rev(a:b:c:d:e:f:g:h:i:j:k:l:m:n:Nil, ?w)"
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    54
apply (rule rules)+
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    55
done
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    56
36319
8feb2c4bef1a mark schematic statements explicitly;
wenzelm
parents: 31974
diff changeset
    57
schematic_lemma "rev(?x, a:b:c:Nil)"
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    58
apply (rule rules)+  -- {* does not solve it directly! *}
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    59
back
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    60
back
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    61
done
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    62
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    63
(*backtracking version*)
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    64
ML {*
26287
df8e5362cff9 proper antiquotations;
wenzelm
parents: 19819
diff changeset
    65
val prolog_tac = DEPTH_FIRST (has_fewer_prems 1) (resolve_tac (@{thms rules}) 1)
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    66
*}
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    67
36319
8feb2c4bef1a mark schematic statements explicitly;
wenzelm
parents: 31974
diff changeset
    68
schematic_lemma "rev(?x, a:b:c:Nil)"
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    69
apply (tactic prolog_tac)
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    70
done
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    71
36319
8feb2c4bef1a mark schematic statements explicitly;
wenzelm
parents: 31974
diff changeset
    72
schematic_lemma "rev(a:?x:c:?y:Nil, d:?z:b:?u)"
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    73
apply (tactic prolog_tac)
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    74
done
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    75
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    76
(*rev([a..p], ?w) requires 153 inferences *)
36319
8feb2c4bef1a mark schematic statements explicitly;
wenzelm
parents: 31974
diff changeset
    77
schematic_lemma "rev(a:b:c:d:e:f:g:h:i:j:k:l:m:n:o:p:Nil, ?w)"
26287
df8e5362cff9 proper antiquotations;
wenzelm
parents: 19819
diff changeset
    78
apply (tactic {* DEPTH_SOLVE (resolve_tac ([@{thm refl}, @{thm conjI}] @ @{thms rules}) 1) *})
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    79
done
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    80
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    81
(*?x has 16, ?y has 32;  rev(?y,?w) requires 561 (rather large) inferences
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    82
  total inferences = 2 + 1 + 17 + 561 = 581*)
36319
8feb2c4bef1a mark schematic statements explicitly;
wenzelm
parents: 31974
diff changeset
    83
schematic_lemma "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)"
26287
df8e5362cff9 proper antiquotations;
wenzelm
parents: 19819
diff changeset
    84
apply (tactic {* DEPTH_SOLVE (resolve_tac ([@{thm refl}, @{thm conjI}] @ @{thms rules}) 1) *})
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    85
done
17245
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
    86
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    87
end