【发布时间】:2020-11-07 18:29:04
【问题描述】:
我一直在玩 miniKanren,试图通过将非常基本的 Prolog 教程转换成它来理解它。
我习惯性地使用 Python,所以我从 LogPy 库开始,该库后来被分叉和改进为实际上称为 miniKanren 的库
从 lib 的 README 中给出的示例中我们可以看到:
>>> from kanren import Relation, facts
>>> parent = Relation()
>>> facts(parent, ("Homer", "Bart"),
... ("Homer", "Lisa"),
... ("Abe", "Homer"))
>>> run(1, x, parent(x, "Bart"))
('Homer',)
这与您在 Prolog 教程开始时可能会看到的内容相对应,例如:
% facts.pl
parent(homer, bart).
parent(homer, lisa).
parent(abe, homer).
?- consult('facts')
true.
?- parent(X, bart).
X = homer
我对此很满意。后来我发现自己阅读了越来越多的 MiniKanren 文献(一般意义上,不是 Python 库),我意识到我没有看到任何以这种方式使用事实数据库的示例,或者提到过。
我错过了吗?或者这实际上不是 MiniKanren 的“A Reasoned Schemer”的一个特点?
我确实在 Clojure core.logic 实现中找到了这样的东西,其中有:
https://github.com/clojure/core.logic/wiki/Features#simple-in-memory-database
它的工作方式非常相似,尽管比 python 更好,因为 db 是一个独特的实体,而不是 lib 中的全局变量。
python lib 是否只是从core.logic 借用了一个非kanren 的想法?还有其他类似的 MiniKanren 实现吗?还是完全不同的方法?
【问题讨论】:
-
请注意,
pldb也直接支持此功能,它是core.logic的一部分。因为这是一个老问题,所以不添加这个作为答案。
标签: clojure-core.logic minikanren reasoned-schemer knowledge-base-population