Tensorflow2.0:CNN、ResNet实现MNIST分类识别

以下仅是个人的学习笔记 ,内容可能是错误

CNN:

复制代码
import tensorflow as tf
from tensorflow import keras
from tensorflow.keras import layers

# 导入数据
(x_train, y_train), (x_test, y_test) = keras.datasets.mnist.load_data()

# 数据预处理
x_train = x_train.reshape(-1, 28, 28, 1) / 255.0
x_test = x_test.reshape(-1, 28, 28, 1) / 255.0

# 构建模型
model = keras.Sequential([
    layers.Conv2D(filters=32, kernel_size=(3, 3), activation='relu', input_shape=(28, 28, 1)),
    layers.MaxPooling2D(pool_size=(2, 2)),
    layers.Flatten(),
    layers.Dense(10, activation='softmax')
])

# 编译模型
model.compile(optimizer='adam',
              loss='sparse_categorical_crossentropy',
              metrics=['accuracy'])

# 训练模型
model.fit(x_train, y_train, epochs=5, validation_data=(x_test, y_test))

# 评估模型
test_loss, test_acc = model.evaluate(x_test, y_test)
print('Test accuracy:', test_acc)

ResNet18:

复制代码
import tensorflow as tf
from keras import layers, models, datasets
import os

# 定义gpu
os.environ['CUDA_VISIBLE_DEVICES'] = '0'  # 指定GPU编号
gpus = tf.config.experimental.list_physical_devices('GPU')
if gpus:
    try:
        tf.config.experimental.set_memory_growth(gpus[0], True)  # 动态申请显存
    except RuntimeError as e:
        print(e)

# 加载数据集
(train_images, train_labels), (test_images, test_labels) = datasets.cifar10.load_data()

# 数据预处理
train_images, test_images = train_images / 255.0, test_images / 255.0


# 搭建残差模块
def resnet_block(inputs, num_filters=16, kernel_size=3, strides=1, activation='relu'):
    x = layers.Conv2D(num_filters, kernel_size=kernel_size, strides=strides, padding='same')(inputs)
    x = layers.BatchNormalization()(x)
    if activation:
        x = layers.Activation(activation)(x)
    return x


# 定义resnet
def resnet18():
    inputs = layers.Input(shape=(32, 32, 3))
    num_filters = 64
    t = layers.BatchNormalization()(inputs)
    t = resnet_block(t, num_filters=num_filters)
    for i in range(2):
        t = resnet_block(t, num_filters=num_filters, activation=None)
        t = layers.Add()([t, layers.Activation('relu')(t)])
    t = resnet_block(t, num_filters=num_filters * 2, strides=2, activation=None)
    t = layers.Add()([t, resnet_block(t, num_filters=num_filters * 2)])
    num_filters *= 2
    for i in range(2):
        t = resnet_block(t, num_filters=num_filters, activation=None)
        t = layers.Add()([t, layers.Activation('relu')(t)])
    t = resnet_block(t, num_filters=num_filters * 2, strides=2, activation=None)
    t = layers.Add()([t, resnet_block(t, num_filters=num_filters * 2)])
    num_filters *= 2
    for i in range(2):
        t = resnet_block(t, num_filters=num_filters, activation=None)
        t = layers.Add()([t, layers.Activation('relu')(t)])
    t = layers.AveragePooling2D()(t)
    outputs = layers.Dense(10, activation='softmax')(layers.Flatten()(t))
    model = models.Model(inputs, outputs)
    return model


# 定义模型
model = resnet18()
model.compile(optimizer='adam',
              loss='sparse_categorical_crossentropy',
              metrics=['accuracy'])

# 训练 CPU
# history = model.fit(train_images, train_labels, epochs=10,
#                     validation_data=(test_images, test_labels))

with tf.device('GPU:0'):  # 指定使用GPU
    history = model.fit(train_images, train_labels, epochs=10,
                        validation_data=(test_images, test_labels))
相关推荐
vvoennvv4 小时前
【Python TensorFlow】 TCN-LSTM时间序列卷积长短期记忆神经网络时序预测算法(附代码)
python·神经网络·机器学习·tensorflow·lstm·tcn
斯外戈的小白18 小时前
【NLP】基础概念+RNN架构
rnn·自然语言处理·分类
巫婆理发22221 小时前
卷积神经网络(卷积+池化+全连接)
深度学习·计算机视觉·cnn
【建模先锋】21 小时前
基于多尺度卷积神经网络(MSCNN-1D)的轴承信号故障诊断模型
人工智能·神经网络·cnn·故障诊断·轴承故障诊断·西储大学轴承数据集
MicroTech20251 天前
MLGO微算法科技时空卷积与双重注意机制驱动的脑信号多任务分类算法
科技·算法·分类
大数据魔法师1 天前
分类与回归算法(四)- 最近邻分类
分类·k近邻算法
东皇太星1 天前
VGGNet (2014)(卷积神经网络)
人工智能·神经网络·cnn·卷积神经网络
qq_17082750 CNC注塑机数采1 天前
【Python TensorFlow】 CNN-GRU卷积神经网络-门控循环神经网络时序预测算法(附代码)
python·rnn·机器学习·cnn·gru·tensorflow
海边夕阳20062 天前
【每天一个AI小知识】:什么是卷积神经网络?
人工智能·经验分享·深度学习·神经网络·机器学习·cnn
vvoennvv2 天前
【Python TensorFlow】CNN-BiLSTM时序预测 卷积神经网络-双向长短期记忆神经网络组合模型(附代码)
python·神经网络·cnn·tensorflow·lstm·bilstm