使用python查找数组簇中的最小值

奥巴贾·维贾亚

我需要一些关于使用 python 编码的帮助。

这是问题所在。

假设我有一个包含浮点数的数组 (size = (50,50))。我想找到每个单元格簇的最小值(大小 = (10,10))。所以总的来说,我将有 25 个值。这就是我到目前为止所做的,也许还有另一种方法可以让程序运行得更快,因为我需要它来处理一个相当大的数组(比如 1 百万 x 1 毫米的单元格)。

import numpy as np
import random
def mini_cluster(z,y,x):
    a = []
    for i in range(y,y+10):
        for j in range(x,x+10):
            a.append(z[i,j])
    return min(a) 

z = np.zeros(shape=(50,50))

for i in range (len(z)):
    for j in range(len(z)):
        z[i,j] = random.uniform(10,12.5)

mini = []
for i in range(0,len(z),10):
    for j in range(0,len(z),10):
        mini.append(mini_cluster(z,i,j)) 
凯莱姆·内加西

我不确定它的速度,但使用 numpy 切片应该可以简化您的工作。您可以避免所有这些 for 循环。这是一些示例代码

import numpy as np
arr=[[1,2,3,8],[4,5,6,7],[8,9,10,11],[0,3,5,9]]
arr_np = np.array(arr)
print(arr_np)
cluster= arr_np[:3,:3]
print('\n')
print(cluster)
print('\n')
print(np.amin(cluster))

[[ 1  2  3  8]
 [ 4  5  6  7]
 [ 8  9 10 11]
 [ 0  3  5  9]]

[[ 1  2  3]
 [ 4  5  6]
 [ 8  9 10]]

1

您也可以查看本教程

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章