pytorch torch.scatter_reduce函数介绍

PyTorch torch.scatter_reduce 函数

torch.scatter_reduce 是 PyTorch 中的一种高级操作,用于在特定维度上将源张量的值按索引归约到目标张量中。它结合了 scatterreduce 操作,非常适合处理需要对特定索引进行归约(如求和、最大值等)的场景。


函数签名

复制代码
torch.scatter_reduce(input, dim, index, src, reduce, *, include_self=True, out=None)

参数说明

  1. input:

    • 目标张量,表示归约操作的初始值。
  2. dim:

    • 指定在目标张量 input 中进行归约操作的维度。
  3. index:

    • 张量,表示目标张量中归约操作的索引位置。
    • index 的形状必须与 src 兼容,或者可以广播成 src 的形状。
  4. src:

    • 源张量,提供要归约到 input 中的值。
  5. reduce:

    • 指定归约操作的类型,支持以下选项:
      • "sum":按索引进行求和。
      • "prod":按索引进行乘积。
      • "mean":按索引计算平均值。
      • "amax":按索引取最大值。
      • "amin":按索引取最小值。
  6. include_self (可选, 默认 True):

    • 是否在归约时包括 input 中的原始值。
    • 如果为 False,只使用 src 中的值进行归约。
  7. out (可选):

    • 用于存储结果的张量。如果提供,将直接修改此张量。

返回值

返回一个张量,包含归约操作的结果,形状与 input 相同。


示例

1. 按索引求和 (reduce="sum")
复制代码
import torch

input = torch.zeros(3, 5)
index = torch.tensor([[0, 1, 2, 0, 1],
                      [1, 2, 0, 1, 2]])
src = torch.tensor([[10., 20., 30., 40., 50.],
                    [1., 2., 3., 4., 5.]])

result = torch.scatter_reduce(input, dim=1, index=index, src=src, reduce="sum")
print(result)

输出

复制代码
tensor([[50., 70., 30.,  0.,  0.],
        [ 3.,  5.,  7.,  0.,  0.],
        [ 0.,  0.,  0.,  0.,  0.]])
2. 按索引取最大值 (reduce="amax")
复制代码
result = torch.scatter_reduce(input, dim=1, index=index, src=src, reduce="amax")
print(result)

输出

复制代码
tensor([[40., 50., 30.,  0.,  0.],
        [ 3.,  4.,  5.,  0.,  0.],
        [ 0.,  0.,  0.,  0.,  0.]])
3. 使用 include_self=False
复制代码
result = torch.scatter_reduce(input, dim=1, index=index, src=src, reduce="sum", include_self=False)
print(result)

输出:

复制代码
tensor([[50., 70., 30.,  0.,  0.],
        [ 3.,  5.,  7.,  0.,  0.],
        [ 0.,  0.,  0.,  0.,  0.]])

注意事项

  1. index 范围

    • index 的值必须在 [0, input.shape[dim]) 范围内,否则会引发错误。
  2. 广播规则

    • indexsrc 必须具有相同的形状,或者可以通过广播匹配。
  3. 性能优化

    • torch.scatter_reduce 对于稀疏更新和归约非常高效,避免了循环操作。

应用场景

  • 聚合数据(如按索引分组求和或求最大值)。
  • 构造稀疏张量。
  • 实现自定义的归约操作(如图神经网络中的消息传递)。
相关推荐
广州赛远几秒前
IRB2600-201.65特殊机器人防护服清洗工具详解与避坑指南
大数据·人工智能
喵手4 分钟前
Python爬虫实战:全站 Sitemap 自动发现 - 解析 sitemap.xml → 自动生成抓取队列的工业级实现!
爬虫·python·爬虫实战·零基础python爬虫教学·sitemap·解析sitemap.xml·自动生成抓取队列实现
Eloudy5 分钟前
直接法 读书笔记 01 第1章 引言
人工智能·机器学习·hpc
luoluoal9 分钟前
基于深度学习的web端多格式纠错系统(源码+文档)
python·mysql·django·毕业设计·源码
xsc-xyc14 分钟前
RuntimeError: Dataset ‘/data.yaml‘ error ❌ ‘_lz
人工智能·深度学习·yolo·计算机视觉·视觉检测
深蓝海拓16 分钟前
PySide6从0开始学习的笔记(二十七) 日志管理
笔记·python·学习·pyqt
川西胖墩墩17 分钟前
垂直模型价值:专业领域超越通用模型的竞争
大数据·人工智能
小润nature20 分钟前
# Moltbot/OpenClaw 架构解读与二次开发完全指南
人工智能
AEIC学术交流中心22 分钟前
【快速EI检索 | SPIE出版】2026年机器学习与大模型国际学术会议(ICMLM 2026)
人工智能·机器学习
咕噜签名-铁蛋22 分钟前
无偿安利一款企业签名分发工具
人工智能