python求度分布的程序

使用python求度分布的程序

# -*- coding: utf-8 -*-
"""
Created on Sun Jun 16 20:13:42 2019

@author: Administrator
"""

"""

这个函数的作用是将一个矩阵给转换成一个图,
矩阵以多维列表的形式存在,即列表的列表
此处的转换是针对无向图

根据邻接矩阵得到图之后,我们就可以调用networkx
里面的各种函数来分析图的性质,比如度分布,
平均路径程度,聚类系数等一系列图的拓扑性质

"""

import networkx as nx
import matplotlib.pyplot as plt


def degree_of_graph():
  
 # reload(sys) 
  G = nx.Graph()
  
  filestr = ""
  
  with open("matrix.txt") as files:
     for line in files:
         filestr += line.strip()
  
  #将字符串转换成列表
  matrix = eval(filestr)
  
  #存储y坐标的值
  y_value = []
  
  #存储x坐标的值
  x_value = []
  
  nodes = range(len(matrix))
  G.add_nodes_from(nodes)
 
  for i in range(len(matrix)):
    for j in range(len(matrix)):
      if(matrix[i][j] == 1):
		G.add_edge(i, j)
        
  print("每个节点的编号以及度值如下:")
  print(nx.degree(G)) 
  print("---------------------------------------------------------")
  print("每个度值的个数为:")
  print(nx.degree_histogram(G))
  print("---------------------------------------------------------")
  print("度值序列如下:")
  print(range(len(nx.degree_histogram(G))))
  print("---------------------------------------------------------")
  print("度值所占的比例如下:")
  for i in nx.degree_histogram(G):
      y_value.append(float(i)/sum(nx.degree_histogram(G)))
      
  for j in range(len(nx.degree_histogram(G))):
      x_value.append(j)
  print(y_value)
  print("---------------------------------------------------------")
  
  #使用x坐标和y坐标来构成一个字典
  x_y_value = {}
  
  for i in range(len(x_value)):
      for j in range(len(y_value)):
          if(i == j and y_value[j] != 0):
              x_y_value[x_value[i]] = y_value[j]
              
  
  print("去掉0以后的度值序列如下:")
  print(x_y_value.keys())
  print("去掉0以后的度值所占的比例如下:")
  print(x_y_value.values())
  fig = plt.figure()
  ax1 = fig.add_subplot(111)  

  #设置标题  
  #ax1.set_title("  ")  

  plt.xlabel('K')
  plt.ylabel("P(K)")

  plt.scatter(x_y_value.keys(),x_y_value.values(),c = "red",s=10)


degree_of_graph()

在这里插入图片描述

  • 4
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值