工业党福利:使用PaddleX高效实现指针型表计读取(一)

 

飞桨开发者说】李康宇,PPDE飞桨开发者技术专家,工做于机械科学研究总院,视觉研发工程师html

最近在作一个工业巡检的项目,主要涉及的内容是指针型表计的读取。本系列文章主要介绍实现表计读取的全流程开发。其中主要使用的工具为飞桨全流程开发工具PaddleX和Visual Studio 2019。git

下载安装命令

## CPU版本安装命令
pip install -f https://paddlepaddle.org.cn/pip/oschina/cpu paddlepaddle

## GPU版本安装命令
pip install -f https://paddlepaddle.org.cn/pip/oschina/gpu paddlepaddle-gpu

工业质检和工业巡检是深度学习技术在工业领域应用比较普遍的两个场景,而其实现流程是相似的,能够由图1大体展现:github

图1 工业质检及巡检实现流程json

本系列文章的内容包含了上述流程的所有内容,主要内容以下:服务器

  • 高效语义分割:基于PaddleX图形化开发界面(Demo),零代码快速实现表计分割ide

  • 工业场景适配:Windows下PaddleX的C++编译并生成dll函数

  • 表计读取实战:基于C#的识别界面开发和dll文件调用工具

正文开始前再说一句,各位兄弟姐妹快去GitHub给PaddleX点star啊。点star,不白嫖!连接以下:性能

https://github.com/PaddlePaddle/PaddleX学习

 

高效语义分割:基于PaddleX零代码快速实现表计分割

 

PaddleX是什么?

PaddleX的官网上有其详细的介绍,我这里把它们摘录出来:

PaddleX是基于飞桨开发的一款全流程开发套件,以低代码、甚至零代码的形式支持开发者快速实现产业实际项目落地。

PaddleX中集成了飞桨智能视觉领域图像分类、目标检测、语义分割、实例分割任务能力,将深度学习开发全流程从数据准备、模型训练与优化到多端部署端到端打通,并提供统一任务API接口及图形化开发界面(Demo)。开发者无需分别安装不一样套件,以低代码的形式便可快速完成飞桨全流程开发。

PaddleX 通过质检、安防、巡检、遥感、零售、医疗等十多个行业实际应用场景验证,沉淀产业实际经验,并提供丰富的案例实践教程,全程助力开发者产业实践落地。

一句话归纳优点:极大下降开发成本、缩短开发周期、下降开发难度。

工业党们最在乎的效率和成本,PaddleX都解决了。PaddleX提供了两种开发模型:Python函数库开发模式和 PaddleX图形化开发模式。

(1)Python函数库模式:这种模式与咱们平时比较熟悉的深度学习开发模式差很少,不过PaddleX提供了众多简洁、全面、集成度较高的API,这使得咱们仅仅须要很是少许的的代码量,就能够实现图像分类、检测、分割等任务,并快速进行模型部署。

(2)“丧心病狂”的图形化开发模式:当我第一次看到PaddleX图形化开发界面的时候,我就知道,调参党的日子要很差过了,以及工业党的福利来了。之因此这么说,是由于使用PaddleX图形化开发界面,零代码就能够实现数据准备、模型训练、模型调优、模型部署全流程的开发。而且,这款工具居然是免费的。如图2所示,它将深度学习开发中的调参转化为点选式的选择,无需代码就能够便捷、高效地调整模型类型、backbone、模型参数和训练参数。相信通过作项目验证、作方案的工业党们都明白这意味着什么。从个人经验来看,使用PaddleX 图形化开发界面,可以改进低效流程,将项目验证的效率提高10倍以上,极大缩短开发周期。

若是你们但愿本身开发一个企业或者行业专用版本的图形化开发界面,PaddleX也是个很好的参照。

图2 PaddleX 图形化开发界面

 

如何使用PaddleX实现压力表的语义分割

 

废话很少说,下面将以压力表的语义分割为例,边介绍边实战。飞桨提供了官方使用教程文档,连接为:

https://paddlex.readthedocs.io/zh_CN/develop/gui/how_to_use.html

与命令行模式的深度学习开发相似,使用PaddleX图形化开发界面完成压力表的语义分割也须要按照如图3所示的流程进行。

