如何创建这两个单独的极坐标图的图形?

时间:2019-04-19 15:20:23

标签: python matplotlib

我正在尝试在同一图上创建两个单独的图作为子图。这两个图都是极地的。我的尝试导致它们绘制在同一张图上。

def GenerateTrigonometryTable(x): #Define Function
    A = np.arange (0,360,x) 
    B = np.sin(A*np.pi/180)  
    C = np.cos(A*np.pi/180)
    table = np.dstack(([A],[B],[C])) 
    return table 
Theta = (GenerateTrigonometryTable(5)[:,:,0]) 
STheta = (GenerateTrigonometryTable(5)[:,:,1])
CTheta = (GenerateTrigonometryTable(5)[:,:,2])

ax1 = plt.subplot(111, projection='polar')
ax1.plot(Theta.flatten(), STheta.flatten())
ax2 = plt.subplot(111, projection='polar')
ax2.plot(Theta.flatten(), CTheta.flatten())

fig.show()

这会将它绘制在同一张图上,我需要它是两个独立图的图。

2 个答案:

答案 0 :(得分:0)

您需要以下内容:121表示在1x2子图网格上的第一个图,122表示在1x2子图网格上的第二个图。

ax1 = plt.subplot(121, projection='polar')
ax1.plot(Theta.flatten(), STheta.flatten())
ax2 = plt.subplot(122, projection='polar')
ax2.plot(Theta.flatten(), CTheta.flatten())

fig.show()

enter image description here

答案 1 :(得分:0)

更面向对象的方法是:

fig = plt.figure()
ax1 = fig.add_subplot(121, projection='polar')
ax2 = fig.add_subplot(122, projection='polar')
ax1.plot(Theta.flatten(), STheta.flatten())
ax2.plot(Theta.flatten(), CTheta.flatten())

fig.show()

等效于Sheldore的答案,但显示了如何在matplotlib中表达图形,轴和图。