gpt4 book ai didi

python - 在 draw_networkx 和 matplotlib 中设置颜色

转载 作者:太空狗 更新时间:2023-10-30 02:59:02 24 4
gpt4 key购买 nike

我正在绘制两种类型的图形,我想为它们对齐颜色:

  1. 网络中节点的颜色x.Graph,以及
  2. 常规绘图中 pyplot.hlines 的颜色。

这两个图都依赖于以 node_names 作为键、以 ints 作为值的字典,以及 matplotlib.colors.LinearSegmentedColormap cmap。像下面这样:

import matplotlib.pyplot as plt
Dict = {"Alice": 0, "Bob": 1, "Carol": 2}
cmap = plt.cm.Accent

这让我可以为每个名字获得独特的颜色。对于这个例子:

for key, value in Dict.iteritems():
print key, value, cmap(value)

给我

Bob 1 (0.50482122313742539, 0.78532873251858881, 0.50718954287323292, 1.0)
Alice 0 (0.49803921580314636, 0.78823530673980713, 0.49803921580314636, 1.0)
Carol 2 (0.51160323047170453, 0.7824221582973705, 0.5163398699433196, 1.0)

可以按如下方式使用:

plt.hlines(1, 1, 5, cmap(Dict["Alice"]))
plt.hlines(2, 1, 5, cmap(Dict["Bob"]))
plt.hlines(3, 1, 5, cmap(Dict["Carol"]))

但是,这些值与我绘制以下网络时得到的结果完全不匹配:

G = nx.Graph()
G.add_nodes_from(Dict.keys())
nx.draw_networkx(G, nodelist=Dict.keys(), node_color=range(3), \
cmap=plt.cm.Accent)

对于网络图,我得到了 3 种明显不同的颜色,但对于 hlines,它们几乎无法区分。

关于 nx.draw_networkx 如何使用 node_colorcmap 我错过了什么?

最佳答案

您需要将您的值映射到 [0,1] 颜色图范围内。为您的 hline 图明确地执行此操作 - networkx 的 maptlotlib 接口(interface)将为您执行此操作,您可以指定最小值和最大值。请注意,对于 networkx.draw_networkx 调用,nodelist 顺序和 node_color 顺序必须相同。

import networkx as nx
import matplotlib.pyplot as plt
import matplotlib as mpl
Dict = {"Alice": 0, "Bob": 1, "Carol": 2}
cmap = plt.cm.Accent
norm = mpl.colors.Normalize(vmin=0, vmax=2)
m = plt.cm.ScalarMappable(norm=norm, cmap=cmap)
for key, value in Dict.iteritems():
print key, value, m.to_rgba(value)
plt.hlines(1, 1, 5, m.to_rgba(Dict["Alice"]), linewidth=50)
plt.hlines(2, 1, 5, m.to_rgba(Dict["Bob"]), linewidth=50)
plt.hlines(3, 1, 5, m.to_rgba(Dict["Carol"]), linewidth=50)
G = nx.Graph()
G.add_nodes_from(Dict.keys())

nodelist,node_color = zip(*Dict.items())
nx.draw_networkx(G, nodelist=nodelist, node_size=1000, node_color=node_color,vmin=0.0,vmax=2.0, cmap=cmap)
plt.show()

enter image description here

关于python - 在 draw_networkx 和 matplotlib 中设置颜色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32438462/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com