k-core
k-core主要用于找出图中具有指定core数的子结构,一般k越大,该结构的范围会越小,知道没有满足条件的子结构,且(k)-core的结果一定是(k-1)-core的子图,关于k-core算法的具体细节,可参考直观理解:k-Core算法。
方法名称 | 用途描述 |
---|---|
core_number (G) |
返回每个顶点的核心数 |
k_core (G[, k, core_number]) |
返回图G的 k-core |
k_shell (G[, k, core_number]) |
返回图G的 k-shell |
k_crust (G[, k, core_number]) |
返回图G的 k-crust |
k_corona (G, k[, core_number]) |
返回图G的 k-corona |
k_truss (G, k) |
返回图G的 k-truss |
onion_layers (G) |
返回图的洋葱分解中每个顶点的层。 |
下面开始用代码演示~~~
import networkx as nx
import networkx.algorithms as algos
import matplotlib.pyplot as plt
#创建karate_club
G = nx.karate_club_graph()
nx.draw(G, with_labels = True)
data:image/s3,"s3://crabby-images/76d8b/76d8b19885c0aa6c26c44e72a21a32131d2b3681" alt=""
#返回每个顶点的核心数
print(algos.core_number(G))
#result:{0: 4, 1: 4, 2: 4, 3: 4, 4: 3, 5: 3, 6: 3, 7: 4, 8: 4, 9: 2, 10: 3, 11: 1, 12: 2, 13: 4, 14: 2, 15: 2, 16: 2, 17: 2, 18: 2, 19: 3, 20: 2, 21: 2, 22: 2, 23: 3, 24: 3, 25: 3, 26: 2, 27: 3, 28: 3, 29: 3, 30: 4, 31: 3, 32: 4, 33: 4}
#返回每个顶点的onion_layers
print(algos.onion_layers(G))
#result:{11: 1, 9: 2, 12: 2, 14: 2, 15: 2, 16: 2, 17: 2, 18: 2, 20: 2, 21: 2, 22: 2, 26: 2, 4: 3, 5: 3, 6: 3, 10: 3, 19: 3, 24: 3, 25: 3, 28: 3, 29: 3, 23: 4, 27: 4, 31: 4, 7: 5, 30: 5, 32: 5, 33: 5, 8: 6, 1: 6, 3: 6, 13: 6, 0: 7, 2: 7}
#展示3-core结构
nx.draw(algos.k_core(G, 3), with_labels = True)
data:image/s3,"s3://crabby-images/c1b94/c1b942f91d346af8f9b73759b8d54260f1e56047" alt=""
#展示4-core结构
nx.draw(algos.k_core(G, 4), with_labels = True)
data:image/s3,"s3://crabby-images/87605/87605120e174fc311299df772eede99203b4ad6b" alt=""
#展示3-shell结构
nx.draw(algos.k_shell(G, 3), with_labels = True)
data:image/s3,"s3://crabby-images/3fdb4/3fdb495276b0a5c51da05176f5c9acc34828c729" alt=""
#展示3-shell结构
nx.draw(algos.k_shell(G, 4), with_labels = True)
data:image/s3,"s3://crabby-images/4be5b/4be5bef6146ee27ef93a223a7ddc45471e438e59" alt=""
#展示2-crust结构
nx.draw(algos.k_crust(G, 2), with_labels = True)
data:image/s3,"s3://crabby-images/92cdd/92cddb7b986aebcabe3e8e222eacdae205c74356" alt=""
#展示3-crust结构
nx.draw(algos.k_crust(G, 3), with_labels = True)
data:image/s3,"s3://crabby-images/8cbb8/8cbb8c5b5414eebdf29301ad2deb8addcf668ff7" alt=""
#展示3-corona结构
nx.draw(algos.k_corona(G, 3), with_labels = True)
data:image/s3,"s3://crabby-images/2dc13/2dc133dbe07326bde40c0251e6cb52b877411a38" alt=""
#展示4-corona结构
nx.draw(algos.k_corona(G, 4), with_labels = True)
data:image/s3,"s3://crabby-images/0ec48/0ec48246f5545a8554d84b34dc59a14d08ba4296" alt=""
#展示3-truss结构
nx.draw(algos.k_truss(G, 3), with_labels = True)
data:image/s3,"s3://crabby-images/d50b2/d50b2dff79de9880fdffff026aad0b69532f41ca" alt=""
#展示4-truss结构
nx.draw(algos.k_truss(G, 4), with_labels = True)
data:image/s3,"s3://crabby-images/408a6/408a6f6b0b138d27643a7370499aaefc6ab68bde" alt=""
网友评论