pytorch尝试入门VGG,实现猫狗分类的baseline

照着教程【实战 VGG实现kaggle猫狗图片分类】完整流程 | 提供VGG11,VGG13,VGG16,VGG19 Pytorch 代码写了一下午。做一下学习笔记。

模型如下

关于报错

 第一反应去看评论区,没人提到这个问题,应该是我手残打错了。再看看报错信息,提示两个矩阵不能相乘。按照我浅薄的理解,因为模型的输入需要一个固定的大小,我们应该是在初始化MyDataset的时候就已经把输入图片的矩阵resize成(224, 224)的形状了。

前面这个32应该是我设置的batch_size没错。但是问题来了,224*224=50176,这和上面的四个数字都没有直接关系,正好是100352的一半。再看看后面这个数字,25088=512*7*7,512是最后一个卷积层的输出维度,这没有问题。

突然在注意到VGG 11的定义。

再一看我的网络,怎么只有13层,果然少了一个block,加上后正好输出的通道数再翻一番。这样就是100352了。

现在的模型是这样的:

为什么要用Xavier做初始化

为什么要resize成(224*224)?是怎么resize的?

为什么每经过一个block,通道数都要(会)翻倍?

5.7. 使用重复元素的网络(VGG) — 《动手学深度学习》 文档

Why VGG-16 takes input size 512 * 7 * 7?

neural network - Why VGG-16 takes input size 512 * 7 * 7? - Stack Overflow

为什么使用2个3x3卷积核可以来代替5*5卷积核?

feature map指的是什么?

理解卷积神经网络CNN中的特征图 feature map_dengheCSDN的博客-CSDN博客

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: PyTorch VGG16是一种深度学习模型,可用于分类任务。该模型使用卷积神经网络(CNN)进行训练,具有16个卷积层和3个全连接层。通过在大量的图像数据集上进行训练,该模型可以准确地识别的图像。在实际应用中,可以使用PyTorch VGG16模型来对新的图像进行分类,以便进行自动化的图像识别和分类。 ### 回答2: Pytorch是一种广泛应用的深度学习框架,而VGG16是经典卷积神经网络之一,被广泛应用于图像分类问题中。在本次实验中,我们使用Pytorch框架来实现分类问题。 我们首先需要下载并导入所需的库,比如torch、torchvision、matplotlib等。接下来,我们需要下载数据集。对于分类问题,我们可以使用Kaggle提供的一个数据集,其中包含25000张图片,5000张为验证集。在训练过程中,我们需要对数据进行预处理和增强,比如随机旋转、裁剪、填充、缩放等,以增加数据的多样性,并防止模型过拟合。 接下来,我们可以构建VGG16卷积神经网络,并对其进行微调。由于该网络已经在大规模的ImageNet数据集上进行了预训练,我们只需要在最后一层加上一个全连接层,并使用softmax激活函数来进行预测。我们可以使用Adam优化器来进行训练,并定义损失函数为交叉熵损失函数。 在训练过程中,我们需要设置一些参数,比如batch size、number of epochs等。我们还需要对模型进行评估,以评估其在验证集上的准确率和损失函数值。 最后,我们可以使用训练好的模型来对新的图片进行分类。首先,我们需要将图像进行与训练数据一样的预处理。然后,我们可以使用模型进行预测,并输出预测结果。 总的来说,使用PytorchVGG16实现分类问题是一项有趣而挑战性的任务。通过使用预处理技巧和卷积神经网络,我们可以有效地处理这个问题,并得到准确的预测结果。 ### 回答3: 在分类问题上,PyTorch中的VGG16模型被普遍应用于图像分类问题,它是一种卷积神经网络模型。这个模型基于ImageNet数据集进行训练,可以对各种物体进行分类,包括。在分类项目中,我们可以利用VGG16模型进行特征提取,并利用这些特征进行分类。以下是一个基本的步骤: 1. 数据集准备 在开始训练模型之前,需要先准备好数据集。可以使用训练集和验证集,每个集合分别包含标签为“”或“”的图像。每张图像的大小和像素数应该相同。 2. 加载数据集 将数据集加载到PyTorch Tensor中,这个步骤可以通过使用torchvision.transforms来进行图像预处理,例如图像缩放、标准化等,这样可以帮助训练更快收敛。 3. 加载VGG16模型 加载预训练的VGG16模型,并将其想要的分类层替换为预训练的VGG16模型的特定层。 4. 特征提取 将图像输入到模型中,获取使用了预训练的VGG16模型的特征映射。 5. 分类 将获取的特征映射传递到分类层中,这个分类层可以是任何全连接层。 6. 训练和验证 使用交叉熵作为损失函数,利用Mini-batch stochastic gradient descent作为优化器,开始训练模型。 7. 发布、测试和评估模型 在测试集上运行模型,并计算其准确度,同时在分类错误的图像中观察,并尝试找出哪些特征基本上错了(即容易混淆)。 总的来说,通过利用PyTorch VGG16模型进行分类,我们可以轻松地创建出一个非常精确的模型来区分。这个模型可以被应用于实际的应用场景,例如应用在宠物社交媒体应用程序上,或其他需要对进行分类的场景。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值