2

我已经生成:

curr(p5,2) curr(p5,1) curr(p5,6)

如何总结激光场 2+1+6?

我在 cligo_guild.pdf 的第 21 页看到了以下内容:

15 :- not M-2 [ enroll(C) : hours(C,H) = H ] M, max_hours(M).

上来:

#sum [pick(P) : curr(P,I) = I].

但我得到:

ERROR: unstratified predicate in:
bus3.lp:73:2: #sum[pick(P)=I:curr(P,I)].
bus3.lp:73:17: curr/2

我正在使用 clgo 3.0.4。谢谢您的帮助。

4

2 回答 2

1

我假设您需要每个“选择”的总数,并且我假设选择定义为

pick(P) :- curr(P, _).

您应该在代码中说明您的意思。在您引用的 cligo3 指南案例中,这不是必需的。

在 clgo3 中:

% clingo3
curr(p4,2). curr(p4,2). curr(p4,6).
curr(p5,2). curr(p5,1). curr(p5,6).

pick(P) :- curr(P, _).
% for each pick P, sum all I from matching curr(P, I)
totals(P, S) :- S = #sum[ curr(P,I) = I ], pick(P).

#hide.
#show totals/2.

而在 cligo4 中,它使用更一致的方式来表达这些:

% clingo4
% ...
totals(P, S) :- S = #sum{ I : curr(P,I)}, pick(P).
#show totals/2.
于 2015-05-02T05:20:11.230 回答
0
curr(p5,2). curr(p5,1). curr(p5,6).

sum(S) :- S = #sum{Y: curr(X,Y)}.

输出:

clingo version 5.0.0
Solving...
Answer: 1
curr(p5,2) curr(p5,1) curr(p5,6) sum(9)
SATISFIABLE
于 2018-12-02T22:41:12.483 回答