PyTorch中F.softmax的具体使用

 更新时间:2025年05月13日 10:16:38   作者:资源存储库  
F.softmax是PyTorch中用于计算Softmax函数的函数,本文主要介绍了PyTorch中F.softmax的具体使用,具有一定的参考价值,感兴趣的可以了解一下

F.softmax 是 PyTorch 中用于计算 Softmax 函数 的函数,通常用于 多分类任务 的输出层,用来将模型的原始输出(称为 logits)转化为概率分布。

Softmax 函数将每个类别的得分(logits)转换为一个介于 0 和 1 之间的概率值,并且所有类别的概率之和等于 1。

Softmax 函数的定义

给定一个包含n 个元素的向量\mathbf{z} = [z_1, z_2, ..., z_n] ,Softmax 函数的输出是一个概率分布\mathbf{p} = [p_1, p_2, ..., p_n] ,其中每个p_i 表示第i个类别的概率。Softmax 的公式如下:

​​p_i = \frac{e^{z_i}}{\sum_{j=1}^{n} e^{z_j}}

  • z_i:第i个类别的原始得分(logit)。
  • e^{z_i}:对得分进行指数运算。
  • \sum_{j=1}^{n} e^{z_j}:所有类别得分指数的总和,用于对概率进行归一化,使得所有的概率和为 1。

F.softmax 的作用

F.softmax 函数将给定的 logits(即模型的原始输出)转换为概率分布。

假设我们有一个包含 10 个类别的模型输出,那么 F.softmax 会将这 10 个 logits 转化为 10 个概率,每个概率值在 0 到 1 之间,并且所有 10 个概率的和为 1。

用法

在 PyTorch 中,F.softmax 由 torch.nn.functional 模块提供,使用方式如下:

import torch
import torch.nn.functional as F

# 假设我们有一个大小为 [batch_size, num_classes] 的张量
logits = torch.tensor([[1.0, 2.0, 3.0], [1.0, 2.0, 3.0]])

# 计算 softmax,dim=1 表示对每一行进行 softmax 计算
probabilities = F.softmax(logits, dim=1)

print(probabilities)

详细解释

  • logits:是一个 2D 张量,每一行表示一个样本的原始输出值(logits),每一列表示该样本在某个类别的得分。

  • dim=1:指定了计算 Softmax 的维度。dim=1 表示对每一行计算 Softmax,即每个样本的得分都会被转化为一个概率分布。注意,如果是处理多维数据,可以通过调整 dim 来指定 Softmax 计算的维度。

    • 如果 dim=0,则对每列计算 Softmax,通常在处理多批次数据时不常用。
  • output:Softmax 转换后的输出是一个概率分布,所有元素都在 0 到 1 之间,并且每行的元素和为 1。

示例代码解释

import torch
import torch.nn.functional as F

# 假设输入是一个大小为 (2, 3) 的张量,其中 2 是 batch_size,3 是类别数
logits = torch.tensor([[1.0, 2.0, 3.0], [1.0, 2.0, 3.0]])

# 计算 Softmax,按照列来计算,即对每行进行 Softmax
probabilities = F.softmax(logits, dim=1)

print(probabilities)

输入:

tensor([[1.0, 2.0, 3.0], 
        [1.0, 2.0, 3.0]])

输出:

tensor([[0.09003057, 0.24472847, 0.66524096],
        [0.09003057, 0.24472847, 0.66524096]])

解释:

  • 对于每一行的得分,Softmax 会将其转换为概率。
    • 第一行 [1.0, 2.0, 3.0] 经过 Softmax 处理后得到 [0.0900, 0.2447, 0.6652],这些概率值的总和为 1。
    • 第二行 [1.0, 2.0, 3.0] 同样经过 Softmax 转换后,得到相同的概率分布 [0.0900, 0.2447, 0.6652],这也保证了概率总和为 1。

为什么使用 Softmax?

  • 多分类任务:在多分类问题中,模型的输出通常是每个类别的原始得分。Softmax 函数能够将这些得分转化为概率分布,使得每个类别的预测概率能够加起来为 1,并且通过最大概率来做预测。

  • 分类概率:Softmax 给出的每个类别的概率可以帮助我们了解模型对每个类别的信心程度。对于实际应用,通常选择概率最大的类别作为模型的预测结果。

