我想为这个组绘制一组带有颜色条的等高线图。由于颜色条取决于您在ax
参数中指定的子图,因此颜色条的范围不会反映前两列中所有图的值范围。
我可以指定反映刻度线上最小值(mina=-500
)和最大值(maxa=500
)的第一个颜色栏(左侧)吗?
这是我的代码:
import numpy as np
import matplotlib.pyplot as plt
v = np.arange(-180,181,15)
y,x = np.meshgrid(v,v)
p1 = 500*np.sin(x+y)
p2 = x
p3 = -500*np.sin(3*x+y)
p4 = y
p5 = -200*np.cos(x+5*y)
p6 = 100*np.cos(x+6*y)
f, ax = plt.subplots(2,3,sharex='row',sharey='col',figsize=(4,6))
mina = min(min(p1.reshape(625,)),min(p2.reshape(625,)),min(p3.reshape(625,)),min(p4.reshape(625,)))
maxa = max(max(p1.reshape(625,)),max(p2.reshape(625,)),max(p3.reshape(625,)),max(p4.reshape(625,)))
minb = min(min(p5.reshape(625,)),min(p6.reshape(625,)))
maxb = max(max(p5.reshape(625,)),max(p6.reshape(625,)))
ax[0,0].contourf(x,y,p1,20,vmin=mina,vmax=maxa)
ax[0,0].set(adjustable='box-forced', aspect='equal')
l0 = ax[1,0].contourf(x,y,p2,20,vmin=mina,vmax=maxa)
ax[1,0].set(adjustable='box-forced', aspect='equal')
ax[0,1].contourf(x,y,p3,20,vmin=mina,vmax=maxa)
ax[0,1].set(adjustable='box-forced', aspect='equal')
ax[1,1].contourf(x,y,p4,20,vmin=mina,vmax=maxa)
ax[1,1].set(adjustable='box-forced', aspect='equal')
ax[0,2].contourf(x,y,p5,20,vmin=minb,vmax=maxb)
ax[0,2].set(adjustable='box-forced', aspect='equal')
l1 = ax[1,2].contourf(x,y,p6,20,vmin=minb,vmax=maxb)
ax[1,2].set(adjustable='box-forced', aspect='equal')
f.colorbar(l0, ax=list(ax[1,0:2]),orientation='horizontal', pad=0.2)
f.colorbar(l1, ax=ax[1,2],orientation='horizontal', aspect=10, pad=0.2)
plt.setp([a.get_xticklabels() for a in ax[0,:]], visible=False)
plt.setp([a.get_yticklabels() for a in ax[:,1]], visible=False)
plt.setp([a.get_yticklabels() for a in ax[:,2]], visible=False)
plt.show()
答案 0 :(得分:0)
我认为在这种情况下解决方案很简单:将第一个绘图用作颜色栏的ScalarMappable
l0 = ax[0,0].contourf(x,y,p1,20,vmin=mina,vmax=maxa)
#...
l1 = ax[0,2].contourf(x,y,p5,20,vmin=minb,vmax=maxb)
#...
在更一般的情况下,可能一个图包含最小值,而另一个图包含最大值,解决方案是创建专门用于颜色条的ScalarMappable。
sm = plt.cm.ScalarMappable(cmap="viridis", norm=plt.Normalize(vmin=mina, vmax=maxa))
sm.set_array([])
f.colorbar(sm, ax=list(ax[1,0:2]),orientation='horizontal', pad=0.2)