美文网首页Python小哥哥
Python图片验证码降噪 — 8邻域降噪

Python图片验证码降噪 — 8邻域降噪

作者: 我爱学python | 来源:发表于2019-04-16 16:09 被阅读2次

简介

图片验证码识别的可以分为几个步骤,一般用 Pillow 库或 OpenCV 来实现,这几个过程是:

1.灰度处理&二值化

2.降噪

3.字符分割

4.标准化

5.识别

所谓降噪就是把不需要的信息通通去除,比如背景,干扰线,干扰像素等等,只留下需要识别的字符,让图片变成2进制点阵,方便代入模型训练。

8邻域降噪

8邻域降噪 的前提是将图片灰度化,即将彩色图像转化为灰度图像。以RGN色彩空间为例,彩色图像中每个像素的颜色由R 、G、B三个分量决定,每个分量由0到255种取值,这个一个像素点可以有一千多万种颜色变化。而灰度则是将三个分量转化成一个,使每个像素点只有0-255种取值,这样可以使后续的图像计算量变得少一些。

以上面的灰度图片为例,图片越接近白色的点像素越接近255,越接近黑色的点像素越接近0,而且验证码字符肯定是非白色的。对于其中噪点大部分都是孤立的小点的,而且字符都是串联在一起的。8邻域降噪 的原理就是依次遍历图中所有非白色的点,计算其周围8个点中属于非白色点的个数,如果数量小于一个固定值,那么这个点就是噪点。对于不同类型的验证码这个阈值是不同的,所以可以在程序中配置,不断尝试找到最佳的阈值。

经过测试8邻域降噪 对于小的噪点的去除是很有效的,而且计算量不大,下图是阈值设置为4去噪后的结果:

Pillow实现

下面是使用 Pillow 模块的实现代码:

OpenCV实现

使用OpenCV可以提高计算效率:

相关文章

网友评论

    本文标题:Python图片验证码降噪 — 8邻域降噪

    本文链接:https://www.haomeiwen.com/subject/wqwbwqtx.html