当前位置: 首页 > news >正文

深度学习基础:从原理到实践——第二章神经网络(中)

3 三层神经网络的构建与实现

三层感知机的 “三层” 指权重计算层的数量,对应的神经元层结构为:

输入层(第0层)→ 隐藏层1(第1层)→ 隐藏层2(第2层)→ 输出层(第3层)

图 10三层神经网络

在实际应用中,三层神经网络虽然结构简单,但在许多任务上都能取得良好的性能。例如,在 MNIST 手写数字识别任务中,三层感知机可以达到 97% 以上的识别准确率​。​

更重要的是,理解三层神经网络的原理是学习更复杂深度学习架构的基础。无论是卷积神经网络(CNN)、循环神经网络(RNN)还是 Transformer,其核心思想都可以追溯到三层神经网络。

三层神经网络的架构设计需要考虑以下几个关键要素:

输入层设计:输入层的神经元数量由输入数据的特征维度决定。对于 MNIST 手写数字识别任务,每张图像是 28×28 像素的灰度图像,因此输入层需要 784 个神经元,每个神经元对应一个像素值。输入层的作用是接收原始数据并将其传递给隐藏层,本身不进行任何计算。

隐藏层设计:隐藏层是三层神经网络的核心,负责对输入数据进行非线性变换和特征提取。隐藏层神经元数量的选择对模型性能有重要影响。根据经验规则,隐藏层神经元数量应在输入层大小和输出层大小之间,通常可以设置为输入层大小的 2/3 加上输出层大小的 2/3,或小于输入层大小的两倍。对于 MNIST 任务,隐藏层通常设置 100-256 个神经元。

输出层设计:输出层的神经元数量由任务的类别数决定。对于 MNIST 手写数字识别,需要识别 0-9 共 10 个数字,因此输出层设置 10 个神经元。输出层的激活函数通常采用 Softmax 函数,将原始输出转换为概率分布,便于进行分类预测。

三层神经网络的工作原理可以分为两个阶段:

前向传播阶段:输入信息从输入层经隐含层逐层计算传向输出层。在这个过程中,每一层的神经元接收来自前一层神经元的输出作为输入,通过加权求和和激活函数处理后,将结果传递给下一层。具体而言,隐藏层的第 j 个神经元的激活值 aⱼ² = σ(∑ᵢ wⱼᵢ¹aᵢ¹ + bⱼ²),输出层的第 k 个神经元的激活值 aₖ³ = σ(∑ⱼ wₖⱼ²aⱼ² + bₖ³),其中 σ 是非线性激活函数。

反向传播阶段:如果输出层没有得到期望的输出,则计算输出层的误差变化值,然后将误差信号沿原来的连接通路反传回来修改各层神经元的权值。反向传播算法基于链式法则,通过逐层计算误差对各层权重和偏置的偏导数,实现对网络参数的优化。

下面为三层感知机的预定义统一符号:

图 11统一符号

三层感知机前向传输的核心逻辑是:信号从输入层开始,经每一层的 “加权和→激活函数” 变换后,逐层传递至输出层。

1)第一步:输入层 → 隐藏层 1 的信号传递

输入层无激活函数,其输出直接作为隐藏层 1 的输入,即

(1)计算隐藏层 1 的加权和

隐藏层 1 的每个神经元会接收输入层所有神经元的信号,并与对应权重相乘后求和,再加上自身偏置:

(2)计算隐藏层 1 的激活输出

为引入非线性变换(打破线性模型的局限性),需将加权和输入激活函数(在此选用sigmoid 函数)

因此,隐藏层 1 的激活输出为:

性质:sigmoid 函数将输入压缩到 \((0,1)\) 区间,为网络引入非线性,是三层感知机能够近似复杂函数的关键

2) 第二步:隐藏层 1 → 隐藏层 2 的信号传递

与 “输入层→隐藏层 1” 逻辑完全一致,隐藏层 1 的激活输出作为隐藏层 2 的输入。

(1)计算隐藏层 2 的加权和

(2)计算隐藏层 2 的激活输出

仍使用 sigmoid 激活函数:

3)第三步:隐藏层 2 → 输出层的信号传递

输出层的目标是根据任务输出最终结果,因此激活函数需适配任务类型(与隐藏层的 sigmoid 不同)。

(1)计算输出层的加权和

(2)计算输出层最终输出

根据任务选择激活函数:

回归任务(如预测房价):用恒等函数(输出与加权和一致)。

分类任务(如二分类 / 多分类):用softmax 函数(输出概率分布),即:

此时 输出的每个元素表示对应类别的概率,且所有元素和为 1。

Softmax 函数具有以下特点:

  • 输出向量中的每个元素都在 (0,1) 之间
  • 所有元素的和为 1,可以解释为概率
  • 指数函数的使用使得较大的输入值对应的输出概率更大,具有 "放大" 效应

http://www.dtcms.com/a/469847.html

相关文章:

  • 从传统Linux部署到容器化:实践对比与工程化指南
  • Python 高效实现 Excel 与 CSV 互转:用自动化提升效率
  • php购物网站开发uml图注册页面设计代码
  • Let‘s Encrypt证书加密原理 免费申请方式
  • 农村电商网站建设分类高校门户网站开发
  • 用vscode查日志方便的搜索-复制所有匹配行功能
  • C++设计模式之行为型模式:观察者模式(Observer)
  • 指数分布:从理论到机器学习应用
  • (Python)终端着色基础(八色样式码):一般(0-9)十之用三四,更有传说『53上划线』,众多终端不实现
  • webman项目开机自启动
  • 男和女做暖暖网站官方正版浏览器
  • 网站收录量是什么意思网站改版 信科网络
  • PDM:产品数据的智能枢纽,驱动企业高效创新
  • Redis重大版本演进全解析:从2.6到7.0
  • mysql高可用架构之MHA部署(二)VIP漂移(保姆级)
  • 【从零开始java学习|第二十二篇】集合进阶之collection
  • 活动回顾 | AutoMQ 新加坡 TOKEN2049:展示高效 Web3 数据流基础设施
  • 多字节串口收发IP设计(四)串口接收模块设计及联合仿真(含源码)
  • 封装相关学习
  • 成都网站优化方案wordpress cms主题教程
  • 网络原理基础
  • aws s3设置跨域,s3配置预签名,aws 配置文件上传
  • 18芯城网站开发案例国内简约网站设计
  • 网站开发用什么字体一般域名的作用
  • 『 QT 』Hello World控件实现指南
  • 【CF】Day148——Codeforces Round 1057 (Div. 2) CD (非退化凸多边形的分类讨论 | 破环成链动态规划)
  • 网站建设教程金旭亮wordpress自动加p标签
  • 使用C#代码将ODT转换为PDF文件
  • 【网络编程】详解 IP 协议:报头字段、路由器功能、网段划分和分片传输
  • 大模型微调 SFTTrainer 数据处理与训练器配置解析(116)