0

考虑以下代码,在cligo中编译。

文件test.lp. 编译命令:clingo 0 test.lp.

col(("rot";"blau")).

freq("rot","hell",2). freq("rot","dunkel",2). freq("rot","hell",5).
freq("blau","hell",20). freq("blau","dunkel",30). freq("blau","hell",50).

freq_sum(C,F) :- F = #sum{ X : freq(C,_,X) }, col(C).
%% does not work: >>error: syntax error, unexpected [, expecting {<<
% freq_sum(C,F) :- F = #sum[ X : freq(C,_,X) ], col(C).

#show freq_sum/2.

代码应该计算每种颜色的频率总和。对于"red",这应该是9,对于“blue"这应该是100。因为"red"该值2被计算两次。当我替换{...}[…]应该使列表成为有序列表并提供有序总和时,编译器会抱怨error: syntax error, unexpected [, expecting {。我有clingo version 4.5.4。我的代码或编译器有问题吗?

有人可以告诉我,我如何在 asp 中执行有序的求和?

4

1 回答 1

0

万一有人遇到这个问题,我找到了解决方案。问题是版本 4 中的 cligo/gringo 版本不支持多集。只能通过 输入列表{...}。尽管如此,还是有一种方法可以防止多个元素的折叠。

freq_sum(C,F) :- F = #sum{ X,H : freq(C,H,X) }, col(C).

命名发生索引的对象,允许列表中的每个项目被唯一标记,防止重复值被视为单个元素。我在http://ceur-ws.org/Vol-1645/paper_9.pdf的 §2 中找到了这个解决方案。

于 2017-01-09T13:59:53.410 回答