我正在尝试使用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')
您应该通过添加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的工作演示。
我意识到它已经很多年了,但是对于遇到这种情况的人来说,下面的代码基本上实现了@ 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]
}