hooks_test.py 5.48 KB
Newer Older
Yanhui Liang's avatar
Yanhui Liang committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# Copyright 2017 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 hooks."""

from __future__ import absolute_import
from __future__ import division
from __future__ import print_function

import time

24
from absl import logging
Karmel Allison's avatar
Karmel Allison committed
25
import tensorflow as tf  # pylint: disable=g-bad-import-order
Yanhui Liang's avatar
Yanhui Liang committed
26

27
from official.utils.logs import hooks
Karmel Allison's avatar
Karmel Allison committed
28
from official.utils.testing import mock_lib
Yanhui Liang's avatar
Yanhui Liang committed
29

30
logging.set_verbosity(logging.DEBUG)
Yanhui Liang's avatar
Yanhui Liang committed
31
32
33


class ExamplesPerSecondHookTest(tf.test.TestCase):
34
35
  """Tests for the ExamplesPerSecondHook.

36
37
38
39
  In the test, we explicitly run global_step tensor after train_op in order to
  keep the global_step value and the train_op (which increase the glboal_step
  by 1) consistent. This is to correct the discrepancies in reported global_step
  value when running on GPUs.
40
  """
Yanhui Liang's avatar
Yanhui Liang committed
41
42
43

  def setUp(self):
    """Mock out logging calls to verify if correct info is being monitored."""
Karmel Allison's avatar
Karmel Allison committed
44
    self._logger = mock_lib.MockBenchmarkLogger()
Yanhui Liang's avatar
Yanhui Liang committed
45
46
47

    self.graph = tf.Graph()
    with self.graph.as_default():
48
49
50
51
      tf.compat.v1.train.create_global_step()
      self.train_op = tf.compat.v1.assign_add(
          tf.compat.v1.train.get_global_step(), 1)
      self.global_step = tf.compat.v1.train.get_global_step()
Yanhui Liang's avatar
Yanhui Liang committed
52
53
54
55
56
57

  def test_raise_in_both_secs_and_steps(self):
    with self.assertRaises(ValueError):
      hooks.ExamplesPerSecondHook(
          batch_size=256,
          every_n_steps=10,
Karmel Allison's avatar
Karmel Allison committed
58
59
          every_n_secs=20,
          metric_logger=self._logger)
Yanhui Liang's avatar
Yanhui Liang committed
60
61
62
63
64
65

  def test_raise_in_none_secs_and_steps(self):
    with self.assertRaises(ValueError):
      hooks.ExamplesPerSecondHook(
          batch_size=256,
          every_n_steps=None,
Karmel Allison's avatar
Karmel Allison committed
66
67
          every_n_secs=None,
          metric_logger=self._logger)
Yanhui Liang's avatar
Yanhui Liang committed
68

69
  def _validate_log_every_n_steps(self, every_n_steps, warm_steps):
Yanhui Liang's avatar
Yanhui Liang committed
70
71
72
    hook = hooks.ExamplesPerSecondHook(
        batch_size=256,
        every_n_steps=every_n_steps,
Karmel Allison's avatar
Karmel Allison committed
73
74
        warm_steps=warm_steps,
        metric_logger=self._logger)
Yanhui Liang's avatar
Yanhui Liang committed
75

76
77
    with tf.compat.v1.train.MonitoredSession(
        tf.compat.v1.train.ChiefSessionCreator(), [hook]) as mon_sess:
78
79
80
81
82
83
84
85
      for _ in range(every_n_steps):
        # Explicitly run global_step after train_op to get the accurate
        # global_step value
        mon_sess.run(self.train_op)
        mon_sess.run(self.global_step)
        # Nothing should be in the list yet
        self.assertFalse(self._logger.logged_metric)

Yanhui Liang's avatar
Yanhui Liang committed
86
      mon_sess.run(self.train_op)
87
      global_step_val = mon_sess.run(self.global_step)
Yanhui Liang's avatar
Yanhui Liang committed
88

