关于#神经网络#的问题:RuntimeError: mat1 and mat2 shapes cannot be multiplied (32x4096 and 3136x512);
在导入图片训练集的时候出现了问题,大致知道是如下代码设置有问题:
class CNN(nn.Module):
def __init__(self, num_classes=100):#100种汉字
super(CNN, self).__init__()
self.conv1 = nn.Conv2d(1, 32, kernel_size=3, stride=1, padding=1)#,输入图像通道数,卷积产生通道数,卷积核尺寸,卷积步长
self.bn1 = nn.BatchNorm2d(32)#归一化处理
self.relu1 = nn.ReLU()#激活函数
self.pool1 = nn.MaxPool2d(kernel_size=2, stride=2)#池化层参数
self.conv2 = nn.Conv2d(32, 64, kernel_size=1, stride=1, padding=1)#mat1
self.bn2 = nn.BatchNorm2d(64)
self.relu2 = nn.ReLU()
self.pool2 = nn.MaxPool2d(kernel_size=2, stride=2)
self.fc1 = nn.Linear(64 * 7 * 7, 512)#mat2
self.relu3 = nn.ReLU()
self.fc2 = nn.Linear(512, num_classes)
def forward(self, x):
x = self.conv1(x)
x = self.bn1(x)
x = self.relu1(x)
x = self.pool1(x)
x = self.conv2(x)
x = self.bn2(x)
x = self.relu2(x)
x = self.pool2(x)
x = x.view(x.size(0), -1)
x = self.fc1(x)
x = self.relu3(x)
x = self.fc2(x)
return x
# 定义训练和测试数据的转换
transform = transforms.Compose([
transforms.Grayscale(num_output_channels=1),
transforms.Resize((28, 28)),
transforms.ToTensor(),
transforms.Normalize((0.5,), (0.5,)),
])
'''
已经尝试过将dataloader中需要设置参数drop_last=True。即丢弃最后一个不足batchSize的样本,但是还是不行;
希望各位大佬帮我看看;