我正试图在pygraph中使用超图,以下是我插入的一个简单示例:
hgr = hypergraph()
hgr.add_nodes(["A1", "B1", "C1", "D1"])
hgr.add_nodes(["A2", "B2", "C2", "D2"])
hgr.add_nodes(["A3", "B3", "C3", "D3"])
hgr.add_nodes(["A4", "B4", "C4", "D4"])
hgr.add_hyperedge(("A1", "A2", "A3", "A4"))
hgr.add_hyperedge(("B1", "B2", "B3", "B4"))
hgr.add_hyperedge(("C1", "C2", "C3", "C4"))
hgr.add_hyperedge(("D1", "D2", "D3", "D4"))
h_dot = write(hgr)
h_gvv = gv.readstring(h_dot)
gv.layout(h_gvv,'dot')
gv.render(h_gvv, 'png', 'hypergraph.png')
请验证这是使用pygraph创建超图的正确方法。
非常感谢!
答案 0 :(得分:2)
由于每个hyperedge不是节点的集合,而是表示为节点,因此您应该为hyperedges使用唯一(简单)标识符,就像对节点一样,然后{{ 3}}他们到节点。
考虑link中的示例图:
要在pygraph
中创建此图表,您可以执行以下操作:
from pygraph.classes.hypergraph import hypergraph
from pygraph.readwrite.dot import write_hypergraph
h = hypergraph()
h.add_nodes(['v1', 'v2', 'v3', 'v4', 'v5', 'v6', 'v7'])
h.add_hyperedges(['e1', 'e2', 'e3', 'e4'])
h.link('v1', 'e1')
h.link('v2', 'e1')
h.link('v3', 'e1')
h.link('v2', 'e2')
h.link('v3', 'e2')
h.link('v3', 'e3')
h.link('v5', 'e3')
h.link('v6', 'e3')
h.link('v4', 'e4')
with open('hypergraph.dot', 'w') as f:
f.write(write_hypergraph(h))
将使用dot
生成此图像输出:
这是我猜的正确表示,但不像维基百科的图像那样直观。如果您正在追踪超图的可视化,您应该查看Wikipedia article for hypergraphs。