tiny imagenet 训练_Dataloader读取图片集并训练网络

这篇博客介绍了如何利用Dataset构建数据集,再通过Dataloader进行读取,以进行tiny imagenet的训练。博主使用resnet34模型,并在训练过程中发现第二个step的loss值异常高。文章详细展示了从数据读取到网络训练的完整流程,包括数据预处理、网络构建、训练设置以及验证网络的步骤。在训练策略上,设置了适当的batch_size和检查点,以便监控和保存模型。
摘要由CSDN通过智能技术生成

使用Dataset制作好数据集之后,可以用Dataloader进行读取,然后用resnet34进行训练。

具体代码及注释如下

1 模块导入

其中data_read是利用Dataset制作数据集时写的文件

# 从data_read文件中读取函数

2 数据的读取

batch_size为每一次处理数据的数量,以60张图片为一组

# 读取数据
trainset = ImageFloder(root='D:/Anaconda3/data/tiny-imagenet-200', subdir='train', transform=train_transform)
traindataloader = DataLoader(trainset, batch_size=60, shuffle=True, num_workers=0)
valset = ImageFloder(root='D:/Anaconda3/data/tiny-imagenet-200', subdir='val', transform=test_transform)
valdataloader = DataLoader(valset, batch_size=60, num_workers=0)

3 网络构建

# 因为batch_size的存在,因此输入的x的size实际为([60,1,224,224])
# 网络开始搭建,自定义类均要继承 nn.Module 类
# 只需要定义 __init__ 和 forward 即可
# class_number表明最后分类的数量,200意味着一共有200个类型的图片,编号为0到199
class Net(nn.Module):
    def __init__(self, class_number=200):
        super(Net, self).__init__()
        self.net = resnet34(pretrained=True)
        # 修改 resnet34 的全连接层,定义第一次Linear的输出通道数
        self.cov2fc =
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值