Enable tensor numerics checking in an eager/graph unified fashion.
tf.debugging.enable_check_numerics( stack_height_limit=30, path_length_limit=50 )
The numerics checking mechanism will cause any TensorFlow eager execution or graph execution to error out as soon as an op's output tensor contains infinity or NaN.
This method is idempotent. Calling it multiple times has the same effect as calling it once.
This method takes effect only on the thread in which it is called.
When a op's float-type output tensor contains any Infinity or NaN, an tf.errors.InvalidArgumentError
will be thrown, with an error message that reveals the following information:
Infinity
and NaN
, respectively.Once enabled, the check-numerics mechanism can be disabled by using tf.debugging.disable_check_numerics()
.
Catching infinity during the execution of a tf.function
graph:
import tensorflow as tf tf.debugging.enable_check_numerics() @tf.function def square_log_x_plus_1(x): v = tf.math.log(x + 1) return tf.math.square(v) x = -1.0 # When the following line runs, a function graph will be compiled # from the Python function `square_log_x_plus_1()`. Due to the # `enable_check_numerics()` call above, the graph will contain # numerics checking ops that will run during the function graph's # execution. The function call generates an -infinity when the Log # (logarithm) op operates on the output tensor of the Add op. # The program errors out at this line, printing an error message. y = square_log_x_plus_1(x) z = -y
Catching NaN during eager execution:
import numpy as np import tensorflow as tf tf.debugging.enable_check_numerics() x = np.array([[0.0, -1.0], [4.0, 3.0]]) # The following line executes the Sqrt op eagerly. Due to the negative # element in the input array, a NaN is generated. Due to the # `enable_check_numerics()` call above, the program errors immediately # at this line, printing an error message. y = tf.math.sqrt(x) z = tf.matmul(y, y)
Note: If your code is running on TPUs, be sure to calltf.config.set_soft_device_placement(True)
before callingtf.debugging.enable_check_numerics()
as this API uses automatic outside compilation on TPUs. For example:
tf.config.set_soft_device_placement(True) tf.debugging.enable_check_numerics() resolver = tf.distribute.cluster_resolver.TPUClusterResolver(tpu='') strategy = tf.distribute.TPUStrategy(resolver) with strategy.scope(): # ...
Args | |
---|---|
stack_height_limit | Limit to the height of the printed stack trace. Applicable only to ops in tf.function s (graphs). |
path_length_limit | Limit to the file path included in the printed stack trace. Applicable only to ops in tf.function s (graphs). |
© 2020 The TensorFlow Authors. All rights reserved.
Licensed under the Creative Commons Attribution License 3.0.
Code samples licensed under the Apache 2.0 License.
https://www.tensorflow.org/versions/r2.4/api_docs/python/tf/debugging/enable_check_numerics