python - 在 2D numpy 数组中找到给定角度的最近项目

标签 python numpy matrix angle

给定一个 numpy 二维数组,在给定角度的情况下,从指定坐标(“X”所在的位置)获取最近项(对于本例“1”)的最佳方法是什么。

例如,假设我们的“X”位于二维数组中的 (1,25),如下所示。假设角度为 225 度,假设 0 度向右笔直,90 度笔直向上。如何获得位于该矢量方向的“1”的最近坐标?

[
0000000000000000000000000000
0000000000000000000000000X00
0000000000000000000000000000
1110000000000000000000000000
1111100000000000000000000000
1111110000000000000000000000
1111111000000000000000000000
1111111110000000000000000000
1111111111100000000000000000
]

最佳答案

我假设朝着那个方向你的意思是像在那条射线上一样。在这种情况下,255° 无解,所以我冒昧地将其更改为 195°。

然后你可以暴力破解它:

import numpy as np

a = """
0000000000000000000000000000
0000000000000000000000000X00
0000000000000000000000000000
1110000000000000000000000000
1111100000000000000000000000
1111110000000000000000000000
1111111000000000000000000000
1111111110000000000000000000
1111111111100000000000000000
"""

a = np.array([[int(i) for i in row] for row in a.strip().replace('X', '2').split()], dtype=np.uint8)

x = np.argwhere(a==2)[0]
y = np.argwhere(a==1)
d = y-x

phi = 195 # 255 has no solutions

on_ray = np.abs(d@(np.sin(np.radians(-phi-90)), np.cos(np.radians(-phi-90))))<np.sqrt(0.5)

show_ray = np.zeros_like(a)
show_ray[tuple(y[on_ray].T)] = 1
print(show_ray)

ymin=y[on_ray][np.argmin(np.einsum('ij,ij->i', d[on_ray], d[on_ray]))]
print(ymin)

输出:

# [[0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]
#  [0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]
#  [0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]
#  [0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]
#  [0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]
#  [0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]
#  [0 0 0 0 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]
#  [1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]
#  [1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]]
# [6 6]

关于python - 在 2D numpy 数组中找到给定角度的最近项目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47916701/

相关文章:

python - 类和私有(private)变量

python - 按元素乘以 1D-numpy 数组(形状(k,1)或(k,))并使结果具有第一个的形状

Ruby-用另一个数组从一个数组中添加/减去元素

python - 在 win 7(64 位)上安装 scrapy

python - 使用私有(private)变量的 Pythonic 方式是什么?

Python 的 fsolve 不起作用

python - Numpy根据XYZ获取最大值

matlab - 精度 Matlab 的斜线矩阵运算符

arrays - 在 MATLAB 中创建一个对角线和左对角线全为 1 的矩阵

javascript - 正则表达式提取WUB内的字符