抖音资讯

douyinzx

crnn文字识别教程(识别文字秒杀脚本)

iseeyu2年前 (2024-05-04)抖音资讯121

在前一篇文章中(详见本博客文章:大话文本检测经典模型 CTPN),介绍了文字识别在现实生活中的广泛应用,以及文字识别的简单流程:

 

其中“文本检测”、“文本识别”是其中两个关键环节,“文本检测”已经在前一篇文章中介绍了详细的介绍,本文主要介绍“文本识别”的经典模型CRNN及其原理。

 

在介绍CRNN之前,先来梳理一下要实现“文本识别”的模型,需要具备哪些要素:

(1)首先是要读取输入的图像,提取图像特征,因此,需要有个卷积层用于读取图像和提取特征。具体原理可详见本公众号的文章:白话卷积神经网络(CNN);

(2)由于文本序列是不定长的,因此在模型中需要引入RNN(循环神经网络),一般是使用双向LSTM来处理不定长序列预测的问题。具体原理可详见本公众号的文章:白话循环神经网络(RNN);

(3)为了提升模型的适用性,最好不要要求对输入字符进行分割,直接可进行端到端的训练,这样可减少大量的分割标注工作,这时就要引入CTC模型(Connectionist temporal classification, 联接时间分类),来解决样本的分割对齐的问题。

(4)最后根据一定的规则,对模型输出结果进行纠正处理,输出正确结果。

以上就是“文本识别”模型的几个必须具备的要素。

接下来要介绍的CRNN模型,也是基本由这几部分组成的。

 

1、什么是CRNN

CRNN(Convolutional Recurrent Neural Network,卷积循环神经网络),是华中科技大学在发表的论文《An End-to-End Trainable Neural Network for Image-based Sequence Recognition and ItsApplication to Scene Text Recognition》提出的一个识别文本的方法,该模型主要用于解决基于图像的序列识别问题,特别是场景文字识别问题。

CRNN的主要特点是:

(1)可以进行端到端的训练;

(2)不需要对样本数据进行字符分割,可识别任意长度的文本序列

(3)模型速度快、性能好,并且模型很小(参数少)

 

2、CRNN模型结构

CRNN模型的结构如下:

 

正如前面梳理的“文本识别”模型必须具备的要素,CRNN模型主要由以下三部分组成:

(1)卷积层:从输入图像中提取出特征序列;

(2)循环层:预测从卷积层获取的特征序列的标签分布;

(3)转录层:把从循环层获取的标签分布通过去重、整合等操作转换成最终的识别结果。

 

下面将展开对这三个层进行介绍:

(1)卷积层

① 预处理

CRNN对输入图像先做了缩放处理,把所有输入图像缩放到相同高度,默认是32,宽度可任意长。

② 卷积运算

由标准的CNN模型中的卷积层和最大池化层组成,结构类似于VGG,如下图:

 

从上图可以看出,卷积层是由一系列的卷积、最大池化、批量归一化等操作组成。

③ 提取序列特征

提取的特征序列中的向量是在特征图上从左到右按照顺序生成的,用于作为循环层的输入,每个特征向量表示了图像上一定宽度上的特征,默认的宽度是1,也就是单个像素。由于CRNN已将输入图像缩放到同样高度了,因此只需按照一定的宽度提取特征即可。如下图所示:

 

(2)循环层

循环层由一个双向LSTM循环神经网络构成,预测特征序列中的每一个特征向量的标签分布。

由于LSTM需要有个时间维度,在本模型中把序列的 width 当作LSTM 的时间 time steps。

其中,“Map-to-Sequence”自定义网络层主要是做循环层误差反馈,与特征序列的转换,作为卷积层和循环层之间连接的桥梁,从而将误差从循环层反馈到卷积层。

 

(3)转录层

转录层是将LSTM网络预测的特征序列的结果进行整合,转换为最终输出的结果。

在CRNN模型中双向LSTM网络层的最后连接上一个CTC模型,从而做到了端对端的识别。所谓CTC模型(Connectionist Temporal Classification,联接时间分类),主要用于解决输入数据与给定标签的对齐问题,可用于执行端到端的训练,输出不定长的序列结果。

