PyTorch实现简单的卷积神经网络
class SimpleCNN(nn.Module):
def __init__(self):
super(SimpleCNN, self).__init__()
layer1 = nn.Sequential()
layer1.add_module('conv1', nn.Conv2d(3,32,3,1,padding=1))
layer1.add_module('relu1', nn.ReLu(True))
layer1.add_module('pool1', nn.MaxPool2d(2,2))
self.layer1 = layer1
layer2 = nn.Sequential()
layer2.add_module('conv2', nn.Conv2d(32,64,3,1,padding=1))
layer2.add_module('relu2', nn.ReLu(True))
layer2.add_module('pool2', nn.MaxPool2d(2,2))
self.layer2 = layer2
layer3 = nn.Sequential()
layer3.add_module('conv3', nn.Conv2d(64,128,3,1,padding=1))
layer3.add_module('relu3', nn.ReLu(True))
layer3.add_module('pool3', nn.MaxPool2d(2,2))
self.layer3 = layer3
layer4 = nn.Sequential()
layer4.add_module('fc1', nn.Linear(2048,512))
layer4.add_module('fc_relu1', nn.ReLu(True))
layer4.add_module('fc2', nn.Linear(512,64))
layer4.add_module('fc_relu2', nn.ReLu(True))
layer4.add_module('fc3', nn.Linear(64,10))
self.layer4 = layer4
def forward(self, x):
conv1 = self.layer1(x)
conv2 = self.layer2(conv1)
conv3 = self.layer2(conv2)
fc_input = conv3.view(x.size(0), -1)
fc_out = self.layer4(fc_input)
return fc_out
model = SimpleCNN()