以下程序noMetagolR在:
中给出http://www.doc.ic.ac.uk/~shm/Papers/metagol_gram.pdf第33页。
SELECT s FROM Setting s WHERE :code MEMBER OF s.languages.code
示例查询是:
parse(S,G1,G2) :- parse(s(0),S,[],G1,G2).
parse(Q,X,X,G1,G2) :- abduce(acceptor(Q),G1,G2).
parse(Q,[C|X],Y,G1,G2) :- Skolem(P), abduce(delta1(Q,C,P),G1,G3), parse(P,X,Y,G3,G2).
abduce(X,G,G) :- member(X,G).
abduce(X,G,[X|G]) :- not(member(X,G)).
Skolem(s(0)). Skolem(s(1)). ...
答案替换应返回学习的奇偶校验语法。
该程序据说在Yap运行。我通常使用SWI-prolog。无论哪种方式,
我该怎么做让他们理解parse([],[],G1), parse([0],G1,G2), parse([0,0],G2,G3), parse([1,1],G3,G4), parse([0,0,0],G4,G5), parse([0,1,1],G5,G6), parse([1,0,1],G6,G),not(parse([1],G,G)), not(parse([0,1],G,G)).
?这是否意味着Skolem/1
是变量?我想可能使用Skolem
但这不起作用。
还需要多少=..
个事实?
答案 0 :(得分:0)
:- set_prolog_flag(allow_variable_name_as_functor,true).
见current_prolog_flag / 2
关于REPL的例子:
1 ?- set_prolog_flag(allow_variable_name_as_functor,true).
true.
2 ?- assert(X(1)).
true.
3 ?- X(Y).
Y = 1.