TensorFlow入门教程(25)车牌识别之文本检测模型EAST论文简介(一)

本文主要是介绍TensorFlow入门教程(25)车牌识别之文本检测模型EAST论文简介(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

#
#作者:韦访
#博客:https://blog.csdn.net/rookie_wei
#微信:1007895847
#添加微信的备注一下是CSDN的
#欢迎大家一起学习
#

1、概述

在OpenCV3入门教程(https://blog.csdn.net/rookie_wei/article/details/83094938)中,我大概讲了怎么使用OpenCV的方法来做车牌检测,这是我在大学时老师讲的方法。我在文末的时候说,如果有机会就用深度学习的方法试试,两年前吹的牛,最近有空就来实现它吧。大概思路就是先做文本检测,检测到车牌,然后再使用文本识别的算法,对车牌号进行识别。文本检测有非常多的算法,鉴于车牌有可能是倾斜的,而且车牌不会是弯曲的,也不会是垂直的,也不会特别长,所以使用EAST算法。文本识别则使用比较流行的DenseNet+CTC。这一系列可能需要好几篇博客才能讲完,先来简单刷一遍EAST的论文原理,然后再逐步实现EAST的代码。然后再简单说一下CRNN的论文,并实现代码。最后将它们结合起来完成车牌的检测和识别。先看一下最终的车牌识别效果图吧,

环境配置:

操作系统:Ubuntu 64位

显卡:GTX 1080ti

Python:Python3.7

TensorFlow:2.3.0

2、网络模型

EAST论文链接:https://arxiv.org/pdf/1704.03155.pdf

3、数据标签制作

以RBOX举例,上图就是RBOX数据标签的制作原理,

(a):黄色框表示数据集中标记的文本框,绿色框表示文本框缩放0.3倍以后的缩放文本框。

(b):表示文本框的score map,其中白色部分就是图(a)中的缩放文本框。在制作score map标签时,白色部分的像素值都为1,其余部分都设为0。这样我们通过模型预测到的score map就是文本框所在区域。但只有这些信息还不足以让我们知道确切的文本框的坐标,因为模型预测到的score map的形状并不像上图(b)中那样的规则四边形,而是如下图这样的结果,

如上图所示,左边的图片是原图,右边的图片是模型预测出的score map,白色区域就是模型预测的文本所在区域,可以看到模型预测出的score map的文本区域其实并不是规则的四边形,但是它大概能预测到文本所在的区域。正是由于只有score map还不足以预测出具体的文本框,所以就还需要geometry map进行辅助。

(c):粉红色的框表示文本框的最小外界矩形,而我们RBOX要求的就是这个最小外接矩形。

(d):该图是有4个通道的geometry map,称为AABB(axis-aligned bounding box),这4个通道geometry map的宽高跟score map的宽高是一样的。score map的每个像素点标记的是该点是否在缩放后的文本框内,而这4个geometry map的每个像素点(对应于score map标记为1的像素点)则分别标记该像素到其所在文本框的最小外接矩形的四条边的距离。

(e):该图也是geometry map,它标记的是每个像素点(对应于score map标记为1的像素点)所在的最小外接矩形(图(d)中粉红色的矩形)最下面的边相对水平轴的旋转角度。

结合我们这里说的制作的score map和geometry map标签,应该能理解我们模型的输出了吧?

4、损失函数

接着来看损失函数的定义,先来看score map,论文中score map的损失函数用的是交叉熵,

5、Locality-Aware NMS

通过模型得到预测的score map和geometry map以后,还需要进行NMS(非极大值抑制)得到最终的文本框。通过上面分析知道,每个score map值为1(当然,通过模型预测得到的score map,我们会筛选值大于某个阈值的点,比如0.8)的像素点都可以结合geometry map生成一个文本框,这会导致文本框的数量可能非常大,如果用传统的NMS算法,计算量会非常大,所以这里就使用Locality-Aware NMS。Locality-Aware NMS提出,如果相邻像素的几何结构具有很高的相似性(IoU超过某个阈值),则将它们进行基于得分的合并,这样不仅可以减少计算量,还可以将所有回归出的文本框的坐标信息都利用起来,提高准确度。

 

这样我们就简单的过了一下论文,有了理论依据,下一讲,我们就来实现具体代码。

 

 

 

这篇关于TensorFlow入门教程(25)车牌识别之文本检测模型EAST论文简介(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

Qt QCustomPlot库简介(最新推荐)

《QtQCustomPlot库简介(最新推荐)》QCustomPlot是一款基于Qt的高性能C++绘图库,专为二维数据可视化设计,它具有轻量级、实时处理百万级数据和多图层支持等特点,适用于科学计算、... 目录核心特性概览核心组件解析1.绘图核心 (QCustomPlot类)2.数据容器 (QCPDataC

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

C++ 检测文件大小和文件传输的方法示例详解

《C++检测文件大小和文件传输的方法示例详解》文章介绍了在C/C++中获取文件大小的三种方法,推荐使用stat()函数,并详细说明了如何设计一次性发送压缩包的结构体及传输流程,包含CRC校验和自动解... 目录检测文件的大小✅ 方法一:使用 stat() 函数(推荐)✅ 用法示例:✅ 方法二:使用 fsee

Python中图片与PDF识别文本(OCR)的全面指南

《Python中图片与PDF识别文本(OCR)的全面指南》在数据爆炸时代,80%的企业数据以非结构化形式存在,其中PDF和图像是最主要的载体,本文将深入探索Python中OCR技术如何将这些数字纸张转... 目录一、OCR技术核心原理二、python图像识别四大工具库1. Pytesseract - 经典O

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

苹果macOS 26 Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色

《苹果macOS26Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色》在整体系统设计方面,macOS26采用了全新的玻璃质感视觉风格,应用于Dock栏、应用图标以及桌面小部件等多个界面... 科技媒体 MACRumors 昨日(6 月 13 日)发布博文,报道称在 macOS 26 Tahoe 中

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取

Python基于微信OCR引擎实现高效图片文字识别

《Python基于微信OCR引擎实现高效图片文字识别》这篇文章主要为大家详细介绍了一款基于微信OCR引擎的图片文字识别桌面应用开发全过程,可以实现从图片拖拽识别到文字提取,感兴趣的小伙伴可以跟随小编一... 目录一、项目概述1.1 开发背景1.2 技术选型1.3 核心优势二、功能详解2.1 核心功能模块2.

Python验证码识别方式(使用pytesseract库)

《Python验证码识别方式(使用pytesseract库)》:本文主要介绍Python验证码识别方式(使用pytesseract库),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全... 目录1、安装Tesseract-OCR2、在python中使用3、本地图片识别4、结合playwrigh