当前位置:网站首页>TensorFlow2学习笔记:4、第一个神经网模型,鸢尾花分类

TensorFlow2学习笔记:4、第一个神经网模型,鸢尾花分类

2022-08-04 05:28:00 不负卿@

关于鸢尾花数据集导入,之前已经分享了,今天就来搭建第一个神经网模型。

第一步、导入模块

import tensorflow as tf  
import numpy as np
from sklearn import datasets        #用于加载数据
from matplotlib import pyplot as plt  #用于绘图

导入的都是深度学习基础模块。

第二步、加载数据和训练前数据处理

1、加载数据

x_data=datasets.load_iris().data    #特征集
y_data=datasets.load_iris().target  #标签集

2、数据乱序

#seed 随机种子,种子一样,每次随机一样
#对两类数据使用同一种子,确保特征数据和标签数据能够正确对应
np.random.seed(85)
np.random.shuffle(x_data) #类似于随机乱序洗牌 打乱数据
np.random.seed(85)
np.random.shuffle(y_data) #类似于随机乱序洗牌 打乱数据

#乱序后的数据 训练集为前120条数据 永不相见
x_train=x_data[:-30]
y_train=y_data[:-30]
#乱序后的数据 测试集为后30条数据 永不相见
x_test=x_data[-30:]
y_test=y_data[-30:]

#转换x数据(特征集)的数据类型,避免后面矩阵相乘,数据类型不一致报错
x_train=tf.cast(x_train,tf.float32)
x_test=tf.cast(x_test,tf.float32)

#特征与标签匹配 打包为batch(批次)大小32
train_db=tf.data.Dataset.from_tensor_slices((x_train,y_train)).batch(32)
test_db=tf.data.Dataset.from_tensor_slices((x_test,y_test)).batch(32)

第三步、 生成神经网络

#输入有4个特征,所以,第一个参数,输入层:4
#因为是3分类,输出节点等于分类数;所以,输出层神经元:3 tf.random.truncated_normal([4,3]
w1=tf.Variable(tf.random.truncated_normal([4,3],stddev=0.1,seed=1))
#偏置b1 应和输出节点数一直,所以:3
b1=tf.Variable(tf.random.truncated_normal([3],stddev=0.1,seed=1))

lr=0.1 #学习率
train_loss_results=[]  #loss列表
test_acc=[]  #acc列表
epoch=500 #循环500轮
loss_all=0  #每轮分4个step,loss_all记录4个step生成的loss总和

for epoch in range(epoch):#数据级别循环迭代,每次循环一次数据集
    # print(epoch)
    for step,(x_train,y_train) in enumerate(train_db):#batch包级循环迭代
        with tf.GradientTape() as tape: #记录梯度信息
            y=tf.matmul(x_train,w1)+b1
            y=tf.nn.softmax(y)
            y_=tf.one_hot(y_train,depth=3)
            loss=tf.reduce_mean(tf.square(y_-y))
            loss_all+=loss.numpy()
        grads=tape.gradient(loss,[w1,b1])
        w1.assign_sub(lr*grads[0])
        b1.assign_sub(lr*grads[1])
    print("Epoch: {},loss:{}".format(epoch,loss_all/4))
    train_loss_results.append(loss_all/4)
    loss_all=0

    total_correct,total_number=0,0
    for x_test,y_test in test_db:
        y=tf.matmul(x_test,w1)+b1
        y=tf.nn.softmax(y)
        pred=tf.argmax(y,axis=1)
        pred=tf.cast(pred,dtype=y_test.dtype)

        correct=tf.cast(tf.equal(pred,y_test),dtype=tf.int32)
        correct=tf.reduce_sum(correct)
        total_correct+=int(correct)
        total_number+=x_test.shape[0]
    acc=total_correct / total_number
    test_acc.append(acc)
    print("test acc:",acc)
    print("-----------------------------")

第四步、 打印曲线,便于观察

plt.title("loss")
plt.xlabel("epoch")
plt.ylabel("loss")
plt.plot(train_loss_results,label="$Loss$")
plt.legend()
plt.show()

plt.title("acc")
plt.xlabel("epoch")
plt.ylabel("acc")
plt.plot(test_acc,label="$Accuracy$")
plt.legend()
plt.show()

第五步、 训练结果

训练过程:
在这里插入图片描述
损失:
在这里插入图片描述
准确率:
在这里插入图片描述

完整代码:

import tensorflow as tf
import numpy as np
from sklearn import datasets
from matplotlib import pyplot as plt
x_data=datasets.load_iris().data 
y_data=datasets.load_iris().target 
np.random.seed(85)
np.random.shuffle(x_data) 
np.random.seed(85)
np.random.shuffle(y_data)
x_train=x_data[:-30]
y_train=y_data[:-30]
x_test=x_data[-30:]
y_test=y_data[-30:]
x_train=tf.cast(x_train,tf.float32)
x_test=tf.cast(x_test,tf.float32)
train_db=tf.data.Dataset.from_tensor_slices((x_train,y_train)).batch(32)
test_db=tf.data.Dataset.from_tensor_slices((x_test,y_test)).batch(32)
w1=tf.Variable(tf.random.truncated_normal([4,3],stddev=0.1,seed=1))
b1=tf.Variable(tf.random.truncated_normal([3],stddev=0.1,seed=1))

lr=0.1 #学习率
train_loss_results=[]  #loss列表
test_acc=[]  #acc列表
epoch=500 #循环500轮
loss_all=0  #每轮分4个step,loss_all记录4个step生成的loss总和

for epoch in range(epoch):#数据级别循环迭代,每次循环一次数据集
    # print(epoch)
    for step,(x_train,y_train) in enumerate(train_db):#batch包级循环迭代
        with tf.GradientTape() as tape: #记录梯度信息
            y=tf.matmul(x_train,w1)+b1
            y=tf.nn.softmax(y)
            y_=tf.one_hot(y_train,depth=3)
            loss=tf.reduce_mean(tf.square(y_-y))
            loss_all+=loss.numpy()
        grads=tape.gradient(loss,[w1,b1])
        w1.assign_sub(lr*grads[0])
        b1.assign_sub(lr*grads[1])
    print("Epoch: {},loss:{}".format(epoch,loss_all/4))
    train_loss_results.append(loss_all/4)
    loss_all=0

    total_correct,total_number=0,0
    for x_test,y_test in test_db:
        y=tf.matmul(x_test,w1)+b1
        y=tf.nn.softmax(y)
        pred=tf.argmax(y,axis=1)
        pred=tf.cast(pred,dtype=y_test.dtype)

        correct=tf.cast(tf.equal(pred,y_test),dtype=tf.int32)
        correct=tf.reduce_sum(correct)
        total_correct+=int(correct)
        total_number+=x_test.shape[0]
    acc=total_correct / total_number
    test_acc.append(acc)
    print("test acc:",acc)
    print("-----------------------------")
plt.title("loss")
plt.xlabel("epoch")
plt.ylabel("loss")
plt.plot(train_loss_results,label="$Loss$")
plt.legend()
plt.show()

plt.title("acc")
plt.xlabel("epoch")
plt.ylabel("acc")
plt.plot(test_acc,label="$Accuracy$")
plt.legend()
plt.show()
原网站

版权声明
本文为[不负卿@]所创,转载请带上原文链接,感谢
https://blog.csdn.net/m0_48300767/article/details/125922004