本文介绍了序言:“香草"带有内置函数的元解释器的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

Jan Burse 的这个答案 展示了 Prolog 中元解释器的最简单实现之一:

This answer by Jan Burse shows one of the simplest implementations of a metainterpreter in Prolog:

solve(true) :- !.
solve((A,B)) :- !, solve(A), solve(B).
solve(H) :- clause(H,B), solve(B).

我想扩展这个解释器,以便它可以调用内置函数.普通版本无法处理诸如 solve(member(X, [1,2,3,4])) 之类的调用.这可以使用 ISO 谓词吗?如果没有,是否可以使用 SWI-Prolog 谓词?

I would like to extend this interpreter so that it can call builtins. The vanilla one isn't able to handle calls such as solve(member(X, [1,2,3,4])). Is this possible using ISO predicates? If not, is it possible using SWI-Prolog predicates?

推荐答案

Stackoverflow 拒绝接受我的回答 :) 那是

Stackoverflow is refusing to accept my answer :) that was

只需打电话/1他们

编辑

例如

?- [user].
solve(true) :- !.
|: solve((A,B)) :- !, solve(A), solve(B).
|: solve(H) :- clause(H,B), solve(B).
|: solve(T) :- call(T).
|: ^Dtrue.

?- solve(member(X, [1,2,3,4])).
X = 1 ;
X = 2 ;
X = 3 ;
X = 4.

唯一的补充:solve(T) :- call(T).

这篇关于序言:“香草"带有内置函数的元解释器的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

10-12 21:13