创建2D数据的3D直方图
将二维数据的直方图演示为3D中的条形图。

# This import registers the 3D projection, but is otherwise unused.from mpl_toolkits.mplot3d import Axes3D # noqa: F401 unused importimport matplotlib.pyplot as pltimport numpy as np# Fixing random state for reproducibilitynp.random.seed(19680801)fig = plt.figure()ax = fig.add_subplot(111, projection='3d')x, y = np.random.rand(2, 100) * 4hist, xedges, yedges = np.histogram2d(x, y, bins=4, range=[[0, 4], [0, 4]])# Construct arrays for the anchor positions of the 16 bars.xpos, ypos = np.meshgrid(xedges[:-1] + 0.25, yedges[:-1] + 0.25, indexing="ij")xpos = xpos.ravel()ypos = ypos.ravel()zpos = 0# Construct arrays with the dimensions for the 16 bars.dx = dy = 0.5 * np.ones_like(zpos)dz = hist.ravel()ax.bar3d(xpos, ypos, zpos, dx, dy, dz, color='b', zsort='average')plt.show()
