import numpy as np
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).astype("float32") / 255.0
x_test = x_test.reshape(-1, 28, 28, 1).astype("float32") / 255.0
y_train = keras.utils.to_categorical(y_train, 10)
y_test = keras.utils.to_categorical(y_test, 10)
# 定义简单的 CNN 模型
def simple_cnn():
model = keras.Sequential([
layers.Conv2D(16, (3, 3), activation='relu', input_shape=(28, 28, 1)),
layers.MaxPooling2D((2, 2)),
layers.Flatten(),
layers.Dense(128, activation='relu'),
layers.Dense(10, activation='softmax')
])
return model
# 定义复杂的 CNN 模型
def complex_cnn():
model = keras.Sequential([
layers.Conv2D(32, (3, 3), activation='relu', input_shape=(28, 28, 1)),
layers.MaxPooling2D((2, 2)),
layers.Conv2D(64, (3, 3), activation='relu'),
layers.MaxPooling2D((2, 2)),
layers.Flatten(),
layers.Dense(256, activation='relu'),
layers.Dense(128, activation='relu'),
layers.Dense(10, activation='softmax')
])
return model
# 定义不同的优化器
optimizers = {
'SGD': keras.optimizers.SGD(learning_rate=0.01),
'Adam': keras.optimizers.Adam(learning_rate=0.001)
}
# 训练不同的模型和优化器组合
epochs = 5
batch_size = 64
for model_name, model_fn in [('Simple CNN', simple_cnn), ('Complex CNN', complex_cnn)]:
for optimizer_name, optimizer in optimizers.items():
model = model_fn()
model.compile(optimizer=optimizer, loss='categorical_crossentropy', metrics=['accuracy'])
print(f"Training {model_name} with {optimizer_name} optimizer:")
history = model.fit(x_train, y_train, epochs=epochs, batch_size=batch_size, validation_data=(x_test, y_test))
train_loss = history.history['loss']
train_acc = history.history['accuracy']
val_loss = history.history['val_loss']
val_acc = history.history['val_accuracy']
print(f"Training Loss: {train_loss}")
print(f"Training Accuracy: {train_acc}")
print(f"Validation Loss: {val_loss}")
print(f"Validation Accuracy: {val_acc}")
python打卡训练营Day41
珂宝_2025-06-02 9:02
相关推荐
有一个好名字1 分钟前
Claude Code 50+命令全解析liliangcsdn12 分钟前
LLM如何与mcp server交互示例Lupino13 分钟前
拯救迷失的荧光溶解氧传感器:从“三无”到“复活”的全记录xcjbqd028 分钟前
SQL中视图能否嵌套存储过程_实现复杂自动化报表逻辑ZC跨境爬虫29 分钟前
海南大学交友平台开发实战day7(实现核心匹配算法+解决JSON请求报错问题)迷藏49431 分钟前
**发散创新:基于角色与属性的混合权限模型在微服务架构中的实战落地**在现代分布式系统中,与虾牵手42 分钟前
OpenClaw 和 AiPy 怎么选?2026 功能实测对比 + 踩坑全记录Csvn43 分钟前
🌟 LangChain 30 天保姆级教程 · Day 16|文档加载器大合集!PDF、Word、网页、数据库一键读取,构建你的知识库!rebekk1 小时前
claude工作区与git仓库的关系Huyuejia1 小时前
rag+agent主程序