本篇文章的主要目的是对上一篇文章已经搭建好的网络进一步丰富其内容,具体体现在6个方面:
1. 加载自己制作的训练集
2. 数据增强
3. 断点续训
4. 参数提取
5. acc/loss可视化
6. 给图识物
-
加载自己制作的训练集
代码:
import tensorflow as tf from PIL import Image import numpy as np import os #加载训练集的路径以及要保存的路径 train_path = './mnist_image_label/mnist_train_jpg_60000/' train_txt = './mnist_image_label/mnist_train_jpg_60000.txt' x_train_savepath = './mnist_image_label/mnist_x_train.npy' y_train_savepath = './mnist_image_label/mnist_y_train.npy' #加载测试集的路径以要保存的路径 test_path = './mnist_image_label/mnist_test_jpg_10000/' test_txt = './mnist_image_label/mnist_test_jpg_10000.txt' x_test_savepath = './mnist_image_label/mnist_x_test.npy' y_test_savepath = './mnist_image_label/mnist_y_test.npy' #-------------------------------------------------------------------------- #---------------------------------自制数据集------------------------------- #-------------------------------------------------------------------------- def generateds(path,txt): f = open(txt,'r') # 以只读形式打开文件 contents = f.readlines() # 读取文件中所有行 f.close() # 关闭txt文件 x,y_ = [],[] # 建立空列表 for content in contents: # 逐行取出 value = content.split() # 以空格分开,图片路径为value[0],标签为value[1],存入列表 img_path = path + value[0] # 拼出图片路径和文件名 img = Image.open(img_path) # 读入图片 img = np.array(img.convert('L')) # 图片变为8位宽灰度值的np.array格式 img = img / 255 # 数据归一化(实现预处理) x.append(img) #归一化后的数据,添加到列表x y_.append(value[1]) #标签添加到列表y print('loading:' + content) #打印状态提示 x = np.array(x) #变为np.array格式 y_ = np.array(y_) #变为np.array格式 y_ = y_.astype(np.int64) #变为64位整型 return x,y_ #返回输入特征x,返回标签y_ if os.path.exists(x_train_savepath) and os.path.exists(y_train_savepath) and os.path.exists(x_test_savepath) and os.path.exists(y_test_savepath): print('----------------Load Datasets---------------------') x_train_save = np.load(x_train_savepath) y_train = np.load(y_train_savepath) x_test_save = np.load(x_test_savepath) y_test = np.load(y_test_savepath) x_train = np.reshape(x_train_save,(len(x_train_save),28,28)) x_test = np.reshape(x_test_save,(len(x_test_save),28,28)) else: print('----------------Generate Datasets---------------------') x_train,y_train = generateds(train_path,train_txt) x_test,y_test = generateds(test_path,test_txt) print('----------------Save Datasets---------------------') x_train_save = np.reshape(x_train,(len(x_train), -1)) x_test_save = np.reshape(x_test,(len(x_test), -1)) np.save(x_train_savepath,x_train_save) np.save(y_train_savepath,y_train) np.save(x_test_savepath,x_test_save) np.save(y_test_savepath,y_test) model = tf.keras.models.Sequential([ tf.keras.layers.Flatten(), tf.keras.layers.Dense(128,activation = 'relu'), tf.keras.layers.Dense(10,activation = 'softmax') ]) model.compile(optimizer = 'adam', loss = tf.keras.losses.SparseCategoricalCrossentropy(from_logits = False), metrics = ['sparse_categorical_accuracy']) model.fit(x_train,y_train,batch_size = 32,epochs = 5,validation_data = (x_test,y_test),validation_freq=1) model.summary()
-
数据增强
函数介绍:Image_gen_train = tf.keras.preprocessing.image.ImageDataGenerator( Rescale = 所有数据将乘以该数值 Rotation_range = 随机旋转角度数范围 Width_shift_range = 随机宽度偏移量 Height_shift_range = 随机高度偏移量 水平翻转:horizontal_flip = 是否随机水平翻转 随机缩放:zoom_range = 随机缩放的范围[1-n,1+n] ) Image_gen_train.fit(x_train)
代码:
import tensorflow as tf from tensorflow.keras.preprocessing.image import ImageDataGenerator mnist = tf.keras.datasets.mnist (x_train,y_train),(x_test,y_test) = mnist.load_data() x_train,x_test = x_train / 255.0,x_test / 255.0 x_train = x_train.reshape(x_train.shape[0],28,28,1) #给数据增减一个维度,从(60000,28,28)reshape为(60000,28,28,1) image_gen_train = ImageDataGenerator( rescale = 1. / 1., rotation_range = 45, width_shift_range = .15, height_shift_range = .15, horizontal_flip = False, zoom_range = 0.5 ) image_gen_train.fit(x_train) model = tf.keras.models.Sequential([ tf.keras.layers.Flatten(), tf.keras.layers.Dense(128,activation = 'relu'), tf.keras.layers.Dense(10,activation = 'softmax') ]) model.compile(optimizer = 'adam', loss = tf.keras.losses.SparseCategoricalCrossentropy(from_logits = False), metrics = ['sparse_categorical_accuracy']) model.fit(image_gen_train.flow(x_train,y_train,batch_size = 32),epochs = 5,validation_data = (x_test,y_test),validation_freq=1) model.summary()
-
断点续训
a. 读取模型:函数:load_weights(路径文件名) 例子: checkpoint_save_path = "./checkpoint/mnist.ckpt" if os.path.exists(checkpoint_save_path + '.index'): print("--------------load the model---------------") model.load_weights(checkpoint_save_path)
b. 保存模型:
函数: tf.keras.callbacks.ModelCheckpoint( filepath = 路径文件名, save_weights_only = True/False, save_best_only = True/False ) history = mlodel.fit(callbacks = [cp_callback]) 例子: cp_callback = tf.keras.callbacks.ModelCheckpoint( filepath = checkpoint_save_path, save_weights_only = True, save_best_only = True) history = model.fit(x_train,y_train,batch_size=32,epochs=5,validation_data=(x_test,y_test),validation_freq=1,callbacks = [cp_callback])
代码:
import tensorflow as tf import os mnist = tf.keras.datasets.mnist (x_train,y_train),(x_test,y_test) = mnist.load_data() x_train,x_test = x_train / 255.0,x_test / 255.0 model = tf.keras.models.Sequential([ tf.keras.layers.Flatten(), tf.keras.layers.Dense(128,activation = 'relu'), tf.keras.layers.Dense(10,activation = 'softmax') ]) model.compile(optimizer = 'adam', loss = tf.keras.losses.SparseCategoricalCrossentropy(from_logits = False), metrics = ['sparse_categorical_accuracy']) checkpoint_save_path = "./checkpoint/mnist.ckpt" if os.path.exists(checkpoint_save_path + '.index'): print("--------------load the model---------------") model.load_weights(checkpoint_save_path) cp_callback = tf.keras.callbacks.ModelCheckpoint( filepath = checkpoint_save_path, save_weights_only = True, save_best_only = True) history = model.fit(x_train,y_train,batch_size=32,epochs=5,validation_data=(x_test,y_test),validation_freq=1,callbacks = [cp_callback]) model.summary()
-
参数提取
代码:import tensorflow as tf import os import numpy as np np.set_printoptions(threshold = np.inf) mnist = tf.keras.datasets.mnist (x_train,y_train),(x_test,y_test) = mnist.load_data() x_train,x_test = x_train / 255.0,x_test / 255.0 model = tf.keras.models.Sequential([ tf.keras.layers.Flatten(), tf.keras.layers.Dense(128,activation = 'relu'), tf.keras.layers.Dense(10,activation = 'softmax') ]) model.compile(optimizer = 'adam', loss = tf.keras.losses.SparseCategoricalCrossentropy(from_logits = False), metrics = ['sparse_categorical_accuracy']) checkpoint_save_path = "./checkpoint/mnist.ckpt" if os.path.exists(checkpoint_save_path + '.index'): print("--------------load the model---------------") model.load_weights(checkpoint_save_path) cp_callback = tf.keras.callbacks.ModelCheckpoint( filepath = checkpoint_save_path, save_weights_only = True, save_best_only = True) history = model.fit(x_train,y_train,batch_size=32,epochs=5,validation_data=(x_test,y_test),validation_freq=1,callbacks = [cp_callback]) model.summary() #打印参数 print(model.trainable_variables) #将参数保存到文件weights.txt中 file = open('./weights.txt','w') for v in model.trainable_variables: file.write(str(v.name) + '\n') file.write(str(v.shape) + '\n') file.write(str(v.numpy()) + '\n') file.close()
-
acc/loss可视化
history包含得出的结果:- 训练集loss:loss
- 测试集loss:val_loss
- 训练集准确率:sparse_categorical_accuracy
- 测试集准确率:val_sparse_cateforical_accuracy
代码:
import tensorflow as tf import os import numpy as np from matplotlib import pyplot as plt np.set_printoptions(threshold = np.inf) mnist = tf.keras.datasets.mnist (x_train,y_train),(x_test,y_test) = mnist.load_data() x_train,x_test = x_train / 255.0,x_test / 255.0 model = tf.keras.models.Sequential([ tf.keras.layers.Flatten(), tf.keras.layers.Dense(128,activation = 'relu'), tf.keras.layers.Dense(10,activation = 'softmax') ]) model.compile(optimizer = 'adam', loss = tf.keras.losses.SparseCategoricalCrossentropy(from_logits = False), metrics = ['sparse_categorical_accuracy']) checkpoint_save_path = "./checkpoint/mnist.ckpt" if os.path.exists(checkpoint_save_path + '.index'): print("--------------load the model---------------") model.load_weights(checkpoint_save_path) cp_callback = tf.keras.callbacks.ModelCheckpoint( filepath = checkpoint_save_path, save_weights_only = True, save_best_only = True) history = model.fit(x_train,y_train,batch_size=32,epochs=5,validation_data=(x_test,y_test),validation_freq=1,callbacks = [cp_callback]) model.summary() print(model.trainable_variables) file = open('./weights.txt','w') for v in model.trainable_variables: file.write(str(v.name) + '\n') file.write(str(v.shape) + '\n') file.write(str(v.numpy()) + '\n') file.close() acc = history.history['sparse_categorical_accuracy'] val_acc = history.history['val_sparse_categorical_accuracy'] loss = history.history['loss'] val_loss = history.history['val_loss'] plt.subplot(1,2,1) plt.plot(acc,label="Training Accuracy") plt.plot(val_acc,label="Validation Accuracy") plt.title("Training abd Validation Accuracy") plt.legend() plt.subplot(1,2,2) plt.plot(loss,label="Training Loss") plt.plot(val_loss,label="Validation Loss") plt.title("Training abd Validation Loss") plt.legend() plt.show()
-
给图识物(也就是前向传播的应用)
-
调用函数:predict(输入特征,batch_size=整数) 返回前向传播的计算结果
-
步骤:
a. 浮现模型 model = tf.keras.models.Sequential([ tf.keras.layers.Flatten(), tf.keras.layers.Dense(128, activation='relu'), tf.keras.layers.Dense(10, activation='softmax')]) b. 加载参数 model.load_weights(model_save_path) c. 预测结果 result = model.predict(x_predict)
代码:
from PIL import Image import numpy as np import tensorflow as tf model_save_path = './checkpoint/mnist.ckpt' model = tf.keras.models.Sequential([ tf.keras.layers.Flatten(), tf.keras.layers.Dense(128, activation='relu'), tf.keras.layers.Dense(10, activation='softmax')]) model.load_weights(model_save_path) preNum = int(input("input the number of test pictures:")) for i in range(preNum): image_path = input("the path of test picture:") img = Image.open(image_path) img = img.resize((28, 28), Image.ANTIALIAS) img_arr = np.array(img.convert('L')) for i in range(28): for j in range(28): if img_arr[i][j] < 200: img_arr[i][j] = 255 else: img_arr[i][j] = 0 img_arr = img_arr / 255.0 x_predict = img_arr[tf.newaxis, ...] result = model.predict(x_predict) pred = tf.argmax(result, axis=1) print('\n') tf.print(pred)
-
下面的是笔者的微信公众号,欢迎关注,会持续更新c++、python、tensorflow、机器学习、深度学习等系列文章