c++ 图片验证码识别_Tensorflow入门实战——验证码识别器

本文介绍了一个使用Tensorflow构建的纯数字验证码识别器的实战过程,包括数据采集、预处理、构建CNN框架、训练与测试。通过简化后的CNN模型,经过约2小时的训练,虽然精度只有40%,但对理解和熟悉tensorflow框架有所帮助。
摘要由CSDN通过智能技术生成

18f7046bdd147566dececedbce6a7646.png

从4月中旬开始深度学习之旅,到现在已经逐渐对神经网络有了一些初步的认识,选择tensorflow框架进行深度学习时,刚开始或许不太适应这种graph形式,但是tensorflow也在一定程度上帮助我们更好地理解神经网路的框架。

谨以此文来鼓励在劳动节还依然坚持学习的自己。


一、项目简介

1.目标:建立一个纯数字验证码识别器

2.原理:CNN

3.工具:Tensorflow

4.意义:熟悉tensorflow框架,推导前向传播过程,促进CNN的理解

二、数据采集—— ImageCaptcha

训练数据和测试数据均来自于 captcha.image库中的ImageCaptcha类。

ImageCaptcha可以根据输入的文本生成相应的验证码图片

由于时第一次处理图像数据,所以前期大部分功夫还是以图像预处理为主

首先写一个脚本,测试一下文本验证码和图片验证码的获取

import tensorflow as tf
import numpy as np  
import matplotlib.pyplot as plt  
from PIL import Image  
import random 
#载入数据集
from captcha.image import ImageCaptcha   

number = ['0','1','2','3','4','5','6','7','8','9']  
alphabet = ['a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z']  
ALPHABET = ['A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'] 

将以上数字和字母随机组合在一起,生成一个验证码,验证码的长度为4,总共有62*62*62*62种不同的label

#定义一个random_captcha_text函数,每调用一次就会生成一个验证码,其组成元素存放在一个列表中
def random_captcha_text(char_set=number+alphabet+ALPHABET, captcha_size=4):
    captcha_text = [] 
    for i in range(captcha_size):  #循环取四次
        x = random.choice(char_set)   #random.choice随机选区一个元素
        captcha_text.append(x)
    return captcha_text

#将构成验证码的元素与图片相对应,从captcha.image库中获得相应的图片
def get_captcha_text_and_image():
    #调用ImageCaptcha类,用来生成验证码图片
    image = ImageCaptcha()
    #用random_captcha_text()函数得到四个元素
    captcha_text = random_captcha_text()
    #将四个元素连接在一起,组成一个完整的验证码
    captcha_text = ''.join(captcha_text)
    
    #根据生成的文本验证码得到相应的图片验证码
    captcha = image.generate(captcha_text)
    #打开图片,PIL.Image.open()专接图片路径,用来直接读取该路径指向的图片
    captcha_image = Image.open(captcha)
    #将图片转化为array格式
    captcha_image = np.array(captcha_image)
    
    return captcha_text,captcha_image

最后测试一下数据是否正确

if __name__ == '__main__':   
    text, image = get_captcha_text_and_image()  
   
    f = plt.figure()  
    ax = f.add_subplot(111)  
    ax.text(0.1, 0.9,text, ha='center', va='center', transform=ax.transAxes)  
    plt.imshow(image)  
   
    plt.show()      

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: _pywrap_tensorflow_internal是TensorFlow的内部Python包,包含了TensorFlow的内部实现和底层代码。它主要用于TensorFlow的开发和调试,一般用户不需要直接使用该包。 ### 回答2: _pywrap_tensorflow_internal是一个C++封装了TensorFlow的功能的模块。TensorFlow是一个用于机学习和深度学习的开源框架,而_pywrap_tensorflow_internal模块是TensorFlow内部使用的一个C++模块,用于提供对TensorFlow核心功能的高级封装。 _pywrap_tensorflow_internal模块提供了一些包装类和函数,可以方便地在C++代码中调用TensorFlow的功能。这样,开发者可以使用C++语言来更高效地利用TensorFlow的各种功能,在底层实现更复杂的机学习模型和算法。 该模块包含了一些重要功能的封装,如张量操作、计算图的搭建和执行、模型的保存和加载等。这些功能可以方便地通过Python的API进行调用,但在底层实现时,使用了C++来提高执行效率。 在TensorFlow的源代码中,_pywrap_tensorflow_internal模块是由C++编写的,它提供了底层的功能实现,为TensorFlow提供了高性能和灵活性。通过对_pywrap_tensorflow_internal的使用,可以更好地理解TensorFlow的内部实现,并为开发者提供更多自定义机会。 总而言之,_pywrap_tensorflow_internal是一个C++封装了TensorFlow核心功能的模块,提供了高效且灵活的机学习和深度学习编程环境。它在TensorFlow中扮演着重要的角色,为开发者提供了更多底层的功能和自定义机会。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值