环境: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层了
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模型识别自己手写的数字方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
keras,识别,手写数字
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 《暗喻幻想》顺风耳作用介绍
- 崔健1985-梦中的倾诉[再版][WAV+CUE]
- 黄子馨《追星Xin的恋人们2》HQ头版限量编号[WAV+CUE]
- 孟庭苇《情人的眼泪》开盘母带[低速原抓WAV+CUE]
- 孙露《谁为我停留HQCD》[低速原抓WAV+CUE][1.1G]
- 孙悦《时光音乐会》纯银CD[低速原抓WAV+CUE][1.1G]
- 任然《渐晚》[FLAC/分轨][72.32MB]
- 英雄联盟新英雄安蓓萨上线了吗 新英雄安蓓萨技能介绍
- 魔兽世界奥杜尔竞速赛什么时候开启 奥杜尔竞速赛开启时间介绍
- 无畏契约CGRS准星代码多少 CGRS准星代码分享一览
- 张靓颖.2012-倾听【少城时代】【WAV+CUE】
- 游鸿明.1999-五月的雪【大宇国际】【WAV+CUE】
- 曹方.2005-遇见我【钛友文化】【WAV+CUE】
- Unity6引擎上线:稳定性提升、CPU性能最高提升4倍
- 人皇Sky今日举行婚礼!电竞传奇步入新篇章