92c590f78133

Pool logic frames to avoid creating so many hash tables
[view raw] [browse files]
author Steve Losh <steve@stevelosh.com>
date Sat, 09 Jul 2016 21:03:01 +0000 (2016-07-09)
parents 8c853f632f8c
children 07e1d5f315f5
branches/tags (none)
files src/wam/dump.lisp src/wam/wam.lisp

Changes

--- a/src/wam/dump.lisp	Fri Jul 08 18:14:05 2016 +0000
+++ b/src/wam/dump.lisp	Sat Jul 09 21:03:01 2016 +0000
@@ -308,8 +308,8 @@
      (to (min (+ (wam-program-counter wam) 8) ; is
               (length (wam-code wam))))) ; bad
   (format t "CODE (size: ~D frame(s) / ~:[OPEN~;CLOSED~])~%"
-          (length (wam-code-stack wam))
-          (wam-code-closed-p wam))
+          (length (wam-logic-stack wam))
+          (wam-logic-closed-p wam))
   (dump-code-store wam (wam-code wam) from to))
 
 
--- a/src/wam/wam.lisp	Fri Jul 08 18:14:05 2016 +0000
+++ b/src/wam/wam.lisp	Sat Jul 09 21:03:01 2016 +0000
@@ -7,6 +7,7 @@
           wam-code
           wam-code-labels
           wam-logic-stack
+          wam-logic-pool
           wam-functors
           wam-fail
           wam-backtracked
@@ -65,6 +66,9 @@
   (logic-stack
     nil
     :type list)
+  (logic-pool
+    nil
+    :type list)
   (functors
     (make-array 64
       :fill-pointer 0
@@ -615,6 +619,20 @@
   (predicates (make-hash-table) :type hash-table))
 
 
+(defun* wam-logic-pool-release ((wam wam) (frame logic-frame))
+  (:returns :void)
+  (with-slots (start final predicates) frame
+    (clrhash predicates)
+    (setf start 0 final nil))
+  (push frame (wam-logic-pool wam))
+  (values))
+
+(defun* wam-logic-pool-request ((wam wam))
+  (:returns logic-frame)
+  (or (pop (wam-logic-pool wam))
+      (make-logic-frame)))
+
+
 (defun* wam-current-logic-frame ((wam wam))
   (:returns (or null logic-frame))
   (first (wam-logic-stack wam)))
@@ -638,11 +656,10 @@
   (:returns :void)
   (assert (wam-logic-closed-p wam) ()
     "Cannot push logic frame unless the logic stack is closed.")
-  (push (make-logic-frame
-          :start (fill-pointer (wam-code wam))
-          :final nil
-          :predicates (make-hash-table))
-        (wam-logic-stack wam))
+  (let ((frame (wam-logic-pool-request wam)))
+    (setf (logic-frame-start frame)
+          (fill-pointer (wam-code wam)))
+    (push frame (wam-logic-stack wam)))
   (values))
 
 (defun* wam-pop-logic-frame! ((wam wam))
@@ -652,11 +669,12 @@
       "Cannot pop logic frame from an empty logic stack.")
     (assert (logic-frame-final (first logic-stack)) ()
       "Cannot pop unfinalized logic frame.")
-    (with-slots (start predicates)
-        (pop logic-stack)
-      (setf (fill-pointer (wam-code wam)) start)
-      (loop :for label :being :the hash-keys :of predicates
-            :do (remhash label (wam-code-labels wam)))))
+    (let ((frame (pop logic-stack)))
+      (setf (fill-pointer (wam-code wam))
+            (logic-frame-start frame))
+      (loop :for label :being :the hash-keys :of (logic-frame-predicates frame)
+            :do (remhash label (wam-code-labels wam)))
+      (wam-logic-pool-release wam frame)))
   (values))