Add a similar awful benchmark for the PAIP implementation
author |
Steve Losh <steve@stevelosh.com> |
date |
Mon, 02 May 2016 16:44:29 +0000 (2016-05-02) |
parents |
4d33f11b074f
|
children |
ceecc846dd67
|
branches/tags |
(none) |
files |
examples/ggp-paip.lisp examples/ggp.lisp src/paip.lisp test/paip.lisp |
Changes
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/examples/ggp-paip.lisp Mon May 02 16:44:29 2016 +0000
@@ -0,0 +1,277 @@
+(in-package #:bones.paip)
+
+(declaim (optimize (speed 1) (safety 3) (debug 1)))
+; (declaim (optimize (speed 3) (safety 1) (debug 0)))
+
+(clear-db)
+
+(rule (member ?thing (cons ?thing ?rest)))
+
+(rule (member ?thing (cons ?other ?rest))
+ (member ?thing ?rest))
+
+(rule (true ?state ?thing)
+ (member ?thing ?state))
+
+(rule (does ?performed ?role ?move)
+ (member (does ?role ?move) ?performed))
+
+(rule (role robot))
+
+(rule (init (off p)))
+(rule (init (off q)))
+(rule (init (off r)))
+(rule (init (off s)))
+(rule (init (step num1)))
+
+(rule (next ?state ?performed (on p))
+ (does ?performed robot a)
+ (true ?state (off p)))
+(rule (next ?state ?performed (on q))
+ (does ?performed robot a)
+ (true ?state (on q)))
+(rule (next ?state ?performed (on r))
+ (does ?performed robot a)
+ (true ?state (on r)))
+(rule (next ?state ?performed (off p))
+ (does ?performed robot a)
+ (true ?state (on p)))
+(rule (next ?state ?performed (off q))
+ (does ?performed robot a)
+ (true ?state (off q)))
+(rule (next ?state ?performed (off r))
+ (does ?performed robot a)
+ (true ?state (off r)))
+
+(rule (next ?state ?performed (on p))
+ (does ?performed robot b)
+ (true ?state (on q)))
+(rule (next ?state ?performed (on q))
+ (does ?performed robot b)
+ (true ?state (on p)))
+(rule (next ?state ?performed (on r))
+ (does ?performed robot b)
+ (true ?state (on r)))
+(rule (next ?state ?performed (off p))
+ (does ?performed robot b)
+ (true ?state (off q)))
+(rule (next ?state ?performed (off q))
+ (does ?performed robot b)
+ (true ?state (off p)))
+(rule (next ?state ?performed (off r))
+ (does ?performed robot b)
+ (true ?state (off r)))
+
+(rule (next ?state ?performed (on p))
+ (does ?performed robot c)
+ (true ?state (on p)))
+(rule (next ?state ?performed (on q))
+ (does ?performed robot c)
+ (true ?state (on r)))
+(rule (next ?state ?performed (on r))
+ (does ?performed robot c)
+ (true ?state (on q)))
+(rule (next ?state ?performed (off p))
+ (does ?performed robot c)
+ (true ?state (off p)))
+(rule (next ?state ?performed (off q))
+ (does ?performed robot c)
+ (true ?state (off r)))
+(rule (next ?state ?performed (off r))
+ (does ?performed robot c)
+ (true ?state (off q)))
+
+(rule (next ?state ?performed (off s))
+ (does ?performed robot a)
+ (true ?state (off s)))
+(rule (next ?state ?performed (off s))
+ (does ?performed robot b)
+ (true ?state (off s)))
+(rule (next ?state ?performed (off s))
+ (does ?performed robot c)
+ (true ?state (off s)))
+(rule (next ?state ?performed (on s))
+ (does ?performed robot a)
+ (true ?state (on s)))
+(rule (next ?state ?performed (on s))
+ (does ?performed robot b)
+ (true ?state (on s)))
+(rule (next ?state ?performed (on s))
+ (does ?performed robot c)
+ (true ?state (on s)))
+(rule (next ?state ?performed (off s))
+ (does ?performed robot d)
+ (true ?state (on s)))
+(rule (next ?state ?performed (on s))
+ (does ?performed robot d)
+ (true ?state (off s)))
+
+(rule (next ?state ?performed (on p))
+ (does ?performed robot d)
+ (true ?state (on p)))
+(rule (next ?state ?performed (off p))
+ (does ?performed robot d)
+ (true ?state (off p)))
+
+(rule (next ?state ?performed (on q))
+ (does ?performed robot d)
+ (true ?state (on q)))
+(rule (next ?state ?performed (off q))
+ (does ?performed robot d)
+ (true ?state (off q)))
+
+(rule (next ?state ?performed (on r))
+ (does ?performed robot d)
+ (true ?state (on r)))
+(rule (next ?state ?performed (off r))
+ (does ?performed robot d)
+ (true ?state (off r)))
+
+(rule (next ?state ?performed (step ?y))
+ (true ?state (step ?x))
+ (succ ?x ?y))
+
+(rule (succ num1 num2))
+(rule (succ num2 num3))
+(rule (succ num3 num4))
+(rule (succ num4 num5))
+(rule (succ num5 num6))
+(rule (succ num6 num7))
+(rule (succ num7 num8))
+
+(rule (legal robot a))
+(rule (legal robot b))
+(rule (legal robot c))
+(rule (legal robot d))
+
+(rule (goal ?state robot num100)
+ (true ?state (on p))
+ (true ?state (on q))
+ (true ?state (on r))
+ (true ?state (on s)))
+(rule (goal ?state robot num0)
+ (true ?state (off p)))
+(rule (goal ?state robot num0)
+ (true ?state (off q)))
+(rule (goal ?state robot num0)
+ (true ?state (off r)))
+(rule (goal ?state robot num0)
+ (true ?state (off s)))
+
+(rule (terminal ?state)
+ (true ?state (step num8)))
+(rule (terminal ?state)
+ (true ?state (on p))
+ (true ?state (on q))
+ (true ?state (on r))
+ (true ?state (on s)))
+
+
+(defvar *count* 0)
+
+(defun extract (key results)
+ (mapcar (lambda (result) (cdr (assoc key result))) results))
+
+(defun to-fake-list (l)
+ (if (null l)
+ 'nil
+ `(cons ,(car l) ,(to-fake-list (cdr l)))))
+
+
+(defun initial-state ()
+ (to-fake-list
+ (extract '?what (return-all (init ?what)))))
+
+(defun terminalp (state)
+ (raw-provable-p `(terminal ,state)))
+
+(defun legal-moves (state)
+ (declare (ignore state))
+ (return-all (legal ?role ?move)))
+
+(defun roles ()
+ (extract '?role (return-all (role ?role))))
+
+(defun goal-value (state role)
+ (cdr (assoc '?goal
+ (raw-return-one `(goal ,state ,role ?goal)))))
+
+(defun goal-values (state)
+ (raw-return-all `(goal ,state ?role ?goal)))
+
+(defun next-state (current-state move)
+ (let ((does (to-fake-list `((does
+ ,(cdr (assoc '?role move))
+ ,(cdr (assoc '?move move)))))))
+ (to-fake-list
+ (extract
+ '?what
+ (raw-return-all `(next ,current-state ,does ?what))))))
+
+
+(defstruct search-path state (path nil) (previous nil))
+
+(defun tree-search (states goal-p children combine)
+ (labels
+ ((recur (states)
+ (if (null states)
+ nil
+ (destructuring-bind (state . remaining) states
+ (incf *count*)
+ ; (format t "Searching: ~S (~D remaining)~%" state (length remaining))
+ (if (funcall goal-p state)
+ state
+ (recur (funcall combine
+ (funcall children state)
+ remaining)))))))
+ (let ((result (recur states)))
+ (when result
+ (reverse (search-path-path result))))))
+
+
+(defun buttons-goal-p (search-path)
+ (let ((state (search-path-state search-path)))
+ (and (terminalp state)
+ (eql (goal-value state 'robot) 'num100))))
+
+(defun buttons-children (search-path)
+ (let ((state (search-path-state search-path))
+ (path (search-path-path search-path)))
+ (when (not (terminalp state))
+ (loop :for move :in (legal-moves state)
+ :collect (make-search-path :state (next-state state move)
+ :path (cons move path)
+ :previous search-path)))))
+
+(defun never (&rest args)
+ (declare (ignore args))
+ nil)
+
+(defun dfs ()
+ (tree-search (list (make-search-path :state (initial-state)))
+ #'buttons-goal-p
+ #'buttons-children
+ #'append))
+
+(defun dfs-exhaust ()
+ (let ((*count* 0))
+ (prog1
+ (tree-search (list (make-search-path :state (initial-state)))
+ #'never
+ #'buttons-children
+ #'append)
+ (format t "Searched ~D nodes.~%" *count*))))
+
+(defun bfs ()
+ (tree-search (list (make-search-path :state (initial-state)))
+ #'buttons-goal-p
+ #'buttons-children
+ (lambda (x y)
+ (append y x))))
+
+; (sb-sprof:with-profiling
+; (:report :flat
+; :sample-interval 0.001
+; :loop nil)
+; (dfs-exhaust)
+; )
--- a/examples/ggp.lisp Sat Apr 30 22:57:09 2016 +0000
+++ b/examples/ggp.lisp Mon May 02 16:44:29 2016 +0000
@@ -217,6 +217,9 @@
(perform-return `((next ,current-state ,does :what)) :all))))))
+
+(defvar *count* 0)
+
(defstruct search-path state (path nil) (previous nil))
(defun tree-search (states goal-p children combine)
@@ -225,6 +228,7 @@
(if (null states)
nil
(destructuring-bind (state . remaining) states
+ (incf *count*)
; (format t "Searching: ~S (~D remaining)~%" state (length remaining))
(if (funcall goal-p state)
state
@@ -261,10 +265,13 @@
#'append))
(defun dfs-exhaust ()
- (tree-search (list (make-search-path :state (initial-state)))
- #'never
- #'buttons-children
- #'append))
+ (let ((*count* 0))
+ (prog1
+ (tree-search (list (make-search-path :state (initial-state)))
+ #'never
+ #'buttons-children
+ #'append)
+ (format t "Searched ~D nodes.~%" *count*))))
(defun bfs ()
(tree-search (list (make-search-path :state (initial-state)))
@@ -273,9 +280,9 @@
(lambda (x y)
(append y x))))
-(sb-sprof:with-profiling
- (:report :flat
- :sample-interval 0.001
- :loop nil)
- (dfs-exhaust)
- )
+; (sb-sprof:with-profiling
+; (:report :flat
+; :sample-interval 0.001
+; :loop nil)
+; (dfs-exhaust)
+; )
--- a/src/paip.lisp Sat Apr 30 22:57:09 2016 +0000
+++ b/src/paip.lisp Mon May 02 16:44:29 2016 +0000
@@ -414,9 +414,19 @@
(defmacro return-one (&rest goals)
`(top-level-find ',goals 'return-one-result))
+(defun raw-return-one (&rest goals)
+ (top-level-find goals 'return-one-result))
+
(defmacro return-all (&rest goals)
`(top-level-find ',goals 'return-all-results))
+(defun raw-return-all (&rest goals)
+ (top-level-find goals 'return-all-results))
+
+
(defmacro provable-p (&rest goals)
`(top-level-find ',goals 'return-boolean))
+(defun raw-provable-p (&rest goals)
+ (top-level-find goals 'return-boolean))
+
--- a/test/paip.lisp Sat Apr 30 22:57:09 2016 +0000
+++ b/test/paip.lisp Mon May 02 16:44:29 2016 +0000
@@ -3,6 +3,7 @@
(def-suite :bones.paip)
(in-suite :bones.paip)
+
;;;; Utils
(defun alist-equal (x y)
(set-equal x y :test #'equal))