由于输入的自然场景的文字图像,由于字符间隔、图像变形等问题,导致同个文字有不同的表现形式,但实际上都是同一个词,如下图:

 

而引入CTC就是主要解决这个问题,通过CTC模型训练后,对结果中去掉间隔字符、去掉重复字符(如果同个字符连续出现,则表示只有1个字符,如果中间有间隔字符,则表示该字符出现多次),如下图所示:

 

 

以上就是文本识别模型CRNN的介绍,该模型既可用于识别英文、数字,也可用于识别中文。一般是跟CTPN结合一起使用,使用CTPN进行文字的检测,使用CRNN进行文字的识别。

本人使用CTPN+CRNN对中文识别出来的效果如下(隐去私密信息):

 

 

墙裂建议

2015年,Baoguang Shi 等人发表了关于CRNN的经典论文《 An End-to-End Trainable Neural Network for Image-based Sequence Recognition and Its Application to Scene Text Recognition 》,在论文中详细介绍了CRNN的思想和技术原理,建议阅读该论文以进一步了解该模型。

扫描二维码推送至手机访问。

版权声明:本文由西安泽虎代运营发布,如需转载请注明出处。

转载请注明出处https://www.0291.com.cn/post/45999.html

相关文章

创意质量低、负面内容营销审核规范 | 腾讯广告推广平台

创意质量低、负面内容营销审核规范 | 腾讯广告推广平台

素材审核 创意质量低-恶意引流 动态画面无实质内容,仅通过画面中的文字或口播引导用户点击公众号链接,如“点下方蓝字观看完整内容”、“点击链接领取外卖红包”、“点击上方公众号开始测试”等 物料投放示意 驳回原因示例 素材过审指引...

快手短视频推广平台适合快手广告投放的5类行业

快手短视频推广平台适合快手广告投放的5类行业

很多广告主在投放快手广告后,会开始自我怀疑,会思考自己的产品是否适合做快手广告投放? 这个问题可以在了解快手广告之前进行思考,但是我们找到快手广告代理商以后,这类问题就不应该被考虑,因为适不适合不是任何人说了算,而是快手广告数据说了算! 快手广告数据好看,那么广告有效,并且产品适合,如果...

360推广KA与中小客户开发原则-增加医疗行业客户开发原则20150319

360推广KA与中小客户开发原则-增加医疗行业客户开发原则20150319

各位, 就医疗行业客户,KA与中小渠道销售代理商的开发规则如下,各位了解并向内部通知清楚。 360推广医疗行业客户的开发原则 1)  药品及零售药店:360信息流广告除中小已开发的客户外(见附录四),其余客户的全产品线业务均由大客户开发; 2)  专科医院等医疗机构、...

品牌怎样通过快手综艺节目完成营销推广?

品牌怎样通过快手综艺节目完成营销推广?

神仙打架,谁更Nice?“毒舌女王”蔡明扎了哪位爱“装”人士的心?“脱口秀敲门人”杨笠和“带刺的玫瑰”何广智究竟谁“装”到了李诞?11月21日,由智联招聘总冠名的快手《超Nice大会》首期开播,蔡明、杨笠、何广智等艺人,携手快手达人田斌、浩南、李梦然,共同围绕“可恶被他装到了”主题展开激烈讨论。...

视频号直播带货+小程序店铺运营一体化

视频号直播带货+小程序店铺运营一体化

视频号直播带货+小程序店铺运营一体化...

快手营销费用需要多少?广东快手营销推广找谁?

快手营销费用需要多少?广东快手营销推广找谁?

快手是一个快速崛起的短视频平台,越来越多企业开始关注并利用这个平台进行营销推广。但是对于初次尝试快手营销的企业而言,很难明确快手营销费用需要多少,以及在缺乏经验的情况下该如何寻找广东快手营销推广公司。本篇文章将针对这两个问题进行分析。 快手营销费用需要多少? 快手营销费用的高低取决于投放的广告形...

现在,非常期待与您的又一次邂逅

我们努力让每一部企业宣传片和抖音短视频成为商业大片