Softmax 与 Logits

  • Logits 是未经处理的原始输出值,通常来自神经网络的输出层。
  • Softmax 是对 logits 的一种规范化,它将 logits 转换为 0 到 1 之间的概率值。

示例:多分类任务中的 Softmax

假设我们有一个多分类任务,模型的输出是一个包含 4 个类别的 logits 向量,[2.0, 1.0, 0.1, 0.5]

我们希望将其转换为类别的概率分布。

import torch
import torch.nn.functional as F

logits = torch.tensor([2.0, 1.0, 0.1, 0.5])

# 使用 F.softmax 将 logits 转换为概率分布
probabilities = F.softmax(logits, dim=0)

print(probabilities)

输出:

tensor([0.5438, 0.1993, 0.0717, 0.1852])

解释:

  • 原始 logits 为 [2.0, 1.0, 0.1, 0.5],经过 Softmax 处理后,得到了每个类别的概率 [0.5438, 0.1993, 0.0717, 0.1852]。概率最大的类别是第一个类别,其概率为 0.5438。

总结

  • Softmax 函数将 logits 转换为概率分布,适用于多分类任务。
  • 它保证了输出的每个类别概率值在 0 到 1 之间,并且所有概率的和为 1。
  • 在 PyTorch 中,F.softmax 是计算 Softmax 的常用函数,通常与 CrossEntropyLoss 搭配使用。

到此这篇关于PyTorch中F.softmax的具体使用的文章就介绍到这了,更多相关PyTorch F.softmax内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

相关文章

  • python对gif图压缩的完美解决方案

    python对gif图压缩的完美解决方案

    上图图片的时候由于图片太大,导致上次不成功,因此需要对文件进行统一压缩,这篇文章主要给大家介绍了关于python对gif图压缩的完美解决方案,需要的朋友可以参考下
    2021-11-11
  • Django展示可视化图表的多种方式

    Django展示可视化图表的多种方式

    这篇文章主要介绍了Django展示可视化图表的多种方式,帮助大家更好的理解和学习使用django框架,感兴趣的朋友可以了解下
    2021-04-04
  • 使用python 写一个静态服务(实战)

    使用python 写一个静态服务(实战)

    今天小编就为大家分享一篇使用python 写一个静态服务(实战),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-06-06
  • Python中的HTTP请求超时处理方式

    Python中的HTTP请求超时处理方式

    HTTP请求超时是指客户端在设定的时间内未收到服务器完整响应,合理设置超时时间可提高系统性能和用户体验,Python中,requests库和aiohttp库提供超时控制功能,通过timeout参数设置请求超时,并利用try-except捕获异常,合理超时设置和处理是开发HTTP客户端的重要技巧
    2024-11-11
  • python用pandas读写和追加csv文件

    python用pandas读写和追加csv文件

    大家好,本篇文章主要讲的是python用pandas读写和追加csv文件,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2022-02-02
  • Pytorch Dataset,TensorDataset,Dataloader,Sampler关系解读

    Pytorch Dataset,TensorDataset,Dataloader,Sampler关系解读

    这篇文章主要介绍了Pytorch Dataset,TensorDataset,Dataloader,Sampler关系,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • Python爬虫学习之获取指定网页源码

    Python爬虫学习之获取指定网页源码

    这篇文章主要为大家详细介绍了Python爬虫学习之获取指定网页源码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-07-07
  • Python变量访问权限控制详解

    Python变量访问权限控制详解

    这篇文章主要介绍了Python变量访问权限控制详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-06-06
  • Python基础详解之列表复制

    Python基础详解之列表复制

    这篇文章主要介绍了Python基础详解之列表复制,文中有非常详细的代码示例,对正在学习python基础的小伙伴们有很好的帮助,需要的朋友可以参考下
    2021-04-04
  • 对Python中range()函数和list的比较

    对Python中range()函数和list的比较

    下面小编就为大家分享一篇对Python中range()函数和list的比较,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-04-04

最新评论