python - 确定 numpy 数组的 2 个(垂直或水平)相邻元素是否具有相同值的最快方法

标签 python arrays numpy multidimensional-array scipy

我正在寻找确定 2 个(垂直或水平)相邻元素是否具有相同值的最快方法。

假设我有一个 4x4 大小的 numpy 数组。

array([             
[8, 7, 4, 3],    
[8, 4, 0, 4],          
[3, 2, 2, 1],              
[9, 8, 7, 6]])

我希望能够识别出第一列中有两个相邻的8,第三行中有两个相邻的2。我可以对支票进行硬编码,但这会很难看,我想知道是否有更快的方法。

感谢所有指导。谢谢。

最佳答案

我们会沿着行和列寻找微分值,以寻找 zeros 信号重复的值。因此,我们可以做 -

(np.diff(a,axis=0) == 0).any() | (np.diff(a,axis=1) == 0).any()

或者使用切片来提升性能-

(a[1:] == a[:-1]).any() | (a[:,1:] == a[:,:-1]).any()

因此,(a[1:] == a[:-1]).any() 是垂直邻接,而另一个是水平邻接。

沿行或列扩展到 n 个相邻的(相同值)-

from scipy.ndimage.filters import convolve1d as conv

def vert_horz_adj(a, n=1):
    k = np.ones(n,dtype=int)
    v = (conv((a[1:]==a[:-1]).astype(int),k,axis=0,mode='constant')>=n).any()
    h = (conv((a[:,1:]==a[:,:-1]).astype(int),k,axis=1,mode='constant')>=n).any()
    return v | h

sample 运行-

In [413]: np.random.seed(0)
     ...: a = np.random.randint(11,99,(10,4))
     ...: a[[2,3,4,6,7,8],0] = 1

In [414]: a
Out[414]: 
array([[55, 58, 75, 78],
       [78, 20, 94, 32],
       [ 1, 98, 81, 23],
       [ 1, 76, 50, 98],
       [ 1, 92, 48, 36],
       [88, 83, 20, 31],
       [ 1, 80, 90, 58],
       [ 1, 93, 60, 40],
       [ 1, 30, 25, 50],
       [43, 76, 20, 68]])

In [415]: vert_horz_adj(a, n=1)
Out[415]: True  # Because of first col

In [416]: vert_horz_adj(a, n=2)
Out[416]: True  # Because of first col

In [417]: vert_horz_adj(a, n=3)
Out[417]: False

In [418]: a[-1] = 10

In [419]: vert_horz_adj(a, n=3)
Out[419]: True  # Because of last row

关于python - 确定 numpy 数组的 2 个(垂直或水平)相邻元素是否具有相同值的最快方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47084045/

相关文章:

Java:数组星号打印值

python - python 和 opencv 中的快速组件标记

python - 如何使用 %debug 来调查 Python unittest 失败?

python - 无法确定 NumPy 数组的切片索引

python - 如何根据 Numpy 数组的内容替换其特定条目

python - 如何在 'partially' 安装 Python 包

python - 避免 python 3.5 中的溢出

python - 用相似的索引替换 Pandas DataFrame 中的值

Python 读行()

C矩阵函数分割错误