masked_fill

paddle. masked_fill ( x, mask, value, name=None ) [源代码]

返回一个 1-D 的 Tensor,Tensor 的值是根据 mask 信息,将 value 中的值填充到 xmask 对应为 True 的位置,mask 的数据类型是 bool。

参数

  • x (Tensor) - 输入 Tensor,数据类型为 float,double,int,int64_t,float16 或者 bfloat16。

  • mask (Tensor) - 布尔张量,表示要填充的位置。mask 的数据类型必须为 bool。

  • value (Scalar or 0-D Tensor):用于填充目标张量的值,数据类型为 float,double,int,int64_t,float16 或者 bfloat16。

  • name (str,可选) - 具体用法请参见 Name,一般无需设置,默认值为 None。

返回

返回一个根据 mask 将对应位置填充为 value 的 Tensor,数据类型与 x 相同。

代码示例

>>> import paddle
>>> x = paddle.ones((3, 3), dtype="float32")
>>> mask = paddle.to_tensor([[True, True, False]])
>>> print(mask)
Tensor(shape=[1, 3], dtype=bool, place=Place(gpu:0), stop_gradient=True,
       [[True , True , False]])
>>> out = paddle.masked_fill(x, mask, 2)
>>> print(out)
Tensor(shape=[3, 3], dtype=float32, place=Place(gpu:0), stop_gradient=True,
       [[2., 2., 1.],
        [2., 2., 1.],
        [2., 2., 1.]])