48 lines
1.2 KiB
Python
48 lines
1.2 KiB
Python
"""
|
|
=======
|
|
Sampson
|
|
=======
|
|
|
|
Sampson's monastery data.
|
|
|
|
Shows how to read data from a zip file and plot multiple frames.
|
|
|
|
The data file can be found at:
|
|
|
|
- https://github.com/networkx/networkx/blob/main/examples/drawing/sampson_data.zip
|
|
"""
|
|
|
|
import zipfile
|
|
from io import BytesIO as StringIO
|
|
|
|
import matplotlib.pyplot as plt
|
|
import networkx as nx
|
|
|
|
with zipfile.ZipFile("sampson_data.zip") as zf:
|
|
e1 = StringIO(zf.read("samplike1.txt"))
|
|
e2 = StringIO(zf.read("samplike2.txt"))
|
|
e3 = StringIO(zf.read("samplike3.txt"))
|
|
|
|
G1 = nx.read_edgelist(e1, delimiter="\t")
|
|
G2 = nx.read_edgelist(e2, delimiter="\t")
|
|
G3 = nx.read_edgelist(e3, delimiter="\t")
|
|
pos = nx.spring_layout(G3, iterations=100, seed=173)
|
|
plt.clf()
|
|
|
|
plt.subplot(221)
|
|
plt.title("samplike1")
|
|
nx.draw(G1, pos, node_size=50, with_labels=False)
|
|
plt.subplot(222)
|
|
plt.title("samplike2")
|
|
nx.draw(G2, pos, node_size=50, with_labels=False)
|
|
plt.subplot(223)
|
|
plt.title("samplike3")
|
|
nx.draw(G3, pos, node_size=50, with_labels=False)
|
|
plt.subplot(224)
|
|
plt.title("samplike1,2,3")
|
|
nx.draw(G3, pos, edgelist=list(G3.edges()), node_size=50, with_labels=False)
|
|
nx.draw_networkx_edges(G1, pos, alpha=0.25)
|
|
nx.draw_networkx_edges(G2, pos, alpha=0.25)
|
|
plt.tight_layout()
|
|
plt.show()
|