src/FOL/ex/Prolog.thy
author wenzelm
Wed, 21 Aug 2019 15:19:31 +0200
changeset 70600 6e97e31933a6
parent 69593 3dda49e08b9d
permissions -rw-r--r--
more scalable buffer: produce compact chunks on the fly, avoid too many small particles that might congest heap management;
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
60770
240563fbf41d isabelle update_cartouches;
wenzelm
parents: 59498
diff changeset
     6
section \<open>First-Order Logic: PROLOG examples\<close>
17245
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
69590
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    13
instance list :: (\<open>term\<close>) \<open>term\<close> ..
41779
a68f503805ed modernized specifications;
wenzelm
parents: 36319
diff changeset
    14
a68f503805ed modernized specifications;
wenzelm
parents: 36319
diff changeset
    15
axiomatization
69590
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    16
  Nil     :: \<open>'a list\<close> and
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    17
  Cons    :: \<open>['a, 'a list]=> 'a list\<close>    (infixr \<open>:\<close> 60) and
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    18
  app     :: \<open>['a list, 'a list, 'a list] => o\<close> and
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    19
  rev     :: \<open>['a list, 'a list] => o\<close>
41779
a68f503805ed modernized specifications;
wenzelm
parents: 36319
diff changeset
    20
where
69590
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    21
  appNil:  \<open>app(Nil,ys,ys)\<close> and
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    22
  appCons: \<open>app(xs,ys,zs) ==> app(x:xs, ys, x:zs)\<close> and
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    23
  revNil:  \<open>rev(Nil,Nil)\<close> and
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    24
  revCons: \<open>[| rev(xs,ys);  app(ys, x:Nil, zs) |] ==> rev(x:xs, zs)\<close>
17245
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
    25
69590
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    26
schematic_goal \<open>app(a:b:c:Nil, d:e:Nil, ?x)\<close>
19819
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
apply (rule appNil appCons)
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    31
done
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    32
69590
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    33
schematic_goal \<open>app(?x, c:d:Nil, a:b:c:d:Nil)\<close>
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    34
apply (rule appNil appCons)+
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    35
done
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    36
69590
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    37
schematic_goal \<open>app(?x, ?y, a:b:c:d:Nil)\<close>
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    38
apply (rule appNil appCons)+
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
back
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    43
done
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    44
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    45
(*app([x1,...,xn], y, ?z) requires (n+1) inferences*)
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    46
(*rev([x1,...,xn], ?y) requires (n+1)(n+2)/2 inferences*)
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    47
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    48
lemmas rules = appNil appCons revNil revCons
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    49
69590
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    50
schematic_goal \<open>rev(a:b:c:d:Nil, ?x)\<close>
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    51
apply (rule rules)+
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    52
done
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    53
69590
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    54
schematic_goal \<open>rev(a:b:c:d:e:f:g:h:i:j:k:l:m:n:Nil, ?w)\<close>
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    55
apply (rule rules)+
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    56
done
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    57
69590
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    58
schematic_goal \<open>rev(?x, a:b:c:Nil)\<close>
62020
5d208fd2507d isabelle update_cartouches -c -t;
wenzelm
parents: 61489
diff changeset
    59
apply (rule rules)+  \<comment> \<open>does not solve it directly!\<close>
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    60
back
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    61
back
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    62
done
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    63
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    64
(*backtracking version*)
60770
240563fbf41d isabelle update_cartouches;
wenzelm
parents: 59498
diff changeset
    65
ML \<open>
59498
50b60f501b05 proper context for resolve_tac, eresolve_tac, dresolve_tac, forward_tac etc.;
wenzelm
parents: 58889
diff changeset
    66
fun prolog_tac ctxt =
50b60f501b05 proper context for resolve_tac, eresolve_tac, dresolve_tac, forward_tac etc.;
wenzelm
parents: 58889
diff changeset
    67
  DEPTH_FIRST (has_fewer_prems 1) (resolve_tac ctxt @{thms rules} 1)
60770
240563fbf41d isabelle update_cartouches;
wenzelm
parents: 59498
diff changeset
    68
\<close>
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    69
69590
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    70
schematic_goal \<open>rev(?x, a:b:c:Nil)\<close>
69593
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 69590
diff changeset
    71
apply (tactic \<open>prolog_tac \<^context>\<close>)
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    72
done
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    73
69590
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    74
schematic_goal \<open>rev(a:?x:c:?y:Nil, d:?z:b:?u)\<close>
69593
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 69590
diff changeset
    75
apply (tactic \<open>prolog_tac \<^context>\<close>)
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    76
done
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    77
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    78
(*rev([a..p], ?w) requires 153 inferences *)
69590
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    79
schematic_goal \<open>rev(a:b:c:d:e:f:g:h:i:j:k:l:m:n:o:p:Nil, ?w)\<close>
60770
240563fbf41d isabelle update_cartouches;
wenzelm
parents: 59498
diff changeset
    80
apply (tactic \<open>
69593
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 69590
diff changeset
    81
  DEPTH_SOLVE (resolve_tac \<^context> ([@{thm refl}, @{thm conjI}] @ @{thms rules}) 1)\<close>)
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    82
done
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    83
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    84
(*?x has 16, ?y has 32;  rev(?y,?w) requires 561 (rather large) inferences
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    85
  total inferences = 2 + 1 + 17 + 561 = 581*)
69590
e65314985426 isabelle update_inner_syntax_cartouches;
wenzelm
parents: 69587
diff changeset
    86
schematic_goal \<open>a:b:c:d:e:f:g:h:i:j:k:l:m:n:o:p:Nil = ?x \<and> app(?x,?x,?y) \<and> rev(?y,?w)\<close>
60770
240563fbf41d isabelle update_cartouches;
wenzelm
parents: 59498
diff changeset
    87
apply (tactic \<open>
69593
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 69590
diff changeset
    88
  DEPTH_SOLVE (resolve_tac \<^context> ([@{thm refl}, @{thm conjI}] @ @{thms rules}) 1)\<close>)
19819
14de4d05d275 removed obsolete ML files;
wenzelm
parents: 17245
diff changeset
    89
done
17245
1c519a3cca59 converted to Isar theory format;
wenzelm
parents: 1473
diff changeset
    90
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    91
end