我有一个旋转的极点投影(取自快速刷新模型参数),我能够在 matplotlib-basemap 中正确绘制,但无法弄清楚如何用 cartopy 重现。这是使用底图的 Python 代码:
import matplotlib.pyplot as plt
from mpl_toolkits.basemap import Basemap
bm = Basemap(projection = "rotpole",
o_lat_p = 36.0,
o_lon_p = 180.0,
llcrnrlat = -10.590603,
urcrnrlat = 46.591976,
llcrnrlon = -139.08585,
urcrnrlon = 22.661009,
lon_0 = -106.0,
rsphere = 6370000,
resolution = 'l')
fig = plt.figure(figsize=(8,8))
ax = fig.add_axes([0.1,0.1,0.8,0.8])
bm.drawcoastlines(linewidth=.5)
print bm.proj4string
plt.savefig("basemap_map.png")
plt.close(fig)
打印的 proj4 字符串是:
+o_proj=longlat +lon_0=-106.0 +o_lat_p=36.0 +R=6370000.0 +proj=ob_tran +units=m +o_lon_p=180.0
如果我在 cartopy 中使用 RotatedPole 投影并从上方提供投影参数,我会在南极得到一个图像。这是一个片段(从真实示例中手动输入,请注意):
from cartopy import crs
import matplotlib.pyplot as plt
cart = crs.RotatedPole(pole_longitude=180.0,
pole_latitude=36.0,
central_rotated_longitude=-106.0,
globe = crs.Globe(semimajor_axis=6370000,
semiminor_axis=6370000))
fig = plt.figure(figsize=(8,8))
ax = plt.axes([0.1,0.1,0.8,0.8], projection=cart)
ax.set_extent([-139.08585, 22.661009, -10.590603, 46.591976], crs.Geodetic())
plt.savefig("cartopy_map.png")
plt.close(fig)
我还尝试修改 RotatedPole 类的参数以从上面生成 proj4 参数,甚至尝试创建自己的 _CylindricalProjection 子类并直接在构造函数中设置 proj4 参数,但仍然没有运气。
在 cartopy 中产生与底图相同的结果的正确方法是什么?
这是底图图像:
这是 cartopy 为上述示例生成的内容:
谢谢你的帮助!
账单