【Surface Detection】Segmentation-Based Deep-Learning Approach for Surface-Defect Detection

物体表面缺陷检测现状
传统机器学习局限性
- 传统机器学习方法对于特定的算法只能解决特定的问题,不够灵活,无法快速适应新产品;
 - 不同的问题有不同的特征,当需要解决新问题时,需要重新设计特征,开发周期长;
 
深度学习遇到的问题
- 训练数据数量需求大;
 - 标注精度、耗时需求严格;
 - 计算能力需求高。
 
该篇paper解决了深度学习遇到的如上三个问题
Paper贡献
该篇paper提出了一个两阶段的网络,即分割网络 + 决策网络。
- 分割网络用于对输入的图片进行缺陷的具体定位,最后生成分割掩码(二值图像);
 - 决策网络用于判断输入的图片是否存在缺陷,生成二值分类输出。

 
实现细节

分割网络
分割网络要在高分辨率的图像表面上检查小的缺陷,需满足两个要求:
- 具有较大的感受野;
 - 能够捕捉到较小的特征细节;
 
因此,在设计时,需要具有下采样层,在比较深的层中使用尺寸大的卷积核。
决策网络
为什么要提出这样的决策网络?有什么作用?
简单的分割网络似乎没有足够的信息来预测图像中缺陷的存在。
- 决策网络能够从最后一个分割层的特征图中捕获信息;
 - 额外的下采样增加了感受野的大小,能够捕获缺陷的全局形状。全局形状对分类很重要,有助于提高性能。

 
网络训练过程

数据集
该篇paper中使用到的是工业界中电机转向器的拍摄样本集Kolektor


网络在不同配置下的评估
网络在四个配置组下进行评估:
五种精度的标注;

两种损失函数 (均方误差、交叉熵);
输入图像是全尺寸(1408 x 512 px)还是半尺寸(704 x 256 px);
是否对输入图像进行90°的旋转。
实验结果如下:

可见,paper提出的网络在如下:
1. 标注精度为Dilate = 5;
2. 交叉熵损失函数;
3. 全尺寸图像;
4. 不对图像进行90°旋转。
配置,达到了最优的性能。
性能评估
paper的作者把提出的网络与目前最常用的两个分割网络(DeepLab v3+与U-Net)和用于缺陷检测的商业软件Cognex ViDi Suite进行了性能对比。如下性能指标皆在三个网络和商业软件最优配置下进行评估:


结果如上图所示:
paper提出的网络AP最高,达到了99.9%,漏检个数与误检个数也最少。
所需训练样本个数

如上图所示,paper提出的网络,在仅有33个缺陷样本的训练下,AP能够达到99.9%;在仅有5个缺陷样本的训练下,AP依旧能够达到96.1%。超过了其它分割网络和商业软件在同等配置下的效果,一定程度上解决了深度学习所需样本数量大的问题。
所需训练时间


如上图所示:
paper提出的网络在对单张图片进行检测的平均准确度和时间上,都有着不错的效果,如何能做到这样的效果,也取决于上图,可以看到,paper提出的网络所需的参数,远少于另外两种分割网络,因此在训练以及检测的过程中,花费的时间得到了很大程度的提升。
【Surface Detection】Segmentation-Based Deep-Learning Approach for Surface-Defect Detection的更多相关文章
- 【论文笔记】DeepOrigin: End-to-End Deep Learning for Detection of New Malware Families
		
DeepOrigin: End-to-End Deep Learning for Detection of New Malware Families 标签(空格分隔): 论文 论文基本信息 会议: I ...
 - 论文笔记之:From Facial Parts Responses to Face Detection: A Deep Learning Approach
		
From Facial Parts Responses to Face Detection: A Deep Learning Approach ICCV 2015 从以上两张图就可以感受到本文所提方法 ...
 - 《3-D Deep Learning Approach for Remote Sensing Image Classification》论文笔记
		
论文题目<3-D Deep Learning Approach for Remote Sensing Image Classification> 论文作者:Amina Ben Hamida ...
 - Review of Semantic Segmentation with Deep Learning
		
In this post, I review the literature on semantic segmentation. Most research on semantic segmentati ...
 - 【论文阅读】HydraPlus-Net: Attentive Deep Features for Pedestrian Analysis
		
