Stratify rules according to negations
author |
Steve Losh <steve@stevelosh.com> |
date |
Sun, 20 Nov 2016 15:33:06 +0000 (2016-11-20) |
parents |
fcc52d00b79f
|
children |
addb56e3eb9d
|
branches/tags |
(none) |
files |
src/terms.lisp |
Changes
--- a/src/terms.lisp Fri Nov 18 16:59:02 2016 +0000
+++ b/src/terms.lisp Sun Nov 20 15:33:06 2016 +0000
@@ -70,6 +70,7 @@
(mark-dependency head (bare-term b))))))
(iterate (for rule :in rules)
(for (head . body) = (ensure-list rule))
+ (digraph:insert-vertex graph head)
(mark-dependencies head body)))
graph))
@@ -191,6 +192,28 @@
layers))))
+;;;; Stratification -----------------------------------------------------------
+(defun stratify-layer (rules)
+ (iterate
+ (with dependencies = (build-dependency-graph rules :negations-only t))
+ (with remaining = rules)
+ (until (null remaining))
+
+ (for next-heads = (digraph:leafs dependencies))
+ (when (null next-heads)
+ (error "Cycle in negations detected!"))
+
+ (for stratum = (remove-if-not (lambda (rule)
+ (member (first rule) next-heads))
+ remaining))
+ (collect stratum)
+ ;; TODO: do we want the full rules or just the heads here?
+ ; (collect next-heads)
+
+ (setf remaining (set-difference remaining stratum))
+ (mapc (curry #'digraph:remove-vertex dependencies) next-heads)))
+
+
;;;; API ----------------------------------------------------------------------
(defun integerize-term (term->number term)
(match term
@@ -222,8 +245,19 @@
;;;; Scratch ------------------------------------------------------------------
-#+no (-<> scully.zdd::*rules*
+(-<> '(
+ (ggp-rules::<= a (ggp-rules::true foo))
+ (ggp-rules::<= b (ggp-rules::true foo) (ggp-rules::true baz))
+ (ggp-rules::<= c (ggp-rules::true dogs) (ggp-rules::not a))
+ (ggp-rules::<= x (ggp-rules::not a) b)
+ (ggp-rules::<= y (ggp-rules::not a) (ggp-rules::not x))
+ (ggp-rules::<= y (ggp-rules::not c))
+ )
(integerize-rules <>)
- ; (never <>)
+ (nth 2 <>)
+ (gethash :possible <>)
+ (stratify-layer <>)
+ (mapc (lambda (s) (format t "Stratum:~%~{ ~S~%~}" s)) <>)
+ (never <>)
; (map nil #'print-hash-table <>)
)