我试图使用Graphviz复制此图(该图是在LaTeX中生成的):
进行各种搜索和阅读,我设法做到了这一点:
我对获得超级和下载不感兴趣。如果我真的想要的话,我很清楚我能想出那么多。我想要做的是确保节点都在3 x 3网格中,并且很好地对齐。如您所见,我的作品不一致。我的代码如下。 (该图是使用DiagrammeR软件包在R中制作的。
到目前为止,我已尝试使用[pos='1,1!',pin=true]
,并将位置索引增加到三个网格,但它根本没有改变结果。
任何提示?
库(制图)
grViz(
"
digraph {
graph [overlap = true, fontsize = 10]
node [shape=circle]
Q11 [pos='1,1',pin=true]
Q21 [pos='2,1',pin=true]
Y1 [fillcolor=lightgray,style=filled,pos='3,1',pin=true]
Q11 -> Q21
Q11 -> Y1
Q21 -> Y1
node [shape = circle]
Q12
Q22
Y2 [fillcolor=lightgray,style=filled]
Q12 -> Q22
Q12 -> Y2
Q22 -> Y2
node [shape = circle]
Q13
Q23
Y3 [fillcolor=lightgray,style=filled]
Q13 -> Q23
Q13 -> Y3
Q23 -> Y3
{rank = same; Q11; Q12; Q13}
Q11 -> Q12
Q12 -> Q13
{rank = same; Q21; Q22; Q23}
Q21 -> Q22
Q22 -> Q23
}
",
engine = 'neato')
答案 0 :(得分:3)
您应该通过添加constraint=false
属性来禁用边缘上的少数约束。
digraph {
graph [fontsize=10]
node [shape=circle]
Q21
Q22
Q23
Q12
Q11
Q13
Q21 -> Q22 [constraint=false]
Q22 -> Q23 [constraint=false]
Q11 -> Q21
Q11 -> Y1 [constraint=false]
Q21 -> Y1
Q12 -> Q22
Q12 -> Y2 [constraint=false]
Q22 -> Y2
Q13 -> Q23
Q13 -> Y3 [constraint=false]
Q23 -> Y3
{rank = same; Q11; Q12; Q13;}
Q11 -> Q12 [constraint=false]
Q12 -> Q13 [constraint=false]
{rank = same; Q21; Q22; Q23}
Y3 [fillcolor=lightgray,style=filled]
Y2 [fillcolor=lightgray,style=filled]
Y1 [fillcolor=lightgray,style=filled]
}
此代码将生成下图。
请检查http://graphviz.it/#/LXfbjEui是否有工作演示。
答案 1 :(得分:0)
我意识到这已经是很多年了,但是对于遇到此问题的人们来说,以下代码基本上可以完成@Marcin解决方案的工作..但是减少了代码,并且也许说明了所采用的技术更好。
digraph {
node [shape=circle]
Q11 -> Q21 -> Y1
Q12 -> Q22 -> Y2
Q13 -> Q23 -> Y3
edge [constraint=false]
Q11 -> Q12 -> Q13
Q21 -> Q22 -> Q23
Q11 -> Y1
Q12 -> Y2
Q13 -> Y3
Y1, Y2, Y3 [fillcolor=lightgray,style=filled]
}