NonZero¶
Computes the indices of the input tensor where the value is non-zero. The returned indices are in row-major order.
Inputs¶
input: tensor of type T
.
Outputs¶
output: tensor of type int32
.
Data Types¶
T: bool
, int8
, int32
, float16
, float32
, bfloat16
Shape Information¶
output is a tensor with a shape of \([D,C]\), where \(D\) is the number of dimensions of the input and \(C\) is the number of non-zero values.
Volume Limits¶
input and output can have up to \(2^{31}-1\) elements.
Examples¶
NonZero
opt_profile = get_runner.builder.create_optimization_profile()
get_runner.config.add_optimization_profile(opt_profile)
in1 = network.add_input("input1", dtype=trt.float32, shape=(2, 3))
layer = network.add_non_zero(input=in1)
network.mark_output(layer.get_output(0))
inputs[in1.name] = np.array([[-3.0, -2.0, 0], [0.0, 1.0, 2.0]])
outputs[layer.get_output(0).name] = layer.get_output(0).shape
expected[layer.get_output(0).name] = np.array(
[
[0, 0, 1, 1],
[0, 1, 1, 2],
]
)
C++ API¶
For more information about the C++ INonZeroLayer operator, refer to the C++ INonZeroLayer documentation.
Python API¶
For more information about the Python INonZeroLayer operator, refer to the Python INonZeroLayer documentation.