博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
大话目标检测经典模型:Mark R-CNN
阅读量:5839 次
发布时间:2019-06-18

本文共 1943 字,大约阅读时间需要 6 分钟。

hot3.png

135246_VdTi_876354.png

在之前的文章中介绍了,目标检测一般是为了实现以下效果:

135256_Z0DL_876354.png 
在R-CNN、Fast R-CNN、Faster R-CNN中,实现了对目标的识别和定位,如下图所示:
135302_LmjM_876354.png 
为了更加精确地识别目标,实现在像素级场景中识别不同目标,利用“图像分割”技术定位每个目标的精确像素,如下图所示(精确分割出人、汽车、红绿灯等):
135309_i37X_876354.png 
Mask R-CNN便是这种“图像分割”的重要模型。

Mask R-CNN的思路很简洁,既然Faster R-CNN目标检测的效果非常好,每个候选区域能输出种类标签和定位信息,那么就在Faster R-CNN的基础上再添加一个分支从而增加一个输出,即物体掩膜(object mask),也即由原来的两个任务(分类+回归)变为了三个任务(分类+回归+分割)。如下图所示,Mask R-CNN由两条分支组成:

135324_fo5L_876354.png 
Mask R-CNN的这两个分支是并行的,因此训练简单,仅比Faster R-CNN多了一点计算开销。
分类和定位在Faster R-CNN中有介绍过了(详见文章:),在此就不再重复介绍,下面重点介绍一下第二条分支,即如何实现像素级的图像分割。

如下图所示,Mask R-CNN在Faster R-CNN中添加了一个全卷积网络的分支(图中白色部分),用于输出二进制mask,以说明给定像素是否是目标的一部分。所谓二进制mask,就是当像素属于目标的所有位置上时标识为1,其它位置标识为 0

135331_IOGZ_876354.png 
从上图可以看出,二进制mask是基于特征图输出的,而原始图像经过一系列的卷积、池化之后,尺寸大小已发生了多次变化,如果直接使用特征图输出的二进制mask来分割图像,那肯定是不准的。这时就需要进行了修正,也即使用RoIAlign替换RoIPooling
135338_eB1d_876354.png 
如上图所示,原始图像尺寸大小是128x128,经过卷积网络之后的特征图变为尺寸大小变为 25x25。这时,如果想要圈出与原始图像中左上方15x15像素对应的区域,那么如何在特征图中选择相对应的像素呢?
从上面两张图可以看出,原始图像中的每个像素对应于特征图的25/128像素,因此,要从原始图像中选择15x15像素,则只需在特征图中选择2.93x2.93像素(15x25/128=2.93),在RoIAlign中会使用双线性插值法准确得到2.93像素的内容,这样就能很大程度上,避免了错位问题。
修改后的网络结构如下图所示(黑色部分为原来的Faster R-CNN,红色部分为Mask R-CNN修改的部分)
135344_OMA5_876354.png 
从上图可以看出损失函数变为
135350_ONwm_876354.png 
损失函数为分类误差+检测误差+分割误差,分类误差和检测(回归)误差是Faster R-CNN中的,分割误差为Mask R-CNN中新加的。
对于每个MxM大小的ROI区域,mask分支有KxMxM维的输出(K是指类别数量)。对于每一个像素,都是用sigmod函数求二值交叉熵,也即对每个像素都进行逻辑回归,得到平均的二值交叉熵误差Lmask。通过引入预测K个输出的机制,允许每个类都生成独立的mask,以避免类间竞争,这样就能解耦mask和种类预测。
对于每一个ROI区域,如果检测得到属于哪一个分类,就只使用该类的交叉熵误差进行计算,也即对于一个ROI区域中KxMxM的输出,真正有用的只是某个类别的MxM的输出。如下图所示:
135358_oAD1_876354.png 
例如目前有3个分类:猫、狗、人,检测得到当前ROI属于“人”这一类,那么所使用的Lmask为“人”这一分支的mask。

Mask R-CNN将这些二进制mask与来自Faster R-CNN的分类和边界框组合,便产生了惊人的图像精确分割,如下图所示:

135415_Ez1c_876354.png

Mask R-CNN是一个小巧、灵活的通用对象实例分割框架,它不仅可以对图像中的目标进行检测,还可以对每一个目标输出一个高质量的分割结果。另外,Mask R-CNN还易于泛化到其他任务,比如人物关键点检测,如下图所示:

135533_2rQ1_876354.png
从R-CNN、Fast R-CNN、Faster R-CNN到Mask R-CNN,每次进步不一定是跨越式的发展,这些进步实际上是直观的且渐进的改进之路,但是它们的总和却带来了非常显著的效果。
最后,总结一下目标检测算法模型的发展历程,如下图所示:

135513_UZ6v_876354.png

墙裂建议

2017年,Kaiming He 等人发表了关于Mask R-CNN的经典论文《Mask R-CNN》,在论文中详细介绍了Mask R-CNN的思想、原理和测试效果,建议阅读该论文以进一步了解该模型。

关注本人公众号“大数据与人工智能Lab”(BigdataAILab),然后回复“论文”关键字可在线阅读经典论文的内容

推荐相关阅读

转载于:https://my.oschina.net/u/876354/blog/1802743

你可能感兴趣的文章
mysql 开发进阶篇系列 35 工具篇 mysqldump(数据导出工具)
查看>>
Linux内核分析期中知识点总结
查看>>
对实体 "useSSL" 的引用必须以 ';' 分隔符结尾。
查看>>
创业之感悟三
查看>>
文献综述七:基于SSM的网上商城的开发与设计
查看>>
iOS UIImage DownLoad图片的下载缓存全部在此
查看>>
【模板】可持久化平衡树
查看>>
Windows程序设计笔记(6)
查看>>
移位与乘除法
查看>>
c语言 ctype.h中的函数
查看>>
UIImage 拉伸图片 resizableImageWithCapInsets
查看>>
canvas
查看>>
专家:端午将至湖北地区挂马网站激增 用户需警惕
查看>>
McAfee揭秘网络最危险搜索关键词
查看>>
基于comet服务器推送技术(web实时聊天)
查看>>
程序员达到高效率的一种境界
查看>>
PySide教程:一个简单的点击按钮示例
查看>>
艾伟_转载:对于C#中b=a的N种情况分析
查看>>
数论,数学
查看>>
《mysql必知必会》读书笔记--触发器及管理事务处理
查看>>