linux手写数字识别,mnist手写数字识别与图片预处理

这篇博客介绍了如何在Linux环境下对个人图片进行预处理,以便于用训练好的MNIST模型进行手写数字识别。通过读取图片、转换为灰度、调整尺寸、转换为1*784的张量并调整颜色,使图片符合模型输入要求。接着,使用TensorFlow加载模型并进行预测,展示了识别过程。
摘要由CSDN通过智能技术生成

用户mnist训练了一个模型,想用自己的图片进行测试,需要将自己的图片进行预处理为mnist需要的1*784的二维张量。

因为MNIST数据是28*28的黑底白字图像,而且输入时要将其拉直,也就是可以看成1*784的二维张量(张量的值在0~1之间),所以我们要对图片进行预处理操作,是图片能被网络识别。

引入的库import tensorflow as tf

import pylab

from PIL import Image

import numpy as np

以下为图片预处理过程img = Image.open('./mytestcode/666.jpg').convert('L') # 读取图片转成灰度格式

img = img.resize((28, 28)) # 更改图片大小  我的图片原始大小为:(366, 368)

npimg1 = np.array(img) # 转为numpy矩阵

flatten_img = npimg1.reshape(1, 784) # 转为mnist1*784二维张量

# 以下意思是把白色背景转为黑色背景,因为训练的都是黑色背景

new_flatten_img = (255-flatten_img)/255.0

new_flatten_img = new_flatten_img.reshape(1, 784) #      --------  该数据可直接被模型识别

print(new_flatten_img.shape)

以下为用训练好的模型识别过程tf.reset_default_graph()

# tf Graph Input

x = tf.placeholder(tf.fl

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值