13208
|
1 |
(* Title: HOL/Prolog/HOHH.thy
|
|
2 |
Author: David von Oheimb (based on a lecture on Lambda Prolog by Nadathur)
|
|
3 |
*)
|
9015
|
4 |
|
17311
|
5 |
header {* Higher-order hereditary Harrop formulas *}
|
|
6 |
|
|
7 |
theory HOHH
|
|
8 |
imports HOL
|
21425
|
9 |
uses "prolog.ML"
|
17311
|
10 |
begin
|
9015
|
11 |
|
21425
|
12 |
method_setup ptac =
|
30549
|
13 |
{* Attrib.thms >> (fn thms => fn ctxt => SIMPLE_METHOD' (Prolog.ptac ctxt thms)) *}
|
21425
|
14 |
"Basic Lambda Prolog interpreter"
|
|
15 |
|
|
16 |
method_setup prolog =
|
30549
|
17 |
{* Attrib.thms >> (fn thms => fn ctxt => SIMPLE_METHOD (Prolog.prolog_tac ctxt thms)) *}
|
21425
|
18 |
"Lambda Prolog interpreter"
|
|
19 |
|
9015
|
20 |
consts
|
|
21 |
|
17311
|
22 |
(* D-formulas (programs): D ::= !x. D | D .. D | D :- G | A *)
|
21425
|
23 |
Dand :: "[bool, bool] => bool" (infixr ".." 28)
|
|
24 |
Dif :: "[bool, bool] => bool" (infixl ":-" 29)
|
9015
|
25 |
|
17311
|
26 |
(* G-formulas (goals): G ::= A | G & G | G | G | ? x. G
|
|
27 |
| True | !x. G | D => G *)
|
21425
|
28 |
(*Dand' :: "[bool, bool] => bool" (infixr "," 35)*)
|
|
29 |
Dimp :: "[bool, bool] => bool" (infixr "=>" 27)
|
9015
|
30 |
|
|
31 |
translations
|
|
32 |
|
17311
|
33 |
"D :- G" => "G --> D"
|
|
34 |
"D1 .. D2" => "D1 & D2"
|
|
35 |
(*"G1 , G2" => "G1 & G2"*)
|
|
36 |
"D => G" => "D --> G"
|
9015
|
37 |
|
|
38 |
end
|