当前位置: 首页 > news >正文

pytorch小记(三十二):深度解析 PyTorch 的 `torch.remainder`:向下取整余数运算

pytorch小记(三十二):深度解析 PyTorch 的 `torch.remainder`:向下取整余数运算

    • 深度解析 PyTorch 的 `torch.remainder`:向下取整余数运算
      • 一、函数签名
      • 二、数学定义:向下取整除法
      • 三、与 `torch.fmod` 的区别
      • 四、经典示例
      • 五、广播与张量示例
      • 六、应用场景
      • 七、小结


深度解析 PyTorch 的 torch.remainder:向下取整余数运算

在深度学习和科学计算中,经常需要对张量执行“取余”操作,将数值映射到某个固定范围内。与 Python 自身的 % 操作符不同,PyTorch 提供了更加明确的 符号约定 的两种取余函数:

  • torch.remainder(a, b):余数与除数同号或为零,基于向下取整
  • torch.fmod(a, b):余数与被除数同号或为零,基于截断取整

本文重点介绍 torch.remainder 的工作原理、数学定义、与 fmod 的区别以及丰富示例,帮助你在周期化、环绕索引、模运算等场景中选用正确的工具。


一、函数签名

torch.remainder(input, other, *, out=None) → Tensor
  • input (Tensor or scalar):被除数。
  • other (Tensor or scalar):除数,形状可与 input 相同或可广播。
  • out (可选):将结果写入到指定张量。

返回值形状与 input 相同,每个元素是对应的余数。


二、数学定义:向下取整除法

对标量 aaa(被除数)和 bbb(除数,b≠0b\neq0b=0),

remainder(a,b)=a−b×⌊ab⌋,\mathrm{remainder}(a,b) = a - b \times \left\lfloor \frac{a}{b} \right\rfloor, remainder(a,b)=ab×ba,

其中 ⌊x⌋\lfloor x\rfloorx 表示向下取整(不大于 xxx 的最大整数)。

  • b>0b>0b>0,余数 r∈[0,b)r\in[0,b)r[0,b)
  • b<0b<0b<0,余数 r∈(b,0]r\in(b,0]r(b,0]

三、与 torch.fmod 的区别

运算符定义余数符号归属
remainder(a,b)向下取整:a−b⌊a/b⌋a - b\lfloor a/b\rflooraba/b除数 同号或为 0
fmod(a,b)截断取整:a−btrunc(a/b)a - b\mathrm{trunc}(a/b)abtrunc(a/b)被除数 同号或为 0

示例(a=−3,b=2a=-3, b=2a=3,b=2):

  • torch.remainder: −3−2⌊−1.5⌋=−3−2×(−2)=1-3 - 2\lfloor -1.5\rfloor = -3 - 2\times(-2) = 1321.5=32×(2)=1
  • torch.fmod: −3−2×trunc(−1.5)=−3−2×(−1)=−1-3 - 2\times\mathrm{trunc}(-1.5) = -3 - 2\times(-1) = -132×trunc(1.5)=32×(1)=1

四、经典示例

import torch# 标量示例
print(torch.remainder(torch.tensor( 7), torch.tensor( 3)))  # 1
print(torch.remainder(torch.tensor(-7), torch.tensor( 3)))  # 2
print(torch.remainder(torch.tensor( 7), torch.tensor(-3)))  # -2
print(torch.remainder(torch.tensor(-7), torch.tensor(-3)))  # -1# 对比 fmod
print(torch.fmod(torch.tensor(-7), torch.tensor( 3)))  # -1
print(torch.fmod(torch.tensor(-7), torch.tensor(-3)))  # -1

结果:

1
2
-2
-1
-1
-1

五、广播与张量示例

import torchx = torch.tensor([-2.7, -1.2, 0.5, 1.8, 3.3])
b = 1.0
print(torch.remainder(x, b))
# => tensor([0.3000, 0.8000, 0.5000, 0.8000, 0.3000])b2 = torch.tensor([2.0, -2.0, 2.0, -2.0, 2.0])
print(torch.remainder(x, b2))
# => tensor([ 1.3000, -1.2000,  0.5000, -0.2000,  1.3000])

手算过程示例:

  • −2.7mod1.0=−2.7−1×⌊−2.7⌋=−2.7−1×(−3)=0.3-2.7 \bmod 1.0 = -2.7 - 1\times\lfloor-2.7\rfloor = -2.7 - 1\times(-3) = 0.32.7mod1.0=2.71×2.7=2.71×(3)=0.3.
  • −2.7mod2.0=−2.7−2×⌊−1.35⌋=−2.7−2×(−2)=1.3-2.7 \bmod 2.0 = -2.7 - 2\times\lfloor-1.35\rfloor = -2.7 - 2\times(-2) = 1.32.7mod2.0=2.72×1.35=2.72×(2)=1.3.

六、应用场景

  1. 周期化数据:将角度或索引循环到固定范围,如 [0,2π)[0,2\pi)[0,2π)
  2. 环绕索引:在循环队列、环形缓冲区或图像平铺中计算有效索引。
  3. 同余运算:数学模型、密码学和信号处理中的模运算实现。

七、小结

  • torch.remainder(a,b) 基于向下取整,保证余数与除数同号或为零,适合需要“正向环绕”的场景。
  • torch.fmod(截断取整、余数符号随被除数)的区别在于符号归属
  • 支持标量、张量与广播,语义清晰,易于处理周期性和模运算。
http://www.dtcms.com/a/284180.html

相关文章:

  • 【web安全】DVWA存储型XSS分析与利用
  • 第6天| openGauss中用户一次只能连接到一个数据库,没法访问其他数据库的对象
  • arping(ARP协议网络测试工具)
  • 【实时Linux实战系列】实时系统的安全性架构
  • MySQL如何解决事务并发的幻读问题
  • 从单线程到云原生:Redis 二十年演进全景与内在机理深剖
  • RuoYi-Cloud 定制微服务
  • 宝塔申请证书错误,提示 module ‘OpenSSL.crypto‘ has no attribute ‘sign‘
  • 有痛呻吟!!!
  • 09-three.js Materials
  • 任务4.1 谁做的好事
  • Nginx/OpenResty HTTP 请求处理阶段与 Lua 实践全解20250717
  • Python包测试全攻略:从单元测试到持续集成
  • Rabbitmq Direct Exchange(直连交换机)多个消费者,配置相同的key ,队列,可以保证只有一个消费者消费吗
  • 生成式AI干预下的认知依赖与批判性思维发展:基于ChatGPT辅助写作的纵向追踪
  • stl-string模拟
  • [NIPST AI]对抗性机器学习攻击和缓解的分类和术语
  • 【机器学习【7】】数据预处理:数据准备、数据转换、数据输出
  • 「Trae IDE 全流程实战」——从 0 下载安装,到在本地跑起一个可玩的 2048 小游戏
  • Java项目:基于SSM框架实现的在线视频点播管理系统【ssm+B/S架构+源码+数据库+毕业论文】
  • Redis学习系列之—— JDHotKey 热点缓存探测系统
  • 4.PCL点云的数据结构
  • Kotlin抽象类
  • Kotlin属性重写
  • 【web安全】DVWA反射型XSS漏洞分析与利用
  • web安全入门 | 记新手小白初次尝试挖越权漏洞
  • Java行为型模式---命令模式
  • AR智能巡检:制造业零缺陷安装的“数字监工”
  • 深入理解Java中的Collections.max()方法
  • Adobe Photoshop:数字图像处理的终极工具指南