从合金4.2中的图形创建独立集合

时间:2015-11-01 16:34:54

标签: graph alloy independent-set

我已经创建了一个测试图来尝试创建一个独立的集合。我知道并且独立组是一组没有连接的顶点,但我不知道如何在合金4.2中实现这一点。这就是我所拥有的:

abstract sig Vertex {
    e: set Vertex   -- e is the edge relation
}
-- the test graph has vertices A, B, C, D, E, F
one sig A, B, C, D, E, F extends Vertex { }
pred independentSet[e: Vertex->Vertex, s: set Vertex] {
    --code here?
}
pred show {
    -- setting up the edge relation
    (A->A + A->B + A->C + A->D) +
        (B->A + B->B + B->C + B->E) +
            (C->A + C->B + C->C + C->F) = e
}
run show for 6

2 个答案:

答案 0 :(得分:0)

all i, j: s | not i -> j in e

这就是我提出的答案,我认为这是正确的,它给出了一个实例。我认为它错过了一点,但我不确定如何充分表达它。我希望它能给你一个想法!

答案 1 :(得分:0)

no e更短。 (但是评论太短了,所以这是填充物。)