tensorflow2.0+mnist已经算是ML界的“HELLO WORLD”了吧。网络上这方面的内容也比较多,可是有很多教程都是讲到训练完成就结束,如果只从数据上看准确率,对我们的主观感受不深。这里讲一下如何拿一张图片验证一下,以便直观感受。
- import tensorflow as tf
- import pandas as pd
- import matplotlib.pyplot as plt
- %matplotlib inline
- import image
- import numpy as np
-
- data = tf.keras.datasets.mnist
- (x_train,y_train),(x_test,y_test) = data.load_data()
- x_train,x_test = x_train/255.0,x_test/255.0
- #print(x_train.shape)
-
- #plt.imshow(y_train[0])
- #print(x_train[0])
- #y_test[0]
- model = tf.keras.models.Sequential()
- model.add(tf.keras.layers.Flatten(input_shape=(28,28)))
- model.add(tf.keras.layers.Dense(128, activation="relu"))
- model.add(tf.keras.layers.Dropout(0.2))
- model.add(tf.keras.layers.Dense(10))
- loss_fn = loss_fn = tf.keras.losses.SparseCategoricalCrossentropy(from_logits=True)
- model.compile(
- optimizer="adam",
- loss=loss_fn,
- metrics=['accuracy']
- )
- model.fit(x_train,y_train,epochs=5)
-
1、需要注意的是model.predict()输入参数应该是一个2维1列的矩阵。
2、这样做的好处是可以一次输入多个待验证数据,一并取得答案。
3、
而图片为28*28的矩阵,取其中一个:
img1_ = x_test[INDEX]
将矩阵展开成1维数组:
img1_ = img1_.flatten()
将1维数组展转换成2维1列的矩阵,-1代表由函数自动确认个数:
img1 = img1_.reshape(1,-1)
- #以下为训练,输入训练集的索引为3
- INDEX = 3
-
- img1_ = x_test[INDEX]
- img1_ = img1_.flatten()
- img1 = img1_.reshape(1,-1)
- #print(img1)
- ret = model.predict(img1)
- #显示预测值,其实对应的是0-9共10个数分别的概率,最大的为预测值
- print(ret)
- #显示真正值
- print(y_test[INDEX])
---------------------------------------------------------------分割线---------------------------------------------------------
model.save("./mnist_model/mnist01.h5")
#保存在了路径:./mnist_model/mnist01.h5 里。
model = tf.keras.models.load_model("./mnist_model/mnist01.h5")