0

我的目标是绘制一些数据并将其与世界地图合并。我使用 Delaunay 三角剖分生成数据,如下所示:

u = np.array(lat)
v = np.array(lon)
x = u
y = v
z = np.array(iwv)
tri = Delaunay(np.array([u,v]).T)
plt.tricontourf(y, x, z, lev, triangles=tri.simplices)
plt.colorbar()
plt.show()

我还使用 mpl_toolkits 制作了一张地图:

from mpl_toolkits.basemap import Basemap
import matplotlib.pyplot as plt
m = Basemap(projection='merc',llcrnrlat= 35,urcrnrlat=60,llcrnrlon=0,urcrnrlon=30,resolution='c', suppress_ticks=True)
m.drawcountries()
m.drawcoastlines()
plt.show()

这些程序给了我两张连续的分开的图片,上面有三角测量的结果和地图。如何合并它们并获得地图和三角测量结果的图片?先感谢您。

给阿玛蒂塔。感谢您的回答,但它没有帮助。当我运行此代码时:

u = np.array(lat)
v = np.array(lon)
x = u
y = v
z = np.array(iwv)
tri = Delaunay(np.array([u,v]).T)
lev = np.linspace(0, 0.1, 100)
m = Basemap(projection='merc',llcrnrlat= 35,urcrnrlat=60,llcrnrlon=0,urcrnrlon=30,resolution='c', suppress_ticks=True)
m.drawcountries()
m.drawcoastlines()
plt.tricontourf(y, x, z, lev, triangles=tri.simplices)
plt.colorbar()
plt.show()

我只得到一张带彩条的空地图。

致 dl.meteo:谢谢,但当我尝试这样做时,我收到下一条消息:

> Traceback (most recent call last):   File
> "/home/anton/PycharmProjects/final/test.py", line 76, in <module>
>     plot = m.contourf(x1, y1,z, lev)   File "/usr/lib/pymodules/python2.7/mpl_toolkits/basemap/__init__.py", line
> 521, in with_transform
>     return plotfunc(self,x,y,data,*args,**kwargs)   File "/usr/lib/pymodules/python2.7/mpl_toolkits/basemap/__init__.py", line
> 3644, in contourf
>     xx = x[x.shape[0]/2,:] IndexError: too many indices

据我了解,contourf() 中的第三个参数应该是二维数组,但三角测量返回一维数组。

4

1 回答 1

0

您必须将 m (map) 引用到您的变量 x 和 y 。

x,y = m(lats,lons)

然后你必须初始化轮廓

plot = m.contour(x,y)

我希望这会有所帮助,我也是初学者;)

于 2016-03-17T14:26:34.480 回答