| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393 |
- # Copyright 2016 Google Inc. 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 slim.variables."""
- from __future__ import absolute_import
- from __future__ import division
- from __future__ import print_function
- import tensorflow as tf
- from inception.slim import scopes
- from inception.slim import variables
- class VariablesTest(tf.test.TestCase):
- def testCreateVariable(self):
- with self.test_session():
- with tf.variable_scope('A'):
- a = variables.variable('a', [5])
- self.assertEquals(a.op.name, 'A/a')
- self.assertListEqual(a.get_shape().as_list(), [5])
- def testGetVariables(self):
- with self.test_session():
- with tf.variable_scope('A'):
- a = variables.variable('a', [5])
- with tf.variable_scope('B'):
- b = variables.variable('a', [5])
- self.assertEquals([a, b], variables.get_variables())
- self.assertEquals([a], variables.get_variables('A'))
- self.assertEquals([b], variables.get_variables('B'))
- def testGetVariablesSuffix(self):
- with self.test_session():
- with tf.variable_scope('A'):
- a = variables.variable('a', [5])
- with tf.variable_scope('A'):
- b = variables.variable('b', [5])
- self.assertEquals([a], variables.get_variables(suffix='a'))
- self.assertEquals([b], variables.get_variables(suffix='b'))
- def testGetVariableWithSingleVar(self):
- with self.test_session():
- with tf.variable_scope('parent'):
- a = variables.variable('child', [5])
- self.assertEquals(a, variables.get_unique_variable('parent/child'))
- def testGetVariableWithDistractors(self):
- with self.test_session():
- with tf.variable_scope('parent'):
- a = variables.variable('child', [5])
- with tf.variable_scope('child'):
- variables.variable('grandchild1', [7])
- variables.variable('grandchild2', [9])
- self.assertEquals(a, variables.get_unique_variable('parent/child'))
- def testGetVariableThrowsExceptionWithNoMatch(self):
- var_name = 'cant_find_me'
- with self.test_session():
- with self.assertRaises(ValueError):
- variables.get_unique_variable(var_name)
- def testGetThrowsExceptionWithChildrenButNoMatch(self):
- var_name = 'parent/child'
- with self.test_session():
- with tf.variable_scope(var_name):
- variables.variable('grandchild1', [7])
- variables.variable('grandchild2', [9])
- with self.assertRaises(ValueError):
- variables.get_unique_variable(var_name)
- def testGetVariablesToRestore(self):
- with self.test_session():
- with tf.variable_scope('A'):
- a = variables.variable('a', [5])
- with tf.variable_scope('B'):
- b = variables.variable('a', [5])
- self.assertEquals([a, b], variables.get_variables_to_restore())
- def testNoneGetVariablesToRestore(self):
- with self.test_session():
- with tf.variable_scope('A'):
- a = variables.variable('a', [5], restore=False)
- with tf.variable_scope('B'):
- b = variables.variable('a', [5], restore=False)
- self.assertEquals([], variables.get_variables_to_restore())
- self.assertEquals([a, b], variables.get_variables())
- def testGetMixedVariablesToRestore(self):
- with self.test_session():
- with tf.variable_scope('A'):
- a = variables.variable('a', [5])
- b = variables.variable('b', [5], restore=False)
- with tf.variable_scope('B'):
- c = variables.variable('c', [5])
- d = variables.variable('d', [5], restore=False)
- self.assertEquals([a, b, c, d], variables.get_variables())
- self.assertEquals([a, c], variables.get_variables_to_restore())
- def testReuseVariable(self):
- with self.test_session():
- with tf.variable_scope('A'):
- a = variables.variable('a', [])
- with tf.variable_scope('A', reuse=True):
- b = variables.variable('a', [])
- self.assertEquals(a, b)
- self.assertListEqual([a], variables.get_variables())
- def testVariableWithDevice(self):
- with self.test_session():
- with tf.variable_scope('A'):
- a = variables.variable('a', [], device='cpu:0')
- b = variables.variable('b', [], device='cpu:1')
- self.assertDeviceEqual(a.device, 'cpu:0')
- self.assertDeviceEqual(b.device, 'cpu:1')
- def testVariableWithDeviceFromScope(self):
- with self.test_session():
- with tf.device('/cpu:0'):
- a = variables.variable('a', [])
- b = variables.variable('b', [], device='cpu:1')
- self.assertDeviceEqual(a.device, 'cpu:0')
- self.assertDeviceEqual(b.device, 'cpu:1')
- def testVariableWithDeviceFunction(self):
- class DevFn(object):
- def __init__(self):
- self.counter = -1
- def __call__(self, op):
- self.counter += 1
- return 'cpu:%d' % self.counter
- with self.test_session():
- with scopes.arg_scope([variables.variable], device=DevFn()):
- a = variables.variable('a', [])
- b = variables.variable('b', [])
- c = variables.variable('c', [], device='cpu:12')
- d = variables.variable('d', [])
- with tf.device('cpu:99'):
- e_init = tf.constant(12)
- e = variables.variable('e', initializer=e_init)
- self.assertDeviceEqual(a.device, 'cpu:0')
- self.assertDeviceEqual(a.initial_value.device, 'cpu:0')
- self.assertDeviceEqual(b.device, 'cpu:1')
- self.assertDeviceEqual(b.initial_value.device, 'cpu:1')
- self.assertDeviceEqual(c.device, 'cpu:12')
- self.assertDeviceEqual(c.initial_value.device, 'cpu:12')
- self.assertDeviceEqual(d.device, 'cpu:2')
- self.assertDeviceEqual(d.initial_value.device, 'cpu:2')
- self.assertDeviceEqual(e.device, 'cpu:3')
- self.assertDeviceEqual(e.initial_value.device, 'cpu:99')
- def testVariableWithReplicaDeviceSetter(self):
- with self.test_session():
- with tf.device(tf.train.replica_device_setter(ps_tasks=2)):
- a = variables.variable('a', [])
- b = variables.variable('b', [])
- c = variables.variable('c', [], device='cpu:12')
- d = variables.variable('d', [])
- with tf.device('cpu:99'):
- e_init = tf.constant(12)
- e = variables.variable('e', initializer=e_init)
- # The values below highlight how the replica_device_setter puts initial
- # values on the worker job, and how it merges explicit devices.
- self.assertDeviceEqual(a.device, '/job:ps/task:0/cpu:0')
- self.assertDeviceEqual(a.initial_value.device, '/job:worker/cpu:0')
- self.assertDeviceEqual(b.device, '/job:ps/task:1/cpu:0')
- self.assertDeviceEqual(b.initial_value.device, '/job:worker/cpu:0')
- self.assertDeviceEqual(c.device, '/job:ps/task:0/cpu:12')
- self.assertDeviceEqual(c.initial_value.device, '/job:worker/cpu:12')
- self.assertDeviceEqual(d.device, '/job:ps/task:1/cpu:0')
- self.assertDeviceEqual(d.initial_value.device, '/job:worker/cpu:0')
- self.assertDeviceEqual(e.device, '/job:ps/task:0/cpu:0')
- self.assertDeviceEqual(e.initial_value.device, '/job:worker/cpu:99')
- def testVariableWithVariableDeviceChooser(self):
- with tf.Graph().as_default():
- device_fn = variables.VariableDeviceChooser(num_parameter_servers=2)
- with scopes.arg_scope([variables.variable], device=device_fn):
- a = variables.variable('a', [])
- b = variables.variable('b', [])
- c = variables.variable('c', [], device='cpu:12')
- d = variables.variable('d', [])
- with tf.device('cpu:99'):
- e_init = tf.constant(12)
- e = variables.variable('e', initializer=e_init)
- # The values below highlight how the VariableDeviceChooser puts initial
- # values on the same device as the variable job.
- self.assertDeviceEqual(a.device, '/job:ps/task:0/cpu:0')
- self.assertDeviceEqual(a.initial_value.device, a.device)
- self.assertDeviceEqual(b.device, '/job:ps/task:1/cpu:0')
- self.assertDeviceEqual(b.initial_value.device, b.device)
- self.assertDeviceEqual(c.device, '/cpu:12')
- self.assertDeviceEqual(c.initial_value.device, c.device)
- self.assertDeviceEqual(d.device, '/job:ps/task:0/cpu:0')
- self.assertDeviceEqual(d.initial_value.device, d.device)
- self.assertDeviceEqual(e.device, '/job:ps/task:1/cpu:0')
- self.assertDeviceEqual(e.initial_value.device, '/cpu:99')
- def testVariableGPUPlacement(self):
- with tf.Graph().as_default():
- device_fn = variables.VariableDeviceChooser(placement='gpu:0')
- with scopes.arg_scope([variables.variable], device=device_fn):
- a = variables.variable('a', [])
- b = variables.variable('b', [])
- c = variables.variable('c', [], device='cpu:12')
- d = variables.variable('d', [])
- with tf.device('cpu:99'):
- e_init = tf.constant(12)
- e = variables.variable('e', initializer=e_init)
- # The values below highlight how the VariableDeviceChooser puts initial
- # values on the same device as the variable job.
- self.assertDeviceEqual(a.device, '/gpu:0')
- self.assertDeviceEqual(a.initial_value.device, a.device)
- self.assertDeviceEqual(b.device, '/gpu:0')
- self.assertDeviceEqual(b.initial_value.device, b.device)
- self.assertDeviceEqual(c.device, '/cpu:12')
- self.assertDeviceEqual(c.initial_value.device, c.device)
- self.assertDeviceEqual(d.device, '/gpu:0')
- self.assertDeviceEqual(d.initial_value.device, d.device)
- self.assertDeviceEqual(e.device, '/gpu:0')
- self.assertDeviceEqual(e.initial_value.device, '/cpu:99')
- def testVariableCollection(self):
- with self.test_session():
- a = variables.variable('a', [], collections='A')
- b = variables.variable('b', [], collections='B')
- self.assertEquals(a, tf.get_collection('A')[0])
- self.assertEquals(b, tf.get_collection('B')[0])
- def testVariableCollections(self):
- with self.test_session():
- a = variables.variable('a', [], collections=['A', 'C'])
- b = variables.variable('b', [], collections=['B', 'C'])
- self.assertEquals(a, tf.get_collection('A')[0])
- self.assertEquals(b, tf.get_collection('B')[0])
- def testVariableCollectionsWithArgScope(self):
- with self.test_session():
- with scopes.arg_scope([variables.variable], collections='A'):
- a = variables.variable('a', [])
- b = variables.variable('b', [])
- self.assertListEqual([a, b], tf.get_collection('A'))
- def testVariableCollectionsWithArgScopeNested(self):
- with self.test_session():
- with scopes.arg_scope([variables.variable], collections='A'):
- a = variables.variable('a', [])
- with scopes.arg_scope([variables.variable], collections='B'):
- b = variables.variable('b', [])
- self.assertEquals(a, tf.get_collection('A')[0])
- self.assertEquals(b, tf.get_collection('B')[0])
- def testVariableCollectionsWithArgScopeNonNested(self):
- with self.test_session():
- with scopes.arg_scope([variables.variable], collections='A'):
- a = variables.variable('a', [])
- with scopes.arg_scope([variables.variable], collections='B'):
- b = variables.variable('b', [])
- variables.variable('c', [])
- self.assertListEqual([a], tf.get_collection('A'))
- self.assertListEqual([b], tf.get_collection('B'))
- def testVariableRestoreWithArgScopeNested(self):
- with self.test_session():
- with scopes.arg_scope([variables.variable], restore=True):
- a = variables.variable('a', [])
- with scopes.arg_scope([variables.variable],
- trainable=False,
- collections=['A', 'B']):
- b = variables.variable('b', [])
- c = variables.variable('c', [])
- self.assertListEqual([a, b, c], variables.get_variables_to_restore())
- self.assertListEqual([a, c], tf.trainable_variables())
- self.assertListEqual([b], tf.get_collection('A'))
- self.assertListEqual([b], tf.get_collection('B'))
- class GetVariablesByNameTest(tf.test.TestCase):
- def testGetVariableGivenNameScoped(self):
- with self.test_session():
- with tf.variable_scope('A'):
- a = variables.variable('a', [5])
- b = variables.variable('b', [5])
- self.assertEquals([a], variables.get_variables_by_name('a'))
- self.assertEquals([b], variables.get_variables_by_name('b'))
- def testGetVariablesByNameReturnsByValueWithScope(self):
- with self.test_session():
- with tf.variable_scope('A'):
- a = variables.variable('a', [5])
- matched_variables = variables.get_variables_by_name('a')
- # If variables.get_variables_by_name returns the list by reference, the
- # following append should persist, and be returned, in subsequent calls
- # to variables.get_variables_by_name('a').
- matched_variables.append(4)
- matched_variables = variables.get_variables_by_name('a')
- self.assertEquals([a], matched_variables)
- def testGetVariablesByNameReturnsByValueWithoutScope(self):
- with self.test_session():
- a = variables.variable('a', [5])
- matched_variables = variables.get_variables_by_name('a')
- # If variables.get_variables_by_name returns the list by reference, the
- # following append should persist, and be returned, in subsequent calls
- # to variables.get_variables_by_name('a').
- matched_variables.append(4)
- matched_variables = variables.get_variables_by_name('a')
- self.assertEquals([a], matched_variables)
- class GlobalStepTest(tf.test.TestCase):
- def testStable(self):
- with tf.Graph().as_default():
- gs = variables.global_step()
- gs2 = variables.global_step()
- self.assertTrue(gs is gs2)
- def testDevice(self):
- with tf.Graph().as_default():
- with scopes.arg_scope([variables.global_step], device='/gpu:0'):
- gs = variables.global_step()
- self.assertDeviceEqual(gs.device, '/gpu:0')
- def testDeviceFn(self):
- class DevFn(object):
- def __init__(self):
- self.counter = -1
- def __call__(self, op):
- self.counter += 1
- return '/cpu:%d' % self.counter
- with tf.Graph().as_default():
- with scopes.arg_scope([variables.global_step], device=DevFn()):
- gs = variables.global_step()
- gs2 = variables.global_step()
- self.assertDeviceEqual(gs.device, '/cpu:0')
- self.assertEquals(gs, gs2)
- self.assertDeviceEqual(gs2.device, '/cpu:0')
- def testReplicaDeviceSetter(self):
- device_fn = tf.train.replica_device_setter(2)
- with tf.Graph().as_default():
- with scopes.arg_scope([variables.global_step], device=device_fn):
- gs = variables.global_step()
- gs2 = variables.global_step()
- self.assertEquals(gs, gs2)
- self.assertDeviceEqual(gs.device, '/job:ps/task:0')
- self.assertDeviceEqual(gs.initial_value.device, '/job:ps/task:0')
- self.assertDeviceEqual(gs2.device, '/job:ps/task:0')
- self.assertDeviceEqual(gs2.initial_value.device, '/job:ps/task:0')
- def testVariableWithVariableDeviceChooser(self):
- with tf.Graph().as_default():
- device_fn = variables.VariableDeviceChooser()
- with scopes.arg_scope([variables.global_step], device=device_fn):
- gs = variables.global_step()
- gs2 = variables.global_step()
- self.assertEquals(gs, gs2)
- self.assertDeviceEqual(gs.device, 'cpu:0')
- self.assertDeviceEqual(gs.initial_value.device, gs.device)
- self.assertDeviceEqual(gs2.device, 'cpu:0')
- self.assertDeviceEqual(gs2.initial_value.device, gs2.device)
- if __name__ == '__main__':
- tf.test.main()
|