kitayou_9 2023-02-08 11:30 采纳率: 0%
浏览 27
已结题

通过邻接矩阵生成有向加权网络

我现在有一张邻接矩阵
A=[[ 0 24 0 0]
[51 0 44 27]
[ 0 41 0 0]
[ 0 43 0 0]]
我希望将它转化为有向加权网络图G,我使用的代码如下:

G = nx.from_numpy_array(A,create_using=nx.DiGraph())
layout = nx.spring_layout(G)
nx.draw(G,layout,with_labels=True)
labels = nx.get_edge_attributes(G,"weight")
nx.draw_networkx_edge_labels(G, pos=layout, edge_labels=labels)
plt.show()

但是我最终得到的结果只显示了一个方向上的权重

img


请问如何调整代码以显示各个方向上的权重?

  • 写回答

3条回答 默认 最新

  • CodeBytes 2023-02-08 11:39
    关注

    该回答引用ChatGPT
    可用以下代码:

    
    labels = nx.get_edge_attributes(G,"weight")
    # 修改为:
    labels = {(i, j): A[i][j] for i in range(A.shape[0]) for j in range(A.shape[1]) if A[i][j] != 0}
    
    # 然后绘图:
    nx.draw_networkx_edge_labels(G, pos=layout, edge_labels=labels)
    
    
    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 2月8日
  • 创建了问题 2月8日