test.py 2.9 KB
Newer Older
Hang Zhang's avatar
test  
Hang Zhang committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
##+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
## Created by: Hang Zhang
## ECE Department, Rutgers University
## Email: zhang.hang@rutgers.edu
## Copyright (c) 2017
##
## This source code is licensed under the MIT-style license found in the
## LICENSE file in the root directory of this source tree 
##+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

import encoding
import torch
import torch.nn.functional as F
from torch.autograd import Variable, gradcheck

Hang Zhang's avatar
v1.0.1  
Hang Zhang committed
16
17
18
19
import torchvision.models as models

EPS = 1e-6

Hang Zhang's avatar
Hang Zhang committed
20
def test_aggregate():
Hang Zhang's avatar
test  
Hang Zhang committed
21
22
23
24
25
26
27
28
    B,N,K,D = 2,3,4,5
    A = Variable(torch.cuda.DoubleTensor(B,N,K).uniform_(-0.5,0.5), 
        requires_grad=True)
    X = Variable(torch.cuda.DoubleTensor(B,N,D).uniform_(-0.5,0.5), 
        requires_grad=True)
    C = Variable(torch.cuda.DoubleTensor(K,D).uniform_(-0.5,0.5), 
        requires_grad=True)
    input = (A, X, C)
Hang Zhang's avatar
v1.0.1  
Hang Zhang committed
29
    test = gradcheck(encoding.functions.aggregate, input, eps=1e-6, atol=1e-4)
Hang Zhang's avatar
Hang Zhang committed
30
    print('Testing aggregate(): {}'.format(test))
Hang Zhang's avatar
test  
Hang Zhang committed
31
32


Hang Zhang's avatar
Hang Zhang committed
33
def test_scaledL2():
Hang Zhang's avatar
test  
Hang Zhang committed
34
35
36
37
38
39
40
41
    B,N,K,D = 2,3,4,5
    X = Variable(torch.cuda.DoubleTensor(B,N,D).uniform_(-0.5,0.5), 
        requires_grad=True)
    C = Variable(torch.cuda.DoubleTensor(K,D).uniform_(-0.5,0.5), 
        requires_grad=True)
    S = Variable(torch.cuda.DoubleTensor(K).uniform_(-0.5,0.5), 
        requires_grad=True)
    input = (X, C, S)
Hang Zhang's avatar
v1.0.1  
Hang Zhang committed
42
    test = gradcheck(encoding.functions.scaledL2, input, eps=1e-6, atol=1e-4)
Hang Zhang's avatar
Hang Zhang committed
43
    print('Testing scaledL2(): {}'.format(test))
Hang Zhang's avatar
test  
Hang Zhang committed
44
45
46
47
48
49
50


def test_encoding():
    B,C,H,W,K = 2,3,4,5,6
    X = Variable(torch.cuda.DoubleTensor(B,C,H,W).uniform_(-0.5,0.5), 
        requires_grad=True)
    input = (X,)
Hang Zhang's avatar
v1.0.1  
Hang Zhang committed
51
    layer = encoding.nn.Encoding(C,K).double().cuda()
Hang Zhang's avatar
test  
Hang Zhang committed
52
53
54
55
56
57
58
59
60
    test = gradcheck(layer, input, eps=1e-6, atol=1e-4)
    print('Testing encoding(): {}'.format(test))
    

def test_sum_square():
    B,C,H,W = 2,3,4,5
    X = Variable(torch.cuda.DoubleTensor(B,C,H,W).uniform_(-0.5,0.5), 
        requires_grad=True)
    input = (X,)
Hang Zhang's avatar
v1.0.1  
Hang Zhang committed
61
    test = gradcheck(encoding.functions.sum_square, input, eps=1e-6, atol=1e-4)
Hang Zhang's avatar
test  
Hang Zhang committed
62
63
64
    print('Testing sum_square(): {}'.format(test))


Hang Zhang's avatar
v1.0.1  
Hang Zhang committed
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
def test_dilated_densenet():
    net = encoding.dilated.densenet161(True).cuda().eval()
    print(net)
    net2 = models.densenet161(True).cuda().eval()

    x=Variable(torch.Tensor(1,3,224,224).uniform_(-0.5,0.5)).cuda()
    y = net.features(x)
    y2 = net2.features(x)

    print(y[0][0])
    print(y2[0][0])


def test_dilated_avgpool():
    X = Variable(torch.cuda.FloatTensor(1,3,75,75).uniform_(-0.5,0.5))
    input = (X,)
    layer = encoding.nn.DilatedAvgPool2d(kernel_size=2, stride=1, padding=0, dilation=2)
    test = gradcheck(layer, input, eps=1e-6, atol=1e-4)
    print('Testing dilatedavgpool2d(): {}'.format(test))


Hang Zhang's avatar
test  
Hang Zhang committed
86
if __name__ == '__main__':
Hang Zhang's avatar
Hang Zhang committed
87
    test_scaledL2()
Hang Zhang's avatar
test  
Hang Zhang committed
88
89
90
    test_encoding() 
    test_aggregate()
    test_sum_square()
Hang Zhang's avatar
v1.0.1  
Hang Zhang committed
91
92
93
94
    test_dilated_avgpool()
    """
    test_dilated_densenet()
    """