nn.functional详细解读

一、normalize用法详解

normalize函数能够对数据做归一化处理,将数据缩放到0~1范围内。

import torch.nn.functional as F
import torch

x = torch.Tensor([[1, 2], [3, 4]])
norm_x = F.normalize(x, p=2, dim=1)
print(norm_x)

输出结果:
tensor([[0.4472, 0.8944],[0.6, 0.8]])

该例子中,p=2表示采用欧式距离进行归一化处理,dim=1表示对列向量进行处理。normalize还支持其他的p取值,例如p=1的曼哈顿距离。

二、dropout用法详解

在深度学习中,过度拟合是一个非常大的问题,dropout能够缓解过度拟合问题。

import torch.nn.functional as F
import torch

x = torch.Tensor([[1, 2], [3, 4]])
drop_x = F.dropout(x, p=0.5, training=True)
print(drop_x)

输出结果:
tensor([[0., 4.],[6., 8.]])

该例子中,p=0.5表示每个元素被随机dropout的概率为0.5,training=True表示dropout操作生效。如果training=False则表示不对数据做dropout,这是在测试时使用的。

三、pad用法详解

在一些场景中,需要对数据进行填充或者裁剪使得尺寸大小相同。pytorch提供了padding函数对数据进行填充操作。

import torch.nn.functional as F
import torch

inputs = torch.randn(1, 3, 5)
pad_inputs = F.pad(inputs, (1, 1, 0, 0), "constant", 0)
print(pad_inputs.shape)

输出结果:
torch.Size([1, 3, 7])

该例子中,pad_inputs在第2个维度上做了padding操作,补0长度为2(前1后1),第3个维度没有做padding操作。”constant”表示使用常数填充,0表示填充的常数为0。

四、cross_entropy用法详解

交叉熵是在分类问题中常用的一种损失函数,nn.functional模块中提供了cross_entropy函数,可以用于计算交叉熵损失。

import torch.nn.functional as F
import torch

inputs = torch.randn(2, 3)
targets = torch.Tensor([1, 2]).long()
loss = F.cross_entropy(inputs, targets)
print(loss)

输出结果:
tensor(2.0171)

该例子中,inputs为一个2行3列的随机flatten数组,targets为标签,cross_entropy计算inputs与targets的交叉熵损失。

五、softmax用法详解

softmax函数可以将一个向量转化为概率分布,常用于分类问题中。

import torch.nn.functional as F
import torch

inputs = torch.Tensor([[1, 2], [3, 4]])
softmax_inputs = F.softmax(inputs, dim=1)
print(softmax_inputs)

输出结果:
tensor([[0.2689, 0.7311],[0.2689, 0.7311]])

该例子中,dim=1表示对列向量进行softmax操作。

原创文章,作者:HRDXA,如若转载,请注明出处:https://www.506064.com/n/316830.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
HRDXAHRDXA
上一篇 2025-01-09 12:14
下一篇 2025-01-09 12:15

相关推荐

  • index.html怎么打开 – 详细解析

    一、index.html怎么打开看 1、如果你已经拥有了index.html文件,那么你可以直接使用任何一个现代浏览器打开index.html文件,比如Google Chrome、…

    编程 2025-04-25
  • Resetful API的详细阐述

    一、Resetful API简介 Resetful(REpresentational State Transfer)是一种基于HTTP协议的Web API设计风格,它是一种轻量级的…

    编程 2025-04-25
  • AXI DMA的详细阐述

    一、AXI DMA概述 AXI DMA是指Advanced eXtensible Interface Direct Memory Access,是Xilinx公司提供的基于AMBA…

    编程 2025-04-25
  • 关键路径的详细阐述

    关键路径是项目管理中非常重要的一个概念,它通常指的是项目中最长的一条路径,它决定了整个项目的完成时间。在这篇文章中,我们将从多个方面对关键路径做详细的阐述。 一、概念 关键路径是指…

    编程 2025-04-25
  • neo4j菜鸟教程详细阐述

    一、neo4j介绍 neo4j是一种图形数据库,以实现高效的图操作为设计目标。neo4j使用图形模型来存储数据,数据的表述方式类似于实际世界中的网络。neo4j具有高效的读和写操作…

    编程 2025-04-25
  • c++ explicit的详细阐述

    一、explicit的作用 在C++中,explicit关键字可以在构造函数声明前加上,防止编译器进行自动类型转换,强制要求调用者必须强制类型转换才能调用该函数,避免了将一个参数类…

    编程 2025-04-25
  • HTMLButton属性及其详细阐述

    一、button属性介绍 button属性是HTML5新增的属性,表示指定文本框拥有可供点击的按钮。该属性包括以下几个取值: 按钮文本 提交 重置 其中,type属性表示按钮类型,…

    编程 2025-04-25
  • crontab测试的详细阐述

    一、crontab的概念 1、crontab是什么:crontab是linux操作系统中实现定时任务的程序,它能够定时执行与系统预设时间相符的指定任务。 2、crontab的使用场…

    编程 2025-04-25
  • Vim使用教程详细指南

    一、Vim使用教程 Vim是一个高度可定制的文本编辑器,可以在Linux,Mac和Windows等不同的平台上运行。它具有快速移动,复制,粘贴,查找和替换等强大功能,尤其在面对大型…

    编程 2025-04-25
  • 网站测试工具的详细阐述

    一、测试工具的概述 在软件开发的过程中,测试工具是一个非常重要的环节。测试工具可以快速、有效地检测软件中的缺陷,提高软件的质量和稳定性。与此同时,测试工具还可以提高软件开发的效率,…

    编程 2025-04-25

发表回复

登录后才能评论