Note
Go to the end to download the full example code
Expected Degree Sequence#
Random graph from given degree sequence.
Degree histogram
degree (#nodes) ****
0 ( 0)
1 ( 0)
2 ( 0)
3 ( 0)
4 ( 0)
5 ( 0)
6 ( 0)
7 ( 0)
8 ( 0)
9 ( 0)
10 ( 0)
11 ( 0)
12 ( 0)
13 ( 0)
14 ( 0)
15 ( 0)
16 ( 0)
17 ( 0)
18 ( 0)
19 ( 0)
20 ( 0)
21 ( 0)
22 ( 0)
23 ( 0)
24 ( 0)
25 ( 0)
26 ( 0)
27 ( 0)
28 ( 0)
29 ( 0)
30 ( 0)
31 ( 1) *
32 ( 1) *
33 ( 3) ***
34 ( 0)
35 ( 3) ***
36 ( 5) *****
37 ( 3) ***
38 (10) **********
39 ( 8) ********
40 ( 7) *******
41 (12) ************
42 (24) ************************
43 (14) **************
44 (15) ***************
45 (22) **********************
46 (30) ******************************
47 (30) ******************************
48 (28) ****************************
49 (30) ******************************
50 (28) ****************************
51 (26) **************************
52 (26) **************************
53 (30) ******************************
54 (19) *******************
55 (26) **************************
56 (20) ********************
57 (14) **************
58 (13) *************
59 (14) **************
60 ( 5) *****
61 ( 7) *******
62 ( 9) *********
63 ( 2) **
64 ( 3) ***
65 ( 4) ****
66 ( 2) **
67 ( 2) **
68 ( 0)
69 ( 1) *
70 ( 1) *
71 ( 0)
72 ( 1) *
73 ( 0)
74 ( 0)
75 ( 0)
76 ( 0)
77 ( 0)
78 ( 1) *
import networkx as nx
# make a random graph of 500 nodes with expected degrees of 50
n = 500 # n nodes
p = 0.1
w = [p * n for i in range(n)] # w = p*n for all nodes
G = nx.expected_degree_graph(w) # configuration model
print("Degree histogram")
print("degree (#nodes) ****")
dh = nx.degree_histogram(G)
for i, d in enumerate(dh):
print(f"{i:2} ({d:2}) {'*'*d}")
Total running time of the script: (0 minutes 0.026 seconds)