生成间隔信息的问题
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
我们获得的间隔比需要的多,因为其中一些不是最大间隔,但我将此留给您考虑:)
希望对您有所帮助。
给定一个随时间变化的二元函数,我尝试提取有关此函数中出现的时间间隔的信息。 例如。我有状态 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
我们获得的间隔比需要的多,因为其中一些不是最大间隔,但我将此留给您考虑:)
希望对您有所帮助。