有人能给我解释一下Numpy中meshgrid
函数的用途吗?我知道它创建了某种坐标网格,但我真的看不到它的直接好处。
我正在学习塞巴斯蒂安Raschka的“Python机器学习”,他正在使用它来绘制决策边界。参见input 11 here。
我也尝试过官方文档中的这段代码,但是,同样,输出对我来说没有意义。
x = np.arange(-5, 5, 1)
y = np.arange(-5, 5, 1)
xx, yy = np.meshgrid(x, y, sparse=True)
z = np.sin(xx**2 + yy**2) / (xx**2 + yy**2)
h = plt.contourf(x,y,z)
如果可能的话,请给我举一些现实世界的例子。
9条答案
按热度按时间u5rb5r591#
meshgrid
的用途是用一个x值数组和一个y值数组创建一个矩形网格。例如,如果我们想创建一个网格,其中x和y方向上的每个0到4之间的整数值都有一个点,要创建一个矩形网格,我们需要
x
和y
点的每一种组合。这将是25个点,对吗?如果我们想为所有这些点创建一个x和y数组,我们可以做以下事情。
这将导致以下
x
和y
矩阵,使得每个矩阵中的对应元素的配对给出网格中的点的x和y坐标。然后我们可以绘制这些图来验证它们是一个网格:
显然,这是非常繁琐的,特别是对于
x
和y
的大范围。相反,meshgrid
可以为我们生成:我们必须指定的只是唯一的x
和y
值。现在,当我们调用
meshgrid
时,会自动获得前面的输出。创建这些矩形网格对很多任务都很有用,在你文章中提供的例子中,它只是一种在
x
和y
的取值范围内对函数(sin(x**2 + y**2) / (x**2 + y**2)
)进行采样的方法。因为这个函数是在一个矩形网格上采样的,所以现在可以将这个函数可视化为一个“图像”。
此外,现在可以将结果传递给需要矩形网格数据的函数(即
contourf
)eh57zj3b2#
微软Excel提供:
t9eec4r03#
实际上
np.meshgrid
的用途已经在文档中提到了:np.meshgrid
从坐标向量返回坐标矩阵。
在给定一维坐标数组x1,x2,...,xn的情况下,为N-D网格上的N-D标量/矢量场的矢量化求值创建N-D坐标数组。
所以它的主要目的是创建一个坐标矩阵。
你可能会问自己:
为什么需要创建坐标矩阵?
在Python/NumPy中需要坐标矩阵的原因是,坐标与值之间没有直接关系,除非坐标从零开始并且是纯正整数,然后你可以只使用数组的索引作为索引,但是如果不是这种情况,你就需要将坐标与数据一起存储,这就是网格的用武之地。
假设您的数据为:
但是,每个值代表3 x 2千米的区域(水平x垂直)。假设原点位于左上角,并且您需要表示距离的数组,可以用途:
其中v为:
和h:
如果你有两个索引,比如
x
和y
(这就是为什么meshgrid
的返回值通常是xx
或xs
,而不是x
,在这个例子中,我选择h
表示水平!),那么你可以通过下式得到点的x坐标,y坐标和该点的值:这使得跟踪坐标和变得更加容易(更重要的是),您可以将它们传递给需要知道坐标的函数。
稍微长一点的解释
然而,
np.meshgrid
本身并不经常被直接使用,大多数情况下,我们只使用类似对象np.mgrid
或np.ogrid
中的一个,这里np.mgrid
表示sparse=False
,np.ogrid
表示sparse=True
情况(我指的是np.meshgrid
的sparse
参数)注意,np.meshgrid
与np.ogrid
和np.mgrid
之间有一个显著的区别:前两个返回值(如果有两个或更多)是相反的。通常这并不重要,但是你应该根据上下文给变量给予一个有意义的名字。例如,在2D网格和
matplotlib.pyplot.imshow
的情况下,将第一个返回项命名为np.meshgrid
x
并将第二个命名为y
是有意义的,而对于np.mgrid
和np.ogrid
则相反。np.ogrid
和稀疏网格如前所述,与
np.meshgrid
相比,输出是相反的,这就是为什么我将其解压缩为yy, xx
而不是xx, yy
:这看起来已经像坐标,特别是2D图的x和y线。
可视化:
np.mgrid
和密集/充实的网格这同样适用于以下情况:与
np.meshgrid
相比,输出相反:与
ogrid
不同,这些数组包含-5〈= xx〈= 5中的所有xx
和yy
坐标;-5〈= yy〈= 5网格。功能
它不仅限于2D,这些函数也适用于任意维度(在Python中,函数的参数有一个最大值,NumPy也有一个最大维度):
即使这些也适用于1D,但有两个(更常见的)1D栅格创建功能:
np.arange
np.linspace
除了
start
和stop
参数之外,它还支持step
参数(即使是表示步骤数的复杂步骤):应用程序
你特别问了用途,事实上,如果你需要一个坐标系,这些网格是非常有用的。
例如,如果有一个NumPy函数用于计算二维距离:
你想知道每个点的距离:
如果在密集网格中传递而不是在开放网格中传递,输出将是相同的。NumPys广播使之成为可能!
让我们想象一下结果:
这也是NumPys
mgrid
和ogrid
变得非常方便的时候,因为它允许您轻松地更改网格的分辨率:但是,由于
imshow
不支持x
和y
输入,因此必须手动更改刻度,如果它接受x
和y
坐标,那将非常方便,对吗?用NumPy编写自然处理网格的函数很容易,而且NumPy、SciPy、matplotlib中有几个函数希望你传入网格。
我喜欢图像,所以让我们来探索一下
matplotlib.pyplot.contour
:注意坐标是如何被正确设置的!如果你只是传入了
density
,情况就不是这样了。或者用astropy models再给予一个有趣的例子(这次我不太关心坐标,我只是用它们来创建一些网格):
虽然这只是“为了外观”,但Scipy中的一些与功能模型和拟合相关的功能(例如
scipy.interpolate.interp2d
,scipy.interpolate.griddata
甚至显示了使用np.mgrid
的示例)等需要网格。这些功能大多数使用开放网格和密集网格,但有些只使用其中之一。wixjitnu4#
假设您有一个函数:
比如,你想看看它在0到2*pi的范围内是什么样子的,你会怎么做?这里有
np.meshgrid
:这样的图看起来像这样:
所以
np.meshgrid
只是一种方便,原则上也可以这样做:但是在那里你需要意识到你的维度(假设你有两个以上...)和正确的广播。
np.meshgrid
为你做了所有这些。此外,meshgrid还允许您删除坐标和数据,例如,如果您要执行插值但排除某些值:
那么你现在怎么做插值呢?你可以把
x
和y
赋给一个像scipy.interpolate.interp2d
这样的插值函数,所以你需要一种方法来知道哪些坐标被删除了:然后你仍然可以用“正确的”坐标进行插值(尝试不使用meshgrid,你会有很多额外的代码):
原始meshgrid允许您再次在原始网格上进行插值:
这些只是我使用
meshgrid
的一些例子,可能还有更多。0g0grzrc5#
meshgrid
的目的是通过NumPy库中提供的更快矢量化操作来帮助replace slow Python loops。meshgrid
的作用是准备矢量化操作所需的2D数组。假设我们有两个值序列,
我们想对每一对可能的值执行一个操作,一个从第一个列表中取出,一个从第二个列表中取出,我们还想存储结果,例如,我们想得到每一对可能的值的总和。
结果:
结果:
你可以从这个基本的插图中看到显式的慢Python循环是如何被Numpy库中隐藏的更快的C循环所取代的。这个原理广泛用于3D操作,包括彩色像素贴图。常见的例子是3D绘图。
(从本网站借用)
meshgrid
用于创建-4和+4之间的坐标对,在X和Y方向上各有0.25的增量。然后,使用每对坐标来从中找到R和Z。这种准备坐标"网格"的方法常用于绘制3D表面或为2D表面着色。meshgrid
准备的两个数组是:这些数组是通过水平或垂直重复提供的值创建的。这两个数组的形状对于矢量操作是兼容的。
numpy.meshgrid
来自from MATLAB,就像许多其他的NumPy函数一样。所以你也可以学习MATLAB中的例子来看看meshgrid
的使用,3D绘图的代码看起来像the same in MATLAB。lf3rwulv6#
meshgrid有助于从两个阵列中所有点对的两个1-D阵列创建矩形栅格。
现在,如果你已经定义了一个函数f(x,y),你想把这个函数应用到数组'x'和'y'中所有可能的点组合上,那么你可以这样做:
比如说,如果你的函数只产生两个元素的乘积,那么这就是笛卡尔乘积的实现方式,对于大型数组来说非常有效。
引用自here
umuewwlo7#
基本理念
给定可能的x值
xs
(可以将其视为图中x轴上的刻度线)和可能的y值,ys
,meshgrid
生成相应的(x,y)网格点集--类似于set((x, y) for x in xs for y in yx)
。例如,如果xs=[1,2,3]
和ys=[4,5,6]
,我们将得到坐标集{(1,4), (2,4), (3,4), (1,5), (2,5), (3,5), (1,6), (2,6), (3,6)}
。返回值的形式
但是,
meshgrid
返回的表示与上面的表达式有两个不同之处:meshgrid
在2D数组中布置网格点:行对应于不同的y值,列对应于不同的x值---如list(list((x, y) for x in xs) for y in ys)
中所示,它将给出以下数组:meshgrid
分别返回x和y坐标(即在两个不同的numpy 2D数组中):注意,
np.meshgrid
也可以生成更高维的网格。给定xs,ys和zs,你可以得到xcoords,ycoords,zcoords作为3d数组。meshgrid
还支持维的逆序以及结果的稀疏表示。应用程序
我们为什么要这种形式的输出?
def f(x, y): return (x - y) ** 2
,它可以在两个标量上工作,我也可以在两个numpy数组上应用它来得到一个元素级结果数组:例如,f(xcoords, ycoords)
或f(*np.meshgrid(xs, ys))
在上例中给出以下内容:np.prod(np.meshgrid([1,2,3], [1,2], [1,2,3,4]), axis=0)
.meshgrid
。为此,您使用meshgrid
生成一个网格,在每个网格点上计算函数(例如,如上所示),然后将xcoords、ycoords和计算的f值(即zcoords)传递给contourf函数。hk8txs488#
幕后:
以@Sarsaparilla的answer数据集为例:
并且它输出:
hiz5n14c9#
大多数情况下,您只需要
list(zip(X,Y))
,其中X = np.linspace(x)
和Y = np.linspace(y)