如何在极坐标中制作箭袋图

时间:2012-12-11 21:27:26

标签: python matplotlib

如何在极坐标中制作箭袋图?我有r和theta的数据。我试过了:

import numpy as np

radii = np.linspace(0.5,1,10)
thetas = np.linspace(0,2*np.pi,20)
theta, r = np.meshgrid(thetas, radii)

f = plt.figure()
ax = f.add_subplot(111, polar=True)
ax.quiver(theta, r, dr, dt)

其中dr和dt是r和theta方向上的数据向量。

1 个答案:

答案 0 :(得分:5)

看起来quiver不会为你做转换。你需要做(r,t) - > (x,y)手工转换:

radii = np.linspace(0.5,1,10)
thetas = np.linspace(0,2*np.pi,20)
theta, r = np.meshgrid(thetas, radii)

dr = 1
dt = 1

f = plt.figure()
ax = f.add_subplot(111, polar=True)
ax.quiver(theta, r, dr * cos(theta) - dt * sin (theta), dr * sin(theta) + dt * cos(theta))

graph