gpt4 book ai didi

python - 你能改变cartopy中的虹膜立方体投影吗

转载 作者:行者123 更新时间:2023-11-28 22:58:31 25 4
gpt4 key购买 nike

我真的很喜欢 cartopy 可以在不同的 map 投影中自动绘制的想法。但是,我不知道如何处理 Iris 立方体。作为一个姊妹项目,我希望我能做到。有可能做这样的事情吗?

import iris as I
import cartopy.crs as ccrs
import matplotlib.pyplot as plt

someCube = I.load('someCube.pp')
ax = plt.axes(projection=ccrs.Robinson())
I.plot.contourf(someCube, transform=ccrs.Robinson())
plt.show()

谢谢

最佳答案

我采用了您的伪代码并使其可以与 Iris 的示例数据一起运行:

import iris
import iris.plot as iplt
import cartopy.crs as ccrs
import matplotlib.pyplot as plt


fname = iris.sample_data_path('air_temp.pp')
air_temp = iris.load_cube(fname)

ax = plt.axes(projection=ccrs.Robinson())
iplt.contourf(air_temp, transform=ccrs.Robinson(central_longitude=180))
ax.coastlines()

plt.show()

如果你运行这段代码,你会得到一个异常:

Traceback (most recent call last):
File "using_custom_projections.py", line 11, in <module>
iris.plot.contourf(air_temp, transform=ccrs.Robinson())
File "lib/iris/plot.py", line 452, in contourf
result = _draw_2d_from_points('contourf', None, cube, *args, **kwargs)
File "lib/iris/plot.py", line 263, in _draw_2d_from_points
result = _map_common(draw_method_name, arg_func, iris.coords.POINT_MODE, cube, data, *args, **kwargs)
File "lib/iris/plot.py", line 406, in _map_common
assert 'transform' not in kwargs, 'Transform keyword is not allowed.'
AssertionError: Transform keyword is not allowed.

它试图告诉你,你不需要告诉它立方体在哪个“变换”(或坐标系)中。原因是 Iris 立方体应该包含关于底层数据的完整元数据:坐标系是该元数据的一部分。

因此,要使示例正常运行,您只需删除 contourf 调用中的 transform 关键字参数即可:

import iris
import iris.plot as iplt
import cartopy.crs as ccrs
import matplotlib.pyplot as plt


fname = iris.sample_data_path('air_temp.pp')
air_temp = iris.load_cube(fname)

ax = plt.axes(projection=ccrs.Robinson(central_longitude=180))
iplt.contourf(air_temp)
ax.coastlines()

plt.show()

contoured result

iris gallery 中有一个类似的例子, 具体来说 http://scitools.org.uk/iris/docs/latest/examples/graphics/rotated_pole_mapping.html#rotated-pole-mapping-03 (示例中的最后一个图)。

HTH,

关于python - 你能改变cartopy中的虹膜立方体投影吗,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13766275/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com