当然!只需在极轴上使用pcolormesh.
例如.
import matplotlib.pyplot as plt
import numpy as np
# Generate some data...
# Note that all of these are _2D_ arrays, so that we can use meshgrid
# You'll need to "grid" your data to use pcolormesh if it's un-ordered points
theta, r = np.mgrid[0:2*np.pi:20j, 0:1:10j]
z = np.random.random(theta.size).reshape(theta.shape)
fig, (ax1, ax2) = plt.subplots(ncols=2, subplot_kw=dict(projection='polar'))
ax1.scatter(theta.flatten(), r.flatten(), c=z.flatten())
ax1.set_title('Scattered Points')
ax2.pcolormesh(theta, r, z)
ax2.set_title('Cells')
for ax in [ax1, ax2]:
ax.set_ylim([0, 1])
ax.set_yticklabels([])
plt.show()
如果您的数据尚未在常规网格上,则需要将其格网化以使用pcolormesh.
它看起来像是在你的情节的一个普通的网格.在这种情况下,网格化很简单.如果它已经被命令了,可能就像调用重塑一样简单.否则,一个简单的循环或者利用你的z值作为权重的numpy.histogram2d会做你所需要的.