我正在尝试为membero
适用于向量的 miniKanren (1) 编写等价物。到目前为止,我找不到不涉及观察值是逻辑变量还是部分实例化的方法。任何指针?
目前,我有:
(defun rangeo (x n)
(when (mu-var-p n)
(error "rangeo must be called with a fully instantiated second argument"))
(if (<= n 0)
+fail+
(conde
((== x (1- n)))
((rangeo x (1- n))))))
(defun vmembero (x v)
(when (mu-var-p v)
(error "vmembero must be called with a partially instantiated second argument"))
(fresh (i)
(rangeo i (length v))
(project (i)
(== x (aref v i)))))
(1): 没关系,但我实际上正在使用cl-kanren
; 不过,我认为这里的任何事情都不应该依赖于此。cl-kanren
确实具有向量的统一性。