VGGplus.py 1.29 KB
Newer Older
Benjamin Thomas Graham's avatar
Benjamin Thomas Graham committed
1
2
3
4
5
6
7
# Copyright 2016-present, Facebook, Inc.
# All rights reserved.
#
# This source code is licensed under the license found in the
# LICENSE file in the root directory of this source tree.

import torch
Benjamin Thomas Graham's avatar
Benjamin Thomas Graham committed
8
9
import torch.nn as nn
import sparseconvnet as scn
Benjamin Thomas Graham's avatar
Benjamin Thomas Graham committed
10
11
12
from data import getIterators

# two-dimensional SparseConvNet
Benjamin Thomas Graham's avatar
Benjamin Thomas Graham committed
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
class Model(nn.Module):
    def __init__(self):
        nn.Module.__init__(self)
        self.sparseModel = scn.SparseVggNet(2, 3, [
            ['C', 8, ], ['C', 8], 'MP',
            ['C', 16], ['C', 16], 'MP',
            ['C', 16, 8], ['C', 16, 8], 'MP',
            ['C', 24, 8], ['C', 24, 8], 'MP']
            ).add(scn.Convolution(2, 32, 64, 5, 1, False)
            ).add(scn.BatchNormReLU(64)
            ).add(scn.SparseToDense(2,64))
        self.linear = nn.Linear(64, 183)
    def forward(self, x):
        x = self.sparseModel(x)
        x = x.view(-1,64)
        x = self.linear(x)
        return x
Benjamin Thomas Graham's avatar
Benjamin Thomas Graham committed
30

Benjamin Thomas Graham's avatar
Benjamin Thomas Graham committed
31
32
33
model=Model()
spatial_size = model.sparseModel.input_spatial_size(torch.LongTensor([1, 1]))
print('Input spatial size:', spatial_size)
Benjamin Thomas Graham's avatar
Benjamin Thomas Graham committed
34
35
36
dataset = getIterators(spatial_size, 63, 3)
scn.ClassificationTrainValidate(
    model, dataset,
Benjamin Thomas Graham's avatar
Benjamin Thomas Graham committed
37
38
39
40
41
42
    {'n_epochs': 100,
    'initial_lr': 0.1,
    'lr_decay': 0.05,
    'weight_decay': 1e-4,
    'use_gpu':  torch.cuda.is_available(),
    'check_point': True,})