使用已经得到的keras模型识别自己手写的数字方式


Posted in Python onJune 29, 2020

环境:Python+keras,后端为Tensorflow

训练集:MNIST

对于如何训练一个识别手写数字的神经网络,网上资源十分丰富,并且能达到相当高的精度。但是很少有人涉及到如何将图片输入到网络中并让已经训练好的模型惊醒识别,下面来说说实现方法及注意事项。

首先import相关库,这里就不说了。

然后需要将训练好的模型导入,可通过该语句实现:

model = load_model('cnn_model_2.h5') (cnn_model_2.h5替换为你的模型名)

之后是导入图片,需要的格式为28*28。可用opencv导入:

img = cv2.imread('temp3.png', 0) (temp3.png替换为你手写的图片)

然后reshape一下以符合模型的输入要求:

img = (img.reshape(1,1,28,28)).astype("float32")/255

之后就可以用模型识别了:

predict = model.predict_classes(img)

最后print一下predict即可。

下面划重点:因为MNIST使用的是黑底白字的图片,所以你自己手写数字的时候一定要注意把得到的图片也改成黑底白字的,否则会识别错(至少我得到的结论是这样的 ,之前用白底黑字的图总是识别出错)

源码一览:

import cv2
import numpy as np
from keras.models import load_model
model = load_model('cnn_model_2.h5')

image = cv2.imread('temp3.png', 0)
img = cv2.imread('temp3.png', 0)

img = (img.reshape(1,1,28,28)).astype("float32")/255
predict = model.predict_classes(img)
print ('识别为:')
print (predict)

cv2.imshow("Image1", image)
cv2.waitKey(0)

效果图:

使用已经得到的keras模型识别自己手写的数字方式

补充知识:keras编写自定义的层

写在前面的话

keras已经有很多封装好的库供我们调用,但是有些时候我们需要的操作keras并没有,这时就需要学会自定义keras层了

1.Lambda

这个东西很方便,但是只能完成简单、无状态的自定义操作,而不能建立含有可训练权重的自定义层。

from keras.layers import Input,Lambda
from keras import Model
import tensorflow as tf

input=Input(shape=(224,224,3))
input.shape #Input第一个维度为batchsize维度
output=Lambda(lambda x: x[...,1])(input) #取最后一个维度的数据,...表示前面所有的维度
Model=Model(inputs=input,outputs=output)
Model.output

2.keras_custom

学习自keras中文文档

2.自定义keras层(带有可训练权重)
① build:定义权重,且self.build=True,可以通过迪奥哟经super([layer],self).build()完成
② call:功能逻辑实现
③ compute_output_shape:计算输出张量的shape

import keras.backend as K
from keras.engine.topology import Layer #这里的Layer是一个父类,下面的MyLayer将会继承Layer 

class MyLayer(Layer): #自定义一个keras层类
 def __init__(self,output_dim,**kwargs): #初始化方法
  self.output_dim=output_dim
  super(MyLayer,self).__init__(**kwargs) #必须要的初始化自定义层
 def build(self,input_shape): #为Mylayer建立一个可训练的权重
  #通过add_weight的形式来为Mylayer创建权重矩阵
  self.kernel=self.add_weight(name='kernel',
         shape=(input_shape[1],self.output_dim), #这里就是建立一个shape大小的权重矩阵
         initializer='uniform',
         trainable=True)
  super(MyLayer,self).build(input_shape) #一定要用,也可以用下面一行
  #self.build=True
 def call(self,x): #call函数里就是定义了对x张量的计算图,且x只是一个形式,所以不能被事先定义
  return K.dot(x,self.kernel) #矩阵乘法
 def compute_output_shape(self,input_shape):
  return (input_shape[0],self.output_dim) #这里是自己手动计算出来的output_shape
--------------------------------------------------------------------------------
class Mylayer(Layer):
 def __init__(self,output_dim,**kwargs):
  self.output_dim=output_dim
  super(MyLayer,self).__init__(**kwargs)
 def build(self,input_shape):
  assert isinstance(input_shape,list) #判断input_shape是否是list类型的
  self.kernel=self.add_weight(name='kernel',
         shape=(input_shape[0][1],self.output_dim), #input_shape应该长得像[(2,2),(3,3)]
         initializer='uniform',
         trainable=True)
  super(MyLayer,self).build(input_shape)
 def call(self,x):
  assert isinstance(x,list)
  a,b=x #从这里可以看出x应该是一个类似[(2,2),(3,3)]的list,a=(2,2),b=(3,3)
  return [K.dot(a,self.kernel)+b,K.mean(b,axis=-1)]

