生成间隔信息的问题

problems generating interval information

给定一个随时间变化的二元函数,我尝试提取有关此函数中出现的时间间隔的信息。 例如。我有状态 a 和 b,以及以下函数:

a, a, b, b, b, a, b, b, a, a

然后我想要一个像这样的事实间隔(开始、长度、值):

interval(0, 2, a)
interval(2, 3, b) 
interval(5, 1, a) 
interval(6, 2, b) 
interval(8, 2, a)

这是我目前得到的:

time(0..9).

duration(1..10).
value(a;b).

1{ function(T, V): value(V) }1 :- time(T).

interval1(T, Length, Value) :- 
    time(T), duration(Length), value(Value),
    function(Ti, Value): Ti >= T, Ti < T + Length, time(Ti).

:- interval1(T, L, V), function(T + L, V).

#show function/2.
#show interval1/3.

这实际上工作得很好,但仍然不正确,这是我的输出,当我 运行 它与 clingo 4.5.4:

function(0,b)
function(1,a)
function(2,b)
function(3,a)
function(4,b)
function(5,a)
function(6,b)
function(7,a)
function(8,b)
function(9,a)
interval1(0,1,b)
interval1(1,1,a)
interval1(2,1,b)
interval1(3,1,a)
interval1(4,1,b)
interval1(5,1,a)
interval1(6,1,b)
interval1(7,1,a)
interval1(8,1,b)
interval1(9,1,a)
interval1(9,10,a)
interval1(9,2,a)
interval1(9,3,a)
interval1(9,4,a)
interval1(9,5,a)
interval1(9,6,a)
interval1(9,7,a)
interval1(9,8,a)
interval1(9,9,a)

只有一个错误:T == 9 处的所有间隔(L == 1 除外)

所以我尝试添加以下约束,以摆脱这些约束:

:- interval1(T, L, V), not time(T + L - 1).

在我看来转化为 "it is prohibited, to have an interval, such that T + L is not a time" 但是现在clingo说这个问题是无法解决的。

所以我尝试了另一种解决方案,它应该做同样的事情,但以一种不太通用的方式:

:- interval1(T, L, V), T + L > 10. 

这也让整件事无解。 我真的不明白,我只是希望这两个规则都能摆脱函数中的 运行 间隔。 那么为什么他们要完全杀死模型的所有元素?

此外,在我的实验中,我将函数规则替换为:

function(
    0, a;
    1, a;
    2, b;
    3, b;
    4, b;
    5, b;
    6, a;
    7, b;
    8, a;
    9, a
).

即使没有有问题的约束,这也会使整个事情无法满足,这是为什么呢?

所以是的......我想,我从根本上误解了一些东西,如果有人能告诉我那到底是什么,我会非常高兴。

最好的问候 乌作

具有约束的程序不一致,因为在 ASP 中,任何同时包含事实 a. 和约束 :-a. 的程序都是不一致的。您基本上是在说 a 是真的,同时 a 不可能是真的。

例如,在您的情况下,您有一个规则告诉您 interval1(9,10,a) 对于某些函数是正确的,另一方面,您有一个约束说 interval(9,10,a) 不能是真的,所以你会变得不一致。

例如,一种消除不需要的间隔的方法是在间隔的定义中添加额外的原子,例如:

interval1(T, Length, Value) :- 
    time(T), duration(Length), value(Value),
    time(T+Length-1), % I added this
    function(Ti, Value): Ti >= T, Ti < T + Length, time(Ti).

现在程序是一致的。

我无法重现您提供的特定功能的不一致之处。对我来说,以下是一致的:

time(0..9).

duration(1..10).
value(a;b).

%1{ function(T, V): value(V) }1 :- time(T).

function(0,a).
function(1,a).
function(2,b).
function(3,b).
function(4,b).
function(5,b).
function(6,a).
function(7,b).
function(8,a).
function(9,a).


interval1(T, Length, Value) :- 
    time(T), duration(Length), value(Value),
    time(T+Length-1),
    function(Ti, Value): Ti >= T, Ti < T + Length, time(Ti).


#show function/2.
#show interval1/3.

这是我在输出中得到的:

$ clingo test 0
clingo version 4.5.4
Reading from test
Solving...
Answer: 1
function(0,a) function(1,a) function(2,b) function(3,b) function(4,b) function(5,b) function(6,a) function(7,b) function(8,a) function(9,a) interval1(0,1,a) interval1(1,1,a) interval1(0,2,a) interval1(6,1,a) interval1(8,1,a) interval1(9,1,a) interval1(8,2,a) interval1(2,1,b) interval1(3,1,b) interval1(2,2,b) interval1(4,1,b) interval1(3,2,b) interval1(2,3,b) interval1(5,1,b) interval1(4,2,b) interval1(3,3,b) interval1(2,4,b) interval1(7,1,b)
SATISFIABLE

Models       : 1     
Calls        : 1
Time         : 0.002s (Solving: 0.00s 1st Model: 0.00s Unsat: 0.00s)
CPU Time     : 0.000s

我们获得的间隔比需要的多,因为其中一些不是最大间隔,但我将此留给您考虑:)

希望对您有所帮助。