pytorch中不同的mask方法:masked_fill, masked_select, masked_scatter

在 PyTorch 中,masked_fillmasked_selectmasked_scatter 是三种常用的掩码(mask)操作方法,它们通过布尔类型的掩码张量(mask)对原始张量进行条件筛选或修改。以下是它们的详细解释和对比:


1. masked_fill

作用 :将原始张量中 maskTrue 的位置用指定值填充,其余位置保持不变。

参数

mask(BoolTensor):与原始张量形状相同的布尔掩码。

value(标量):用于填充的值。

特点

原地操作 :会直接修改原始张量(除非使用 masked_fill_ 的 in-place 版本)。

保持形状:输出张量形状与输入张量一致。

示例

python 复制代码
import torch

x = torch.tensor([[1, 2], [3, 4]])
mask = torch.tensor([[False, True], [True, False]])

y = x.masked_fill(mask, -1)
print(y)
# 输出:
# tensor([[ 1, -1],
#         [-1,  4]])

典型应用

• 在 Transformer 的注意力机制中,用 -inf 填充 padding 或未来的位置,使 softmax 后概率为 0。

• 数据清洗时屏蔽无效值(如 NaN)。


2. masked_select

作用 :从原始张量中提取 maskTrue 的元素,返回一维张量。

参数

mask(BoolTensor):与原始张量形状相同的布尔掩码。

特点

返回一维张量 :输出会丢失原始张量的维度信息。

非原地操作:生成新的张量。

示例

python 复制代码
x = torch.tensor([[1, 2], [3, 4]])
mask = torch.tensor([[False, True], [True, False]])

y = x.masked_select(mask)
print(y)  # tensor([2, 3])

典型应用

• 提取满足条件的元素(如分类任务中筛选正样本)。

• 统计掩码区域的值(如计算非零元素均值)。


3. masked_scatter

作用 :将另一个张量(source)中的值按顺序填充到原始张量中 maskTrue 的位置。

参数

mask(BoolTensor):与原始张量形状相同的布尔掩码。

source(Tensor):提供填充值的源张量。

特点

按顺序填充source 中的值按行优先顺序填充到 maskTrue 的位置。

source 的长度必须 ≥ maskTrue 的数量。

示例

python 复制代码
x = torch.tensor([[1, 2], [3, 4]])
mask = torch.tensor([[False, True], [True, False]])
source = torch.tensor([10, 20])

y = x.masked_scatter(mask, source)
print(y)
# 输出:
# tensor([[ 1, 10],
#         [20,  4]])

典型应用

• 动态替换张量中的部分值(如用随机噪声替换特定区域)。

• 批量更新参数时选择性地替换某些位置。


对比总结

方法 输入张量形状 输出形状 是否修改原张量 核心功能
masked_fill 保留原形状 与原张量相同 是(可选) 用标量填充掩码区域
masked_select 保留原形状 一维张量 提取掩码区域的元素
masked_scatter 保留原形状 与原张量相同 是(可选) 用另一张量填充掩码区域

关键注意事项

  1. 掩码形状匹配mask 必须与原始张量形状严格一致,否则会报错。
  2. 数据类型mask 必须是布尔类型(BoolTensor)。
  3. 梯度传播 :所有操作均支持自动求导,但填充的值(如 masked_fill 中的 value)需是浮点数以避免类型错误。
  4. 性能:对大规模张量频繁使用这些操作可能影响性能,建议优先使用向量化操作。

选择方法指南

• 需要保持形状并填充标量masked_fill

• 需要提取元素并丢弃形状masked_select

• 需要按顺序替换为另一张量的值masked_scatter

通过合理使用这些方法,可以高效实现条件筛选、数据清洗、动态修改等任务。

相关推荐
zhangfeng11335 小时前
国家超算中心 scnet.cn 跨用户文件分享流程总结 多个用户之间 文件共享 不需要反复下载上传
人工智能·语言模型·大模型
MATLAB代码顾问7 小时前
5大智能算法优化标准测试函数对比(Python实现)
开发语言·python
ting94520008 小时前
Tornado 全栈技术深度指南:从原理到实战
人工智能·python·架构·tornado
果汁华8 小时前
Browserbase Skills:让 Claude Agent 真正“看见“网页世界
人工智能·python
ZhengEnCi8 小时前
04-缩放点积注意力代码实现 💻
人工智能·python
DeepReinforce8 小时前
三、AI量化投资:使用akshare获取A股主板20260430所有的涨停股票
python·量化·akshare·龙头战法
HackTwoHub9 小时前
AI大模型网关存在SQL注入、附 POC 复现、影响版本LiteLLM 1.81.16~1.83.7(CVE-2026-42208)
数据库·人工智能·sql·网络安全·系统安全·网络攻击模型·安全架构
段一凡-华北理工大学9 小时前
【高炉炼铁领域炉温监测、预警、调控智能体设计与应用】~系列文章08:多模态数据融合:让数据更聪明
人工智能·python·高炉炼铁·ai赋能·工业智能体·高炉炉温
万粉变现经纪人9 小时前
如何解决 pip install llama-cpp-python 报错 未安装 CMake/Ninja 或 CPU 不支持 AVX 问题
开发语言·python·开源·aigc·pip·ai写作·llama
其实防守也摸鱼9 小时前
CTF密码学综合教学指南--第五章
开发语言·网络·笔记·python·安全·网络安全·密码学