3

我用图形和更多细节更新了问题。感谢 marapet,如果没有 hack,我无法生成所需的图像结果。

为什么这段代码会产生这个图?

digraph {
 rankdir = TB;
 1 -> 2 -> 3 -> 1;
}

如何让 graphviz/dot 产生这样的顺时针方向?

更新

这是我要生成的最终图表(afaik 以这种方式在逻辑上是正确的)

digraph {
  rankdir = TB
  start -> 1
  1 -> 2 -> 3 -> 1
  3 -> end
  3 -> increment
  end -> product
  {rank = same; 2; 3; increment}
  {rank = same; end; product}
}

产生这个结果

虽然我想要这个

谢谢

4

1 回答 1

10

为什么这段代码会产生这个图?

有向图根据它们的关系将其节点置于不同的等级。由于 1 指向 2,它必须高于 2,并且由于 2 指向 3,它必须高于 3。但由于 3 也指向 1,所以圆已完成 - 3 个节点中的任何一个都可能在顶部。Graphviz 只是将第一个提到的节点放在顶部。因此,如果您改写:

2 -> 3 -> 1 -> 2;

节点 2 将在顶部,使用时

3 -> 1 -> 2 -> 3;

节点 3 将是顶部节点。

布局引擎neato可能更适合这个图,生成一个顺时针方向的图:

整洁的布局

如果你绝对必须使用点布局引擎,下面的点代码

digraph {
  rankdir = TB;
  1 -> 2;
  3 -> 2 [dir=back];
  3 -> 1;
  {rank=same; 2; 3;}
}

通过将边缘 2->3 更改为 3->2 并同时反转箭头的方向来产生所需的输出。

或者,相同技术的另一个变体,更容易解释:我们颠倒所有箭头的顺序 (1->3->2->1),但将它们向后显示 (dir=back),并强制节点 2 和 3处于同一等级:

rankdir = TB;
edge[dir=back];
1 -> 3 -> 2 -> 1;
{rank=same; 2;3;}

此 hack 产生以下结果:

黑客

于 2011-02-03T19:26:38.543 回答