forked from facebookresearch/SparseConvNet
-
Notifications
You must be signed in to change notification settings - Fork 0
/
VGGplus.py
48 lines (43 loc) · 1.46 KB
/
VGGplus.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
# 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
import torch.nn as nn
import sparseconvnet as scn
from data import get_iterators
# two-dimensional SparseConvNet
class Model(nn.Module):
def __init__(self):
nn.Module.__init__(self)
self.sparseModel = scn.Sequential(
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']),
scn.Convolution(2, 32, 64, 5, 1, False),
scn.BatchNormReLU(64),
scn.SparseToDense(2, 64))
self.spatial_size= self.sparseModel.input_spatial_size(torch.LongTensor([1, 1]))
self.inputLayer = scn.InputLayer(2,self.spatial_size,2)
self.linear = nn.Linear(64, 183)
def forward(self, x):
x = self.inputLayer(x)
x = self.sparseModel(x)
x = x.view(-1, 64)
x = self.linear(x)
return x
model = Model()
scale=63
dataset = get_iterators(model.spatial_size, scale)
print('Input spatial size:', model.spatial_size, 'Data scale:', scale)
scn.ClassificationTrainValidate(
model, dataset,
{'n_epochs': 100,
'initial_lr': 0.1,
'lr_decay': 0.05,
'weight_decay': 1e-4,
'use_cuda': torch.cuda.is_available(),
'check_point': False, })