-
Notifications
You must be signed in to change notification settings - Fork 41
/
mobilenet_v2_test.py
126 lines (105 loc) · 4.52 KB
/
mobilenet_v2_test.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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
# Copyright 2018 The TensorFlow Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# ==============================================================================
"""Tests for mobilenet_v2."""
from __future__ import absolute_import
from __future__ import division
from __future__ import print_function
import tensorflow as tf
import numpy as np
from mobilenet_v2 import MobilenetV2
def find_ops(optype):
"""Find ops of a given type in graphdef or a graph.
Args:
optype: operation type (e.g. Conv2D)
Returns:
List of operations.
"""
gd = tf.get_default_graph()
return [var for var in gd.get_operations() if var.type == optype]
class MobilenetV2Test(tf.test.TestCase):
def setUp(self):
tf.reset_default_graph()
def testCreation(self):
model = MobilenetV2()
net, endpoints = model.forward(
tf.placeholder(tf.float32, (10, 224, 224, 16)))
# for t in net.graph.get_operations():
# print(t.name)
spec = model.model_def()
num_convs = len(find_ops('Conv2D'))
# This is mostly a sanity test. No deep reason for these particular
# constants.
#
# All but first 2 and last one have two convolutions, and there is one
# extra conv that is not in the spec. (logits)
self.assertEqual(num_convs, len(spec['spec']) * 2 - 3 + 1)
# Check that depthwise are exposed.
for i in range(2, 17):
self.assertIn('layer_%d/depthwise_output' % i, endpoints)
def testCreationNoClasses(self):
model = MobilenetV2()
net, endpoints = model.forward(
tf.placeholder(tf.float32, (10, 224, 224, 16)),
num_classes=None)
self.assertIs(net, endpoints['global_pool'])
def testImageSizes(self):
model = MobilenetV2()
for input_size, output_size in [(224, 7), (192, 6), (160, 5),
(128, 4), (96, 3)]:
tf.reset_default_graph()
net, endpoints = model.forward(
tf.placeholder(tf.float32, (10, input_size, input_size, 16)))
self.assertEqual(
endpoints['layer_18/output'].get_shape().as_list()[1:3],
[output_size] * 2)
def testWithOutputStride8(self):
model = MobilenetV2(output_stride=8)
net, _ = model.forward_base(
tf.placeholder(tf.float32, (10, 224, 224, 16)))
self.assertEqual(net.get_shape().as_list()[1:3], [28, 28])
def testDivisibleBy(self):
tf.reset_default_graph()
model = MobilenetV2(divisible_by=16, min_depth=32)
net, _ = model.forward(
tf.placeholder(tf.float32, (10, 224, 224, 16)))
s = [op.outputs[0].get_shape().as_list()[-1] for op in
find_ops('Conv2D')]
s = sorted(np.unique(s))
self.assertAllEqual([32, 64, 96, 160, 192, 320, 384, 576, 960, 1001,
1280], s)
def testDivisibleByWithMultiplier(self):
tf.reset_default_graph()
model = MobilenetV2(depth_multiplier=0.1, min_depth=32)
net, _ = model.forward(
tf.placeholder(tf.float32, (10, 224, 224, 16)))
s = [op.outputs[0].get_shape().as_list()[-1] for op in
find_ops('Conv2D')]
s = sorted(np.unique(s))
self.assertAllEqual(sorted([32, 192, 128, 1001]), s)
def testMobilenetBase(self):
tf.reset_default_graph()
# Verifies that mobilenet_base returns pre-pooling layer.
model = MobilenetV2(depth_multiplier=0.1, min_depth=32)
net, _ = model.forward_base(
tf.placeholder(tf.float32, (10, 224, 224, 16)))
self.assertEqual(net.get_shape().as_list(), [10, 7, 7, 128])
def testWithOutputStride16(self):
tf.reset_default_graph()
model = MobilenetV2(output_stride=16)
net, _ = model.forward_base(
tf.placeholder(tf.float32, (10, 224, 224, 16)))
self.assertEqual(net.get_shape().as_list()[1:3], [14, 14])
if __name__ == '__main__':
tf.test.main()