Трябва да посочите цвета на лицата от някаква форма на цветна карта, например ако искате 20 кошчета и spectral
цветна карта,
nbins = 20
colors = plt.cm.spectral(np.linspace(nbins))
След това можете да използвате това, за да укажете цвета на лентите, което вероятно е най-лесно да направите, като първо получите данни за хистограма (с помощта на numpy
) и начертаете стълбовидна диаграма. След това можете да добавите цветната лента към отделна ос в долната част.
Като минимален пример,
import numpy as np
import matplotlib.pyplot as plt
import matplotlib as mpl
nbins = 20
minbin = 0.
maxbin = 1.
data = np.random.normal(size=10000)
bins = np.linspace(minbin,maxbin,20)
cmap = plt.cm.spectral
norm = mpl.colors.Normalize(vmin=data.min(), vmax=data.max())
colors = cmap(bins)
hist, bin_edges = np.histogram(data, bins)
fig = plt.figure()
ax = fig.add_axes([0.05, 0.2, 0.9, 0.7])
ax1 = fig.add_axes([0.05, 0.05, 0.9, 0.1])
cb1 = mpl.colorbar.ColorbarBase(ax1, cmap=cmap,
norm=norm,
orientation='horizontal')
ax.bar(bin_edges[:-1], hist, width=0.051, color=colors, alpha=0.8)
ax.set_xlim((0., 1.))
plt.show()
Което дава,
person
Ed Smith
schedule
03.06.2015