代表合金中的数学关系

时间:2015-10-11 01:08:12

标签: alloy

我是Alloy的新手,我仍然很困惑。我对数学关系比较满意,但不知道如何将它们转化为Alloy。

说我有(数学)关系的以下定义

rel = {(x, y) | x \in S1, y \in S2}

以下Alloy片段是' rel'?

的正确表示形式
sig S2 {}

sig S1 {rel: S2}

我如何将这种关系限制为无反射和传递?

2 个答案:

答案 0 :(得分:1)

是的,您的模型将rel定义为集合S1S2之间的关系。要约束关系,你可以编写类似的东西:

fact antireflexive { no iden & rel }

也就是说,rel

中没有元素映射到自身

fact transitive { rel = ^rel }

意味着rel等于其传递闭包,因此具有传递性。

答案 1 :(得分:0)

首先定义类型:

 sig S1, S2 {}

然后,您可以使用以下等效语法

定义rel关系
let rel = { x : univ, y : univ | x in S1 and y in S2 }
let rel = { x : S1, y : S2 }
let rel = S1 -> S2