以上这篇使用已经得到的keras模型识别自己手写的数字方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
用smtplib和email封装python发送邮件模块类分享
Feb 17 Python
python中的代码编码格式转换问题
Jun 10 Python
Python读取一个目录下所有目录和文件的方法
Jul 15 Python
Python实现基于TCP UDP协议的IPv4 IPv6模式客户端和服务端功能示例
Mar 22 Python
python实现读取大文件并逐行写入另外一个文件
Apr 19 Python
使用memory_profiler监测python代码运行时内存消耗方法
Dec 03 Python
Python 2/3下处理cjk编码的zip文件的方法
Apr 26 Python
使用Python制作一个打字训练小工具
Oct 01 Python
通过字符串导入 Python 模块的方法详解
Oct 27 Python
Python列表list操作相关知识小结
Jan 29 Python
python数字类型math库原理解析
Mar 02 Python
Python基于jieba, wordcloud库生成中文词云
May 13 Python
Python接口测试环境搭建过程详解
Jun 29 #Python
python字典的值可以修改吗
Jun 29 #Python
python怎么自定义捕获错误
Jun 29 #Python
python打开文件的方式有哪些
Jun 29 #Python
解决tensorflow/keras时出现数组维度不匹配问题
Jun 29 #Python
python中如何写类
Jun 29 #Python
基于Python的自媒体小助手---登录页面的实现代码
Jun 29 #Python
You might like
discuz authcode 经典php加密解密函数解析
2020/07/12 PHP
php中截取中文字符串的代码小结
2011/07/17 PHP
php 修改、增加xml结点属性的实现代码
2013/10/22 PHP
PHP mail()函数使用及配置方法
2014/01/14 PHP
ThinkPHP实现动态包含文件的方法
2014/11/29 PHP
php采集中国代理服务器网的方法
2015/06/16 PHP
Apache启动报错No space left on device: AH00023该怎么解决
2015/10/16 PHP
js通过googleAIP翻译PHP系统的语言配置的实现代码
2011/10/17 Javascript
jquery文字上下滚动的实现方法
2013/03/22 Javascript
jquery定时滑出可最小化的底部提示层特效代码
2013/10/02 Javascript
Javascript实现简单的富文本编辑器附演示
2014/06/16 Javascript
js中的事件捕捉模型与冒泡模型实例分析
2015/01/10 Javascript
jquery中one()方法的用法实例
2015/01/16 Javascript
jQuery结合CSS制作漂亮的select下拉菜单
2015/05/03 Javascript
最精简的JavaScript实现鼠标拖动效果的方法
2015/05/11 Javascript
angular2使用简单介绍
2016/03/01 Javascript
全面解析Bootstrap中transition、affix的使用方法
2016/05/30 Javascript
jQuery+css实现非常漂亮的水平导航菜单效果
2016/07/27 Javascript
小程序实现分类页
2019/07/12 Javascript
vue-devtools的安装和使用步骤详解
2019/10/17 Javascript
详解element上传组件before-remove钩子问题解决
2020/04/08 Javascript
在树莓派2或树莓派B+上安装Python和OpenCV的教程
2015/03/30 Python
python opencv调用笔记本摄像头
2019/08/28 Python
Python csv文件的读写操作实例详解
2019/11/19 Python
tensorflow 实现自定义layer并添加到计算图中
2020/02/04 Python
python GUI库图形界面开发之PyQt5 MDI(多文档窗口)QMidArea详细使用方法与实例
2020/03/05 Python
做一个能自适应高度的textarea的示例代码
2019/09/06 HTML / CSS
美国诺德斯特龙百货官网:Nordstrom
2016/08/23 全球购物
阿迪达斯比利时官方商城:adidas比利时
2016/10/10 全球购物
Ootori在线按摩椅店:一家专业的按摩椅制造商
2019/04/10 全球购物
大学国际贸易专业自荐信
2014/06/05 职场文书
导游词范文
2015/02/13 职场文书
唱歌比赛拉拉队口号
2015/12/25 职场文书
56句经典英文座右铭
2019/08/09 职场文书
个人职业生涯规划之自我评估篇
2019/09/03 职场文书
导游词之西江千户苗寨
2019/12/24 职场文书