tf.where

View source on GitHub

Return the elements, either from x or y, depending on the condition.

tf.where(
    condition, x=None, y=None, name=None
)

If both x and y are None, then this operation returns the coordinates of true elements of condition. The coordinates are returned in a 2-D tensor where the first dimension (rows) represents the number of true elements, and the second dimension (columns) represents the coordinates of the true elements. Keep in mind, the shape of the output tensor can vary depending on how many true values there are in input. Indices are output in row-major order.

If both non-None, condition, x and y must be broadcastable to the same shape.

The condition tensor acts as a mask that chooses, based on the value at each element, whether the corresponding element / row in the output should be taken from x (if true) or y (if false).

Args:

Returns:

A Tensor with the same type as x and y, and shape that is broadcast from condition, x, and y, if x, y are non-None. Otherwise, a Tensor with shape (num_true, dim_size(condition)).

Raises: