Selective Search

简介:

在目标检测时,为了定位到目标的具体位置,通常会把图像分成许多子块,然后把子块作为输入,送到目标识别的模型中。selective search就是一种选择子块的启发式方法。

主要思路:

输入一张图片,首先通过图像分割的方法获得很多小的区域,然后对这些小的区域不断进行合并,一直到无法合并为止。此时这些原始的小区域和合并得到的区域的就是我们得到的bounding box.
步骤:
算法分为如下几个大步:

**1:**首先预操作生成原始的区域集R(利用felzenszwalb算法)

2. 计算区域集R里每个相邻区域的相似度S={s1,s2,…} 

3. 找出相似度最高的两个区域,将其合并为新集,添加进R 

4. 从S中移除所有与第3步中有关的子集 

5. 计算新集与所有子集的相似度 

6.跳至第三步,不断循环,合并,直至S为空(到不能再合并时为止)

源码:
import skimage.data
import selectivesearch

img = skimage.data.astronaut()
img_lbl, regions = selectivesearch.selective_search(img, scale=500, sigma=0.9, min_size=10)
regions[:10]
=>
[{‘labels’: [0.0], ‘rect’: (0, 0, 15, 24), ‘size’: 260},
{‘labels’: [1.0], ‘rect’: (13, 0, 1, 12), ‘size’: 23},
{‘labels’: [2.0], ‘rect’: (0, 15, 15, 11), ‘size’: 30},
{‘labels’: [3.0], ‘rect’: (15, 14, 0, 0), ‘size’: 1},
{‘labels’: [4.0], ‘rect’: (0, 0, 61, 153), ‘size’: 4927},
{‘labels’: [5.0], ‘rect’: (0, 12, 61, 142), ‘size’: 177},
{‘labels’: [6.0], ‘rect’: (7, 54, 6, 17), ‘size’: 8},
{‘labels’: [7.0], ‘rect’: (28, 50, 18, 32), ‘size’: 22},
{‘labels’: [8.0], ‘rect’: (2, 99, 7, 24), ‘size’: 24},
{‘labels’: [9.0], ‘rect’: (14, 118, 79, 117), ‘size’: 4008}]

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

同学yes

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值