0

我创建了一个测试图来尝试从中创建一个独立的集合。我知道独立集是一组未连接的顶点,但我不确定如何在合金 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
4

2 回答 2

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

这就是我提出的答案,我认为它是正确的,并且提供了一个实例。我认为它遗漏了一点,但不知道如何充分表达它。我希望它能给你一个想法!

于 2015-11-02T00:41:08.420 回答
0

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

于 2015-11-02T15:41:22.757 回答