zoukankan      html  css  js  c++  java
  • python—networkx:依据图的权重绘图

    首先输入边和边的权重,随后画出节点位置,依据权重大小划分实边和虚边

    #coding:utf-8
    #!/usr/bin/env python
    """
    An example using Graph as a weighted network.
    """
    __author__ = """Aric Hagberg (hagberg@lanl.gov)"""
    try:
        import matplotlib.pyplot as plt
    except:
        raise
    
    import networkx as nx
    
    G=nx.Graph()
    #加入带权边
    G.add_edge('a','b',weight=0.6)
    G.add_edge('a','c',weight=0.2)
    G.add_edge('c','d',weight=0.1)
    G.add_edge('c','e',weight=0.7)
    G.add_edge('c','f',weight=0.9)
    G.add_edge('a','d',weight=0.3)
    #按权重划分为重权值得边和轻权值的边
    elarge=[(u,v) for (u,v,d) in G.edges(data=True) if d['weight'] >0.5]
    esmall=[(u,v) for (u,v,d) in G.edges(data=True) if d['weight'] <=0.5]
    #节点位置
    pos=nx.spring_layout(G) # positions for all nodes
    #首先画出节点位置
    # nodes
    nx.draw_networkx_nodes(G,pos,node_size=700)
    #依据权重,实线为权值大的边。虚线为权值小的边
    # edges
    nx.draw_networkx_edges(G,pos,edgelist=elarge,
                        width=6)
    nx.draw_networkx_edges(G,pos,edgelist=esmall,
                        width=6,alpha=0.5,edge_color='b',style='dashed')
    
    # labels标签定义
    nx.draw_networkx_labels(G,pos,font_size=20,font_family='sans-serif')
    
    plt.axis('off')
    plt.savefig("weighted_graph.png") # save as png
    plt.show() # display
    
       
    
  • 相关阅读:
    laravel配置路由出现404
    laravel数据库操作
    dedecms操作数据库
    数据库存储过程详解
    :数据库存储过程缺点总结
    一个SQL存储过程面试题(比较简单)
    也谈用友被面试经历【去年杭州用友被拒】
    用友面试经历 续【最终遭拒】
    Appium Appium 链接夜神模拟器
    Problem A
  • 原文地址:https://www.cnblogs.com/yjbjingcha/p/6897172.html
Copyright © 2011-2022 走看看