转载请注明出处:https://www.cnblogs.com/White-xzx/ 原文地址:https://arxiv.org/abs/1709.09930 Github: https://git ...
 - 【论文阅读】PBA-Population Based Augmentation:Efficient Learning of Augmentation Policy Schedules
		
参考 1. PBA_paper; 2. github; 3. Berkeley_blog; 4. pabbeel_berkeley_EECS_homepage; 完
 - 【论文阅读】End to End Learning for Self-Driving Cars
		
前言引用 [1] End to End Learning for Self-Driving Cars从这里开始 [1.1] 这个是相关的博客:2016:DRL前沿之:End to End Learni ...
 - 机器学习案例学习【每周一例】之 Titanic: Machine Learning from Disaster
		
下面一文章就总结几点关键: 1.要学会观察,尤其是输入数据的特征提取时,看各输入数据和输出的关系,用绘图看! 2.训练后,看测试数据和训练数据误差,确定是否过拟合还是欠拟合: 3.欠拟合的话,说明模 ...
 - 【流行前沿】联邦学习 Federated Learning with Only Positive Labels
		
核心问题:如果每个用户只有一类数据,如何进行联邦学习? Felix X. Yu, , Ankit Singh Rawat, Aditya Krishna Menon, and Sanjiv Kumar ...
 - 【Unity Shaders】Diffuse Shading——创建一个基本的Surface Shader
		
本系列主要参考<Unity Shaders and Effects Cookbook>一书(感谢原书作者),同时会加上一点个人理解或拓展. 这里是本书所有的插图.这里是本书所需的代码和资源 ...
 
随机推荐
- golang中的字符串
			
0.1.索引 https://waterflow.link/articles/1666449874974 1.字符串编码 在go中rune是一个unicode编码点. 我们都知道UTF-8将字符编码为 ...
 - JS中对DOM元素的操作
			
https://www.runoob.com/jquery/jquery-ref-html.html 1.each 遍历 //遍历所有class为checksingle的DOM元素 $(" ...
 - DQL-聚合函数
			
DQL-聚合函数 SQL基本函数,聚合函数对一组值执行计算,并返回单个值,也被称为组函数. 聚合函数对一组值执行计算并返回单一的值.除 COUNT 以外,聚合函数忽略空值,如果COUNT函数的应用对象 ...
 - GIT入门与Gitee的使用
			
一:Git是什么? Git是目前世界上最先进的分布式版本控制系统. 工作原理 / 流程: Workspace:工作区Index / Stage:暂存区Repository:仓库区(或本地仓库)Remo ...
 - Kafka 架构和原理机制 (图文全面详解)
			
目录 一:Kafka 简介 二:Kafka 基本架构 三:Kafka 基本原理 四:Zookeeper 在 kafka 的作用 五:Kafka 的特性 六:Kafka 的应用场景 一:Kafka 简介 ...
 - Oracle用户创建及删除
			
偶尔会用到,记录.分享. 1. Oracle用户创建 #创建用户表空间create tablespace $username datafile '/u01/app/oracle/oradata/ufg ...
 - ios手机键盘拉起之后页面不会回退的问题
			
在input输入框输入内容之后,点击完成,键盘下去了,可是页面没有回退回去,也就是页面会空出浏览器高度那一块,这个问题发现于ios手机中的微信浏览器.解决方案如下 <input type=&qu ...
 - 思维分析逻辑 1 DAY
			
数据分析原则:坚决不做提数机器. 数据分析工作模块 日报 了解业务现状 提升数据敏感性 数据波动解释 周报 了解数据的短期趋势 版本迭代分析 为结论型报告背书 月报 梳理业务的流程 为决策提供部分建议 ...
 - zephyr的GPIOTE驱动开发记录——基于nordic的NCS
			
简介: 本次测试了zephyr的中断驱动方式(GPIOTE),在这可以去看zephyr的官方文档对zephyr的中断定义,连接如下,Interrupts - Zephyr Project Docume ...
 - laravel的_token传值 ; header中传_token
			
laravel框架中只要是涉及到post传值都需要传 _token ,这是框架中为了防止crsf攻击所做的安全措施,那么我们用到ajax中的post 方式传值时,也需要在所传数据中添加一个_token ...