image - 在 numpy 热图上获取 "hottest areas"的坐标

标签 image numpy image-processing computer-vision conv-neural-network

我有一个形状为 (600,400) 的热图 numpy 数组。热图表示检测概率。在我的例子中,图像中人脸检测的概率。我的目标是获取此热图并获得出现概率最高的坐标(X 和 Y)。

我已经解决了单张面孔的问题。其代码如下:

face_location = np.unravel_index(heatmap.argmax(), heatmap.shape)
    print("Face location: " + str(face_location))

但在某些情况下会有多个面孔。我不知道如何调整算法以返回多个“ HitTest 区域”。问题是任何一个热点区域都会被逐渐不那么热点的区域所包围。因此有可能在 HitTest 区域之后,接下来的前 10 个都在初始点附近。

如何调整算法以寻找多个热点区域?可以假设他们不会就在彼此身边。

heatmap = [[  2.00299415e-04   2.03753079e-04   8.17560707e-04 ...,   2.23556344e-04
         1.98958180e-04   9.92935777e-01]
      [  2.00642273e-04   2.04473894e-04   8.19963054e-04 ...,   2.24148811e-04
         1.99438742e-04   9.92921114e-01]
      [  2.01056406e-04   2.05344462e-04   8.22864589e-04 ...,   2.24864416e-04
         2.00019145e-04   9.92903233e-01]
      ..., 
      [  7.28193991e-05  -2.73474743e-05   2.95096161e-05 ...,   5.96550672e-05
         1.98282614e-05   9.99637246e-01]
      [  7.34055429e-05  -2.72389279e-05   3.02382941e-05 ...,   5.98490733e-05
         2.04356711e-05   9.99619305e-01]
      [  7.37556256e-05  -2.71740992e-05   3.06735128e-05 ...,   5.99649393e-05
         2.07984649e-05   9.99608397e-01]]

最佳答案

也许考虑使用 mask array用定义热点区域的阈值概率?

In [29]: threshold_probability = 0.8

In [30]: prng = np.random.RandomState(42)

In [31]: heatmap = prng.rand(600, 400)

In [32]: heatmap
Out[32]: 
array([[ 0.37454012,  0.95071431,  0.73199394, ...,  0.42899403,
         0.75087107,  0.75454287],
       [ 0.10312387,  0.90255291,  0.50525237, ...,  0.56513318,
         0.69665082,  0.92249938],
       [ 0.70723863,  0.15253904,  0.57628836, ...,  0.96887786,
         0.74965183,  0.13008624],
       ..., 
       [ 0.77669933,  0.98757844,  0.72686576, ...,  0.149866  ,
         0.6685433 ,  0.90248875],
       [ 0.116007  ,  0.96352904,  0.33109138, ...,  0.85776718,
         0.88838363,  0.00901272],
       [ 0.30810176,  0.43190563,  0.60935151, ...,  0.07498895,
         0.60716006,  0.31712892]])

In [33]: hottest_areas = np.ma.MaskedArray(heatmap, heatmap < threshold_probability)

In [34]: X, Y = hottest_areas.nonzero()

In [35]: X
Out[35]: array([  0,   0,   0, ..., 599, 599, 599])

In [36]: Y
Out[36]: array([  1,   7,  11, ..., 376, 388, 394])

结果是一个元组,其中包含定义掩码的 bool 条件为 False 的值的 x 和 y 坐标(即,面部概率高于阈值的区域)。

关于image - 在 numpy 热图上获取 "hottest areas"的坐标,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46749526/

相关文章:

javascript - jQuery:添加到 DOM 的新图像在加载后始终具有宽度 0

php - 使用 codeigniter 插入多个图像

python - Numpy 浮点舍入错误

php - 从图像或扫描文档中提取表格数据(非 pdf)

image - 如何根据我的预测获得 ROI 坐标?

php - htaccess RewriteRule 读取文档根目录之外的图像

image - 为什么docker上的相同Elasticsearch镜像的不同容器退出?

python - 如何将 Pandas 数据框转换为一维数组?

python - 'for' 循环中的 i = i + 1 和 i += 1 有什么区别?

image-processing - 在客户端裁剪和调整图像大小