89
90
91
92
93
      if global_step_val > warm_steps:
        self._assert_metrics()
      else:
        # Nothing should be in the list yet
        self.assertFalse(self._logger.logged_metric)
Karmel Allison's avatar
Karmel Allison committed
94

95
96
97
98
      # Add additional run to verify proper reset when called multiple times.
      prev_log_len = len(self._logger.logged_metric)
      mon_sess.run(self.train_op)
      global_step_val = mon_sess.run(self.global_step)
Yanhui Liang's avatar
Yanhui Liang committed
99

100
101
102
103
104
105
      if every_n_steps == 1 and global_step_val > warm_steps:
        # Each time, we log two additional metrics. Did exactly 2 get added?
        self.assertEqual(len(self._logger.logged_metric), prev_log_len + 2)
      else:
        # No change in the size of the metric list.
        self.assertEqual(len(self._logger.logged_metric), prev_log_len)
Yanhui Liang's avatar
Yanhui Liang committed
106
107

  def test_examples_per_sec_every_1_steps(self):
108
109
    with self.graph.as_default():
      self._validate_log_every_n_steps(1, 0)
Yanhui Liang's avatar
Yanhui Liang committed
110
111

  def test_examples_per_sec_every_5_steps(self):
112
113
    with self.graph.as_default():
      self._validate_log_every_n_steps(5, 0)
Yanhui Liang's avatar
Yanhui Liang committed
114
115

  def test_examples_per_sec_every_1_steps_with_warm_steps(self):
116
117
    with self.graph.as_default():
      self._validate_log_every_n_steps(1, 10)
Yanhui Liang's avatar
Yanhui Liang committed
118
119

  def test_examples_per_sec_every_5_steps_with_warm_steps(self):
120
121
    with self.graph.as_default():
      self._validate_log_every_n_steps(5, 10)
Yanhui Liang's avatar
Yanhui Liang committed
122

123
  def _validate_log_every_n_secs(self, every_n_secs):
Yanhui Liang's avatar
Yanhui Liang committed
124
125
126
    hook = hooks.ExamplesPerSecondHook(
        batch_size=256,
        every_n_steps=None,
Karmel Allison's avatar
Karmel Allison committed
127
128
        every_n_secs=every_n_secs,
        metric_logger=self._logger)
Yanhui Liang's avatar
Yanhui Liang committed
129

130
131
    with tf.compat.v1.train.MonitoredSession(
        tf.compat.v1.train.ChiefSessionCreator(), [hook]) as mon_sess:
132
133
134
135
136
137
138
      # Explicitly run global_step after train_op to get the accurate
      # global_step value
      mon_sess.run(self.train_op)
      mon_sess.run(self.global_step)
      # Nothing should be in the list yet
      self.assertFalse(self._logger.logged_metric)
      time.sleep(every_n_secs)
Yanhui Liang's avatar
Yanhui Liang committed
139

140
141
142
      mon_sess.run(self.train_op)
      mon_sess.run(self.global_step)
      self._assert_metrics()
Yanhui Liang's avatar
Yanhui Liang committed
143
144

  def test_examples_per_sec_every_1_secs(self):
145
146
    with self.graph.as_default():
      self._validate_log_every_n_secs(1)
Yanhui Liang's avatar
Yanhui Liang committed
147
148

  def test_examples_per_sec_every_5_secs(self):
149
150
    with self.graph.as_default():
      self._validate_log_every_n_secs(5)
Yanhui Liang's avatar
Yanhui Liang committed
151

Karmel Allison's avatar
Karmel Allison committed
152
153
154
155
156
  def _assert_metrics(self):
    metrics = self._logger.logged_metric
    self.assertEqual(metrics[-2]["name"], "average_examples_per_sec")
    self.assertEqual(metrics[-1]["name"], "current_examples_per_sec")

Yanhui Liang's avatar
Yanhui Liang committed
157

Karmel Allison's avatar
Karmel Allison committed
158
if __name__ == "__main__":
Yanhui Liang's avatar
Yanhui Liang committed
159
  tf.test.main()