图3 使用PaddleX 图形化开发界面实现语义分割流程示意图

(1)数据准备

如图4所示,在安装完PaddleX图形化开发界面以后,打开软件。首先选择数据集管理;而后点击新建数据集,建立语义分割数据集。

图4 建立数据集

点击建立数据集后,如图5所示,首先按照数据集导入规则,将原始图像和标注图像分别放在JPEGImages和Annotations文件夹中;而后选择数据集路径,确认导入。这里须要注意一下,labelme标注出的分割标注格式为json文件,须要首先转换为label.png文件(要注意本身的标注是一个标签仍是多标签)。正如图6中展现的那样,导入后,将数据集切分为训练集、验证集和测试集。通常按照默认比例便可。

图5 数据导入

图6 数据切分

( 2)建立项目

进行模型训练点击个人项目,新建语义分割项目后,进入到项目开发界面。

数据选择:如图7所示,选择数据准备中建立的压力表数据集。

图7 数据选择

参数配置:如图8所示,在参数配置中,你们能够根据本身的需求来配置。我所使用的模型为DeepLabv3+该模型在语义分割有更好的效果。backbone选择MobileNetV2_x0.5。迭代轮数为200,学习率0.005,batch size为1(为控制训练中的振荡幅度,学习率和batch size要相匹配的调整,减少batch size通常需等倍数减少学习率)。

图8 模型及训练参数配置

训练过程当中的模型可视化:如图9及图10所示,经过PaddleX界面查看看到当前的训练轮数,训练集损失值和验证集的各项参数。除此以外,PaddleX中集成了Visual DL,能够查看模型训练过程参数变化、日志详情,及当前最优的训练集和验证集训练指标。

图9 模型训练可视化

图10 VisualDL训练可视化

模型裁剪:训练结束后,可选择进入模型裁剪,也可直接进行模型评估。

(3)模型评估

参数评估:如图11所示,在模型评估页面,可查看训练后的模型效果。评估方法包括混淆矩阵、精度、召回率等。

图11 模型评估

分割测试:如图12所示,能够更加直观地进行测试集图片测试,或者单张图片测试,来评估模型的性能。并可将训练后的模型保存为预训练模型。

图12 模型测试

咱们来看一下使用PaddleX训练后,压力表分割的效果如图13所示:

图13 压力表分割效果

放大以后:

图14 压力表分割放大

本次训练仅使用了60多张压力表的图像数据,数据量比较小。可是能够看出,最终实现的分割效果仍是至关不错的。

(4)模型发布

在获得一个性能较好的模型后,咱们最终的目的是将模型部署至服务器端或者移动端。在作工业质检或巡检时,咱们通常都部署在服务器端。PaddleX的模型发布界面如图15所示:

图15 模型发布

发布的文件主要有两部分:推理代码和模型。如图16所示,模型保存在inference_model文件夹内,在使用时,咱们只须要加载该模型便可。

图16 推理代码和模型

发布的文件以下图所示:

图17模型文件

项目小结及下节预告

在本文中,我介绍了一款很是好用的深度学习开发工具PaddleX,特别以压力表分割为例,阐述了PaddleX 图形化开发界面的使用方法。这一部分的内容比较简单,欢迎你们下载亲自动手试一试。下载连接:

https://www.paddlepaddle.org.cn/paddlex/userinfo

下节预告:在工业应用中,生成一个性能不错的模型只是第一步。因为工业场景须要使用C#开发界面,所以须要将该模型转换成C#可调用的dll,下节将介绍如何将飞桨的C++预测代码生成为Visual Studio下的解决方案,以及最关键的,如何将C++预测代码生成为可调用的动态连接库dll,打通真正能够工业实战的开发流程。都看到这里了,还不点个赞,关注一下,谢谢你们!最后,再一次欢迎你们给这款好用的工具点个star!PaddleX Github连接:

https://github.com/PaddlePaddle/PaddleX

 

下载安装命令

## CPU版本安装命令
pip install -f https://paddlepaddle.org.cn/pip/oschina/cpu paddlepaddle

## GPU版本安装命令
pip install -f https://paddlepaddle.org.cn/pip/oschina/gpu paddlepaddle-gpu
相关文章
相关标签/搜索