12 Pytorch小白从零学教程:神经网络基础之激活函数的使用
在前面的教程中,我们学习了如何定义一个神经网络模型。理解神经网络的运作不仅仅依赖于模型的结构,还离不开激活函数
的使用。激活函数为神经元的输出添加非线性因素,是使得神经网络能够学习复杂的特征和模式的关键部分。在本篇中,我们将详细探讨常见的激活函数及其在PyTorch中的使用方法。
什么是激活函数?
激活函数定义了神经元的输出。对于任意输入,神经元的输出可以表示为:
这里,是权重,是偏置,是激活函数。激活函数的选择直接影响到模型的性能。常见的激活函数包括:
- Sigmoid
- Tanh
- ReLU(Rectified Linear Unit)
- Leaky ReLU
- Softmax
接下来,我们将逐一介绍这些激活函数,并在PyTorch中演示它们的使用。
1. Sigmoid 函数
Sigmoid
函数的公式如下:
Sigmoid函数的输出范围是,非常适合用于二分类问题的输出层。
PyTorch示例:
import torch
import torch.nn as nn
# 定义Sigmoid激活函数
sigmoid = nn.Sigmoid()
# 测试输入
input_tensor = torch.tensor([-1.0, 0.0, 1.0])
output_tensor = sigmoid(input_tensor)
print(output_tensor) # 输出各个值的Sigmoid结果
2. Tanh 函数
tanh
函数可表示为:
Tanh
函数的输出范围是。与Sigmoid
不同,Tanh
在零附近有更强的非线性,通常能带来更好的收敛效果。
PyTorch示例:
# 定义Tanh激活函数
tanh = nn.Tanh()
# 测试输入
input_tensor = torch.tensor([-1.0, 0.0, 1.0])
output_tensor = tanh(input_tensor)
print(output_tensor) # 输出各个值的Tanh结果
3. ReLU 函数
ReLU
(Rectified Linear Unit)是最常用的激活函数,公式为:
它在正数区间内是线性的,并且能有效缓解梯度消失
问题。ReLU
的输出为。
PyTorch示例:
# 定义ReLU激活函数
relu = nn.ReLU()
# 测试输入
input_tensor = torch.tensor([-1.0, 0.0, 1.0])
output_tensor = relu(input_tensor)
print(output_tensor) # 输出ReLU结果
4. Leaky ReLU 函数
Leaky ReLU
是ReLU
的一种变种,解决了ReLU的“神经元死亡”问题。它的定义为:
其中是一个小的常数。
PyTorch示例:
# 定义Leaky ReLU激活函数
leaky_relu = nn.LeakyReLU(negative_slope=0.01)
# 测试输入
input_tensor = torch.tensor([-1.0, 0.0, 1.0])
output_tensor = leaky_relu(input_tensor)
print(output_tensor) # 输出Leaky ReLU结果
5. Softmax 函数
Softmax
函数常用于多分类问题,它将模型的输出转换为概率分布,公式如下:
Softmax的输出范围是,并且所有输出的和等于1。
PyTorch示例:
# 定义Softmax激活函数
softmax = nn.Softmax(dim=0)
# 测试输入
input_tensor = torch.tensor([1.0, 2.0, 3.0])
output_tensor = softmax(input_tensor)
print(output_tensor) # 输出Softmax结果
小结
在本节中,我们重点探讨了各种激活函数
的定义及其在PyTorch中的实现。激活函数
是神经网络中至关重要的一环,通过引入非线性,使得模型能够拟合复杂的数据分布。理解不同激活函数的特性可以帮助我们选择合适的激活函数以实现更好的模型性能。
在下一篇教程中,我们将学习如何定义损失函数,进一步提升我们对神经网络训练过程的理解。