如何从一系列点中找到最接近的坐标?

2022-04-15 00:00:00 python coordinates distance

问题描述

假设我有一个x,y坐标列表,如下所示:

A = [(26, 63), (23, 63), (22, 63), (21, 63), (20, 63), (22, 62), (27, 63)] 

我有一个点的x,y坐标,如下所示:

leftbottom = (0, 238)

现在,我要在列表A中查找最接近leftbottom点的点。

如何才能最有效地执行此操作?


解决方案

NumPy有一个有用的函数:Norm。

import numpy as np
A = [(26, 63), (25, 63), (24, 63), (23, 63), (22, 63), (21, 63), (20, 63), (22, 62), (27, 63)]
A = np.array(A)
leftbottom = np.array((0,238))
distances = np.linalg.norm(A-leftbottom, axis=1)
min_index = np.argmin(distances)
print(f"the closest point is {A[min_index]}, at a distance of {distances[min_index]}")

结果:

the closest point is [20 63], at a distance of 176.13914953808538

相关文章