src/HOL/Prolog/Test.thy
author paulson
Tue, 11 May 2004 10:47:15 +0200
changeset 14732 967db86e853c
parent 13208 965f95a3abd9
child 14981 e73f8140af78
permissions -rw-r--r--
auto update
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
13208
965f95a3abd9 added the usual file headers
oheimb
parents: 12338
diff changeset
     1
(*  Title:    HOL/Prolog/Test.thy
965f95a3abd9 added the usual file headers
oheimb
parents: 12338
diff changeset
     2
    ID:       $Id$
965f95a3abd9 added the usual file headers
oheimb
parents: 12338
diff changeset
     3
    Author:   David von Oheimb (based on a lecture on Lambda Prolog by Nadathur)
965f95a3abd9 added the usual file headers
oheimb
parents: 12338
diff changeset
     4
    License:  GPL (GNU GENERAL PUBLIC LICENSE)
965f95a3abd9 added the usual file headers
oheimb
parents: 12338
diff changeset
     5
965f95a3abd9 added the usual file headers
oheimb
parents: 12338
diff changeset
     6
basic examples 
965f95a3abd9 added the usual file headers
oheimb
parents: 12338
diff changeset
     7
*)
9015
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
     8
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
     9
Test = HOHH +
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    10
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    11
types nat
12338
de0f4a63baa5 renamed class "term" to "type" (actually "HOL.type");
wenzelm
parents: 9015
diff changeset
    12
arities nat :: type
9015
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    13
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    14
types 'a list
12338
de0f4a63baa5 renamed class "term" to "type" (actually "HOL.type");
wenzelm
parents: 9015
diff changeset
    15
arities list :: (type) type
9015
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    16
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    17
consts Nil   :: 'a list		 	 		 ("[]")
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    18
       Cons  :: 'a => 'a list => 'a list		 (infixr "#"  65)
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    19
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    20
syntax
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    21
  (* list Enumeration *)
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    22
  "@list"     :: args => 'a list                          ("[(_)]")
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    23
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    24
translations
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    25
  "[x, xs]"     == "x#[xs]"
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    26
  "[x]"         == "x#[]"
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    27
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    28
types   person
12338
de0f4a63baa5 renamed class "term" to "type" (actually "HOL.type");
wenzelm
parents: 9015
diff changeset
    29
arities person  :: type
9015
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    30
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    31
consts  
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    32
	append  :: ['a list, 'a list, 'a list]		  => bool
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    33
	reverse :: ['a list, 'a list]			  => bool
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    34
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    35
	mappred	:: [('a => 'b => bool), 'a list, 'b list] => bool
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    36
	mapfun	:: [('a => 'b), 'a list, 'b list]	  => bool
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    37
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    38
	bob	:: person
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    39
	sue	:: person
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    40
	ned	:: person
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    41
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    42
	"23"	:: nat		("23")
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    43
	"24"	:: nat		("24")
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    44
	"25"	:: nat		("25")
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    45
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    46
	age	:: [person, nat]			  => bool
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    47
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    48
	eq	:: ['a, 'a]				  => bool
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    49
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    50
	empty	:: ['b]					  => bool
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    51
	add	:: ['a, 'b, 'b]				  => bool
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    52
	remove	:: ['a, 'b, 'b]				  => bool
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    53
	bag_appl:: ['a, 'a, 'a, 'a]			  => bool
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    54
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    55
rules   append	"append  []    xs  xs    ..
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    56
		 append (x#xs) ys (x#zs) :- append xs ys zs"
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    57
	reverse "reverse L1 L2 :- (!rev_aux. 
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    58
		  (!L.          rev_aux  []    L  L )..
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    59
		  (!X L1 L2 L3. rev_aux (X#L1) L2 L3 :- rev_aux L1 L2 (X#L3))
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    60
		  => rev_aux L1 L2 [])"
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    61
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    62
	mappred "mappred P  []     []    ..
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    63
		 mappred P (x#xs) (y#ys) :- P x y  &  mappred P xs ys"
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    64
	mapfun  "mapfun f  []     []      ..
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    65
		 mapfun f (x#xs) (f x#ys) :- mapfun f xs ys"
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    66
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    67
	age     "age bob 24 ..
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    68
		 age sue 23 ..
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    69
		 age ned 23"
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    70
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    71
	eq	"eq x x"
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    72
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    73
(* actual definitions of empty and add is hidden -> yields abstract data type *)
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    74
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    75
	bag_appl"bag_appl A B X Y:- (? S1 S2 S3 S4 S5.
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    76
				empty    S1    &
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    77
				add A    S1 S2 &
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    78
				add B    S2 S3 &
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    79
				remove X S3 S4 &
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    80
				remove Y S4 S5 &
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    81
				empty    S5)"
8006e9009621 added HOL/Prolog
oheimb
parents:
diff changeset
    82
end