论文《A Convolutional Neural Network Cascade for Face Detection》笔记

2024-05-11 22:08

本文主要是介绍论文《A Convolutional Neural Network Cascade for Face Detection》笔记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

论文:A Convolutional Neural Network Cascade for Face Detection.pdf

实现:https://github.com/anson0910/CNN_face_detection

该论文发表于2015年CVPR上,作者提出了一种级连的CNN网络结构用于人脸识别,论文的主要贡献有以下四点:

  • 提出了一种级连的CNN网络结构用于高速的人脸检测。
  • 设计了一种边界校订网络用于更好的定位人脸位置。
  • 提出了一种多分辨率的CNN网络结构,有着比单网络结构更强的识别能力,和一个微小的额外开销。
  • 在FDDB上达到了当时最高的分数。

其实论文的主体框架依然是基于V-J的瀑布流思想,不同以往的是级连了CNN网络(由于论文阅读量有限,不知是否已有前人做出了此类贡献),整个网络的处理流程如下图所示:


可以看出,整个处理流程里包含了六个网络和三次NMS,六个网络按顺序分别是12-net,12-calibration-net,24-net,24-calibration-net,48-net,48-calibration-net。

包含三个二分类网络用于分类其是否为人脸,另外三个calibration网络用于矫正人脸框边界。

其中12-net,24-net和48-net的网络结构如下图所示:


这三个网络的结构大致相同,不同之处在于其读入的图片分辨率和网络的复杂度,其是逐级递增的,了解V-J框架不难理解其实现原理,前面的简单网络拒绝绝大部分非人脸区域,将难以分辨的交由下一级更复杂的网络以获得更准确的结果,这里着重讲其多分辨率的图片读入方式。

要想在CNN结构下实现V-J瀑布级连结构,就要保证瀑布的前端足够简单并有较高的召回率且能够拒绝大部分非人脸区域,将图片缩放可以满足需求,比例为12/F,24/F,48/F,F为检测人脸的最小尺寸,这样对于一张800*600的图片,检测尺寸为40*40的人脸,窗口移动步伐为4个像素,那么会产生((800*12/40-12)/4+1)*((600*12/40-12)/4+1)=2494个窗口。不仅使得窗口数量变少而且窗口的缩放也使前期的CNN结构更加简单,实现了级连的思想。

另外在24-net和48-net的全连接层还会连接该图像缩放后在前一层网络的全连接输出,这么做的目的是为了检测更小的人脸,虽然会带来额外开销,但总体来说,该开销可忽略不计,但是其可以较明显的提高识别率。

12-calibration-net,24-calibration-net,48-calibration-net的结构如下图所示:


这三个网络用于矫正人脸检测框的边界,往往得分最高的边界框并非最佳结果,经过校准后其能更好的定位人脸,其矫正原理其实很简单,就是对原图做45次变换,然后每个变换后的边界框都有一个得分,对于得分高于某个设定的阈值时,将其累加进原边界,最后结果取平均,就是最佳边界框,关于45次变换,有如下得来:


xn,yn是其坐标移动比例,sn是其尺寸缩放比例

变换方式如下:


笔者说R-CNN并不适合于人脸检测,从论文中效果来看,不管是思想还是其实现,这种方法的确比R-CNN简便不少。

最后说说该论文对我的启发:

该论文最具开创性的两点:

一是其多分辨率的网络级连方法,这让我领略了V-J框架在CNN上效果优异的一次演绎。

在pico里图片一直保持着相同的尺寸,不同的是每一层树的数量不断增加,层数不断增多,从而保证复杂度的增高,其实也可以尝试这种多分辨率的策略,在前几层,读的图片可以分辨率低一些,这样,就可以少检测一些窗口,从而提升效率,但是不同于CNN,这么做也许会导致前面几层的召回率和准确率大大降低而得不偿失。

二是其边界校订网络,相比于R-CNN,该网络可称之为大巧不工的典范。

其实在pico中,也有类似边界校订网络这种离散式的加权平均校订方式,但是它只在最后一步做NMS时才做处理,那么如果将该方法加入每个层之后,或许可以在不影响其准确率的前提下显著减少下一层所需处理的样本,获得效率上的进一步提升。

这篇关于论文《A Convolutional Neural Network Cascade for Face Detection》笔记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/980786

相关文章

poj 2349 Arctic Network uva 10369(prim or kruscal最小生成树)

题目很麻烦,因为不熟悉最小生成树的算法调试了好久。 感觉网上的题目解释都没说得很清楚,不适合新手。自己写一个。 题意:给你点的坐标,然后两点间可以有两种方式来通信:第一种是卫星通信,第二种是无线电通信。 卫星通信:任何两个有卫星频道的点间都可以直接建立连接,与点间的距离无关; 无线电通信:两个点之间的距离不能超过D,无线电收发器的功率越大,D越大,越昂贵。 计算无线电收发器D

AI hospital 论文Idea

一、Benchmarking Large Language Models on Communicative Medical Coaching: A Dataset and a Novel System论文地址含代码 大多数现有模型和工具主要迎合以患者为中心的服务。这项工作深入探讨了LLMs在提高医疗专业人员的沟通能力。目标是构建一个模拟实践环境,人类医生(即医学学习者)可以在其中与患者代理进行医学

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

论文翻译:arxiv-2024 Benchmark Data Contamination of Large Language Models: A Survey

Benchmark Data Contamination of Large Language Models: A Survey https://arxiv.org/abs/2406.04244 大规模语言模型的基准数据污染:一项综述 文章目录 大规模语言模型的基准数据污染:一项综述摘要1 引言 摘要 大规模语言模型(LLMs),如GPT-4、Claude-3和Gemini的快

论文阅读笔记: Segment Anything

文章目录 Segment Anything摘要引言任务模型数据引擎数据集负责任的人工智能 Segment Anything Model图像编码器提示编码器mask解码器解决歧义损失和训练 Segment Anything 论文地址: https://arxiv.org/abs/2304.02643 代码地址:https://github.com/facebookresear

数学建模笔记—— 非线性规划

数学建模笔记—— 非线性规划 非线性规划1. 模型原理1.1 非线性规划的标准型1.2 非线性规划求解的Matlab函数 2. 典型例题3. matlab代码求解3.1 例1 一个简单示例3.2 例2 选址问题1. 第一问 线性规划2. 第二问 非线性规划 非线性规划 非线性规划是一种求解目标函数或约束条件中有一个或几个非线性函数的最优化问题的方法。运筹学的一个重要分支。2

【C++学习笔记 20】C++中的智能指针

智能指针的功能 在上一篇笔记提到了在栈和堆上创建变量的区别,使用new关键字创建变量时,需要搭配delete关键字销毁变量。而智能指针的作用就是调用new分配内存时,不必自己去调用delete,甚至不用调用new。 智能指针实际上就是对原始指针的包装。 unique_ptr 最简单的智能指针,是一种作用域指针,意思是当指针超出该作用域时,会自动调用delete。它名为unique的原因是这个

查看提交历史 —— Git 学习笔记 11

查看提交历史 查看提交历史 不带任何选项的git log-p选项--stat 选项--pretty=oneline选项--pretty=format选项git log常用选项列表参考资料 在提交了若干更新,又或者克隆了某个项目之后,你也许想回顾下提交历史。 完成这个任务最简单而又有效的 工具是 git log 命令。 接下来的例子会用一个用于演示的 simplegit

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