Computes the maximum along segments of a tensor.
tf.math.unsorted_segment_max(
data, segment_ids, num_segments, name=None
)
Read the section on segmentation for an explanation of segments.
This operator is similar to tf.math.unsorted_segment_sum
,
Instead of computing the sum over segments, it computes the maximum such that:
\(output_i = \max_{j...} data[j...]\) where max is over tuples j...
such
that segment_ids[j...] == i
.
If the maximum is empty for a given segment ID i
, it outputs the smallest
possible value for the specific numeric type,
output[i] = numeric_limits<T>::lowest()
.
If the given segment ID i
is negative, then the corresponding value is
dropped, and will not be included in the result.
For example:
c = tf.constant([[1,2,3,4], [5,6,7,8], [4,3,2,1]])
tf.math.unsorted_segment_max(c, tf.constant([0, 1, 0]), num_segments=2).numpy()
array([[4, 3, 3, 4],
[5, 6, 7, 8]], dtype=int32)
Returns | |
---|---|
A Tensor . Has the same type as data .
|