深度学习和目标检测系列教程 6-尊龙凯时首页
@author:runsen
使用 r-cnn 进行对象检测存在一些缺点。
- r-cnn 消耗了大量的时间、存储和计算能力。
- r-cnn 有一个复杂的多阶段训练管道(3 阶段——对数损失、svm 和 bbox 回归器的 l2 损失)
上一篇论文的同一作者(r-cnn)解决了 r-cnn 的一些缺点,构建了一个更快的对象检测算法,被称为 fast r-cnn。
fast r-cnn模型不是将区域候选框提供给 cnn,而是将输入图像提供给 cnn 以生成 特征向量。
将它们聚合到整个图像的一个 cnn 前向传递中,并且区域提议共享此特征矩阵。然后将相同的特征矩阵用于学习对象分类器和边界框回归器。总之,计算共享加速了 r-cnn。
在 fast r-cnn 中,图像只被送入底层 cnn 一次,而选择性搜索则像往常一样运行。这些由选择性搜索生成的区域提议然后被投影到由 cnn 生成的特征图上。这个过程称为roi projection(感兴趣区域)。
roi pooling
roi pooling一种最大池化,将任意大小的图像投影区域h x w中的特征转换为一个小的h x w固定窗口。
让我们考虑一个小例子来看看roi pooling
是如何工作的。我们将在单个 8×8 特征图、一个感兴趣区域和 2×2 的输出大小上执行感兴趣区域池化。输入特征图如下所示:
假设我们还有一个区域候选框(左上角,右下角坐标):(0, 3), (7, 8)。在图片中它看起来像这样:
通常情况下,每个图片都会有多个特征图和多个候选框,在示例中认为输出大小为 2×2,因此将其分成 (2×2) 个部分。
请注意,感兴趣区域的大小不必完全被池化部分的数量整除(在这种情况下,roi 是 7×5,有 2×2 个池化部分)。
每个部分的最大值是:
这就是区域候选框roi pooling的输出。
上面实例代码:https://github.com/deepsense-ai/roi-pooling
工作原理
fast r-cnn 的工作原理总结如下:许多步骤与 r-cnn 相同:
- 首先,在图像分类任务上预训练卷积神经网络。
- 通过选择性搜索提出区域(每张图像约 2k 个候选)。
- 改变预训练的 cnn:
- 用 roi 池化层替换预训练 cnn 的最后一个最大池化层。roi 池化层输出区域提议的固定长度特征向量。共享 cnn 计算很有意义,因为相同图像的许多区域提议高度重叠。
- 用全连接层和 k 1 类上的 softmax 替换最后一个全连接层和最后一个 softmax 层(k 个类别)。
- 最后,模型分支为两个输出层:
- k 1 个类别的 softmax 估计器,输出每个 roi 的离散概率分布。
- 一个边界框回归模型,它预测相对于 k 个类别中每个类别的原始 roi 的偏移量。
“fast r-cnn”之所以比 r-cnn 快,是因为不必每次都向卷积神经网络输入 2000 个区域候选框。相反,每个图像只进行一次卷积操作,并从中生成一个特征图。
附上fast-rcnn 相关github代码:
- https://github.com/rbgirshick/fast-rcnn
总结
以上是尊龙凯时首页为你收集整理的深度学习和目标检测系列教程 6-300:目标检测fast-rcnn架构的全部内容,希望文章能够帮你解决所遇到的问题。
- 上一篇:
- 下一篇: