torch.reciprocal介绍

在 PyTorch 中,torch.reciprocal 是一个用于计算张量中每个元素倒数的函数。它的作用是逐元素执行倒数计算。如果某个元素为零,则结果会是无穷大 (∞),并产生一个警告。

函数签名

复制代码
torch.reciprocal(input, *, out=None) → Tensor
参数说明
  • input: 输入的张量,其数据类型可以是浮点数或整数。
  • out (可选): 用于存储结果的张量,必须与 input 的形状一致。
返回值

返回一个新的张量,包含输入张量中每个元素的倒数。

示例用法

基本用法
复制代码
import torch

# 创建张量
x = torch.tensor([1.0, 2.0, 0.5, -1.0])

# 计算倒数
y = torch.reciprocal(x)

print(y)
# 输出: tensor([ 1.0000,  0.5000,  2.0000, -1.0000])

处理包含零的张量

复制代码
x = torch.tensor([1.0, 0.0, -2.0])

y = torch.reciprocal(x)

print(y)
# 输出: tensor([ 1.0000,    inf, -0.5000])
# 会产生一个警告: Division by zero encountered.

使用 out 参数

复制代码
x = torch.tensor([2.0, 4.0])
out = torch.empty_like(x)

torch.reciprocal(x, out=out)
print(out)
# 输出: tensor([0.5000, 0.2500])

注意事项

  1. 零值处理:

    • 当输入张量的某些元素为零时,会产生无穷大 (∞∞),并触发警告。
    • 如果需要处理零值,可以在计算前筛选或替换零值,例如使用 torch.where

    x = torch.tensor([1.0, 0.0, 2.0])
    x_safe = torch.where(x == 0, torch.tensor(float('nan')), x)
    y = torch.reciprocal(x_safe)
    print(y)

    输出: tensor([1.0000, nan, 0.5000])

整数类型的输入:

  • 如果输入张量是整数类型,计算结果会自动转换为浮点类型。

    x = torch.tensor([2, 4, 8])
    y = torch.reciprocal(x)
    print(y)

    输出: tensor([0.5000, 0.2500, 0.1250])

常见应用场景

  • 规范化操作: 用于计算归一化时的一部分操作。
  • 数学运算: 计算反函数或求倒数的应用。
  • 模型权重更新: 在优化算法中可能需要计算反比值。

torch.reciprocal 是 PyTorch 中一个简单但常用的工具函数,适用于多种场景,尤其是在需要逐元素倒数计算时。

相关推荐
金井PRATHAMA17 分钟前
意象框架:连接感知与认知的统一信息结构分析——基于上古汉语同源词意义系统的词源学与认知语言学探索
人工智能·自然语言处理
聚客AI24 分钟前
🧠深度解析模型压缩革命:减枝、量化、知识蒸馏
人工智能·深度学习·llm
SHIPKING39331 分钟前
【机器学习&深度学习】Ollama、vLLM、LMDeploy对比:选择适合你的 LLM 推理框架
人工智能·深度学习·机器学习
witkey_ak989635 分钟前
python 可迭代对象相关知识点
开发语言·python
站大爷IP43 分钟前
Python生成器与迭代器:从内存优化到协程调度的深度实践
python
zzywxc78743 分钟前
AI 行业应用:金融、医疗、教育、制造业领域的落地案例与技术实现
android·前端·人工智能·chrome·金融·rxjava
新智元1 小时前
刚刚,GPT-5 Pro 自证全新数学定理!OpenAI 总裁直呼颠覆,大佬们集体转发
人工智能·openai
新智元1 小时前
28 岁华人执掌 1.85 万亿科技巨头 AI 大权!一觉醒来,图灵奖得主也要向他汇报
人工智能·openai
二闹1 小时前
Python打印值的两种写法,到底有啥不同?
python
居然JuRan1 小时前
从LoRA到QLoRA再到全量微调
人工智能