205_深度学习的非线性魔法:多层感知机(MLP)与激活函数全解析

如果神经网络只有线性层(Linear),那么无论叠加多少层,最终结果仍然是一个线性变换。为了让网络变"聪明",我们引入了隐藏层和激活函数

1. 什么是多层感知机(MLP)?

多层感知机在输入层和输出层之间增加了一个或多个隐藏层(Hidden Layers)

  • 线性堆叠的失效 :若无激活函数,等价于一个新的线性层
  • 非线性的引入 :在每层线性计算后加入非线性激活函数 ,公式变为 。这使得模型可以学习坐标系中扭曲、复杂的边界。

2. 三大核心激活函数

激活函数必须是非线性的。文件中重点提到了以下三种:

① ReLU (修正线性单元)

  • 特点:目前最受欢迎。x > 0时导数为 1,x < 0时导数为 0。
  • 优点:计算简单,有效缓解梯度消失问题。
  • 代码nn.ReLU()

② Sigmoid

  • 特点 :将输入映射到 区间。
  • 缺点 :在输入很大或很小时,梯度接近 0,容易导致梯度消失

③ Tanh (双曲正切)

  • 特点 :将输入映射到区间,输出以 0 为中心。

3. 代码实战:简洁实现多层感知机

文件演示了如何在 Fashion-MNIST 任务中加入一个拥有 256 个隐藏单元的层。

Python

复制代码
import torch
from torch import nn
from d2l import torch as d2l

# 1. 搭建 MLP 网络
# Flatten: 展平图像
# Linear(784, 256): 隐藏层,256个神经元
# ReLU: 激活函数,引入非线性
# Linear(256, 10): 输出层
net = nn.Sequential(
    nn.Flatten(),
    nn.Linear(784, 256),
    nn.ReLU(),
    nn.Linear(256, 10)
)

# 2. 初始化参数
def init_weights(m):
    if type(m) == nn.Linear:
        nn.init.normal_(m.weight, std=0.01)

net.apply(init_weights)

# 3. 设置训练超参数
batch_size, lr, num_epochs = 256, 0.1, 10
loss = nn.CrossEntropyLoss()
trainer = torch.optim.SGD(net.parameters(), lr=lr)

# 4. 加载数据并训练
train_iter, test_iter = d2l.load_data_fashion_mnist(batch_size)
d2l.train_ch3(net, train_iter, test_iter, loss, num_epochs, trainer)

4. 关键超参数:隐藏单元个数

在代码中,我们将隐藏层设为 256

  • 为什么是 256? 这是一个超参数。隐藏单元越多,模型的表达能力越强,但也越容易过拟合(Overfitting)且计算量更大。
  • 设计准则:通常设置在输入维度(784)和输出维度(10)之间,且常用 2 的幂次方。

5. 总结:MLP 的三要素

  1. 隐藏层:提供模型深度。
  2. 激活函数:提供非线性动力。
  3. 超参数调整:通过调整层数和神经元个数来平衡模型的"欠拟合"与"过拟合"。

💡 学习小结

多层感知机是现代深度学习的基石。当你理解了非线性激活函数的重要性后,你也就理解了为什么深度学习能处理比传统算法复杂得多的任务。

相关推荐
iAm_Ike2 小时前
Go 中自定义类型与基础类型间的显式类型转换详解
jvm·数据库·python
iuvtsrt2 小时前
Golang怎么实现方法集与接口的匹配_Golang如何理解值类型和指针类型实现接口的区别【详解】
jvm·数据库·python
牧子川2 小时前
009-Transformer-Architecture
人工智能·深度学习·transformer
covco2 小时前
矩阵管理系统指南:拆解星链引擎的架构设计与全链路落地实践
大数据·人工智能·矩阵
沪漂阿龙3 小时前
AI大模型面试题:支持向量机是什么?间隔最大化、软间隔、核函数、LinearSVC 全面拆解
人工智能·算法·支持向量机
lifewange3 小时前
AI编写测试用例工具介绍
人工智能·测试用例
陕西字符3 小时前
2026 西安 豆包获客优化技术深度解析:企来客科技 AI 全域获客系统测评
大数据·人工智能
掘金安东尼3 小时前
GGUF、GPTQ、AWQ、EXL2、MLX、VMLX...运行大模型,为什么会有这么多格式?
人工智能
新知图书3 小时前
市场分析报告自动化生成(使用千问)
人工智能·ai助手·千问·高效办公
无心水3 小时前
【Hermes:安全、权限与生产环境】38、Hermes Agent 安全四层纵深:最小权限原则从理论到落地的完全指南
人工智能·安全·mcp协议·openclaw·养龙虾·hermes·honcho