Добавление colorbar в pcolormesh с полярной проекцией

Я пытаюсь добавить цветовую шкалу на график pcolormesh с полярной проекцией. Код работает нормально, если я не укажу полярную проекцию. При заданной полярной проекции получается крошечный график, а цветовая полоса отсутствует. Я делаю что-то глупое, или это ошибка? Я использую matplotlib 1.3.1 на Fedora 20.

import matplotlib.pyplot as plot
import mpl_toolkits.axes_grid1 as axes_grid1
import numpy as np

t = np.linspace(0.0, 2.0 * np.pi, 360)
r = np.linspace(0,100,200)
rg, tg = np.meshgrid(r,t)
c = rg * np.sin(tg)

# If I remove the projection="polar" argument here the 
ax = plot.subplot2grid((1, 1), (0, 0), projection="polar", aspect=1.)
im = ax.pcolormesh(t, r, c.T)
divider = axes_grid1.make_axes_locatable(ax)
cax = divider.append_axes("right", size="5%", pad=0.05)
plot.colorbar(im, cax=cax)
plot.show()

1 ответ

То, как вы это делаете, cax ось на самом деле в polar проекция. Вы можете проверить это:

cax = divider.append_axes("right", size="200%", pad=0.5)
#plot.colorbar(im, cax=cax)
cax.pcolormesh(t, r, c.T)

Хотя это может быть ошибкой, я думаю, что более чистым способом для достижения этой цели может быть использование GridSpec:

gs = gridspec.GridSpec(1, 2,
                       width_ratios=[10,1],
                       )

ax1 = plt.subplot(gs[0], projection="polar", aspect=1.)
ax2 = plt.subplot(gs[1])

t = np.linspace(0.0, 2.0 * np.pi, 360)
r = np.linspace(0,100,200)
rg, tg = np.meshgrid(r,t)
c = rg * np.sin(tg)

im = ax1.pcolormesh(t, r, c.T)
plot.colorbar(im, cax=ax2)

Другие вопросы по тегам