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

【机器学习】深度学习(DNN)

文章目录

    • 1. 神经网络结构
    • 2. 训练步骤
    • 3. 反向传播
    • 4. 为什么深,而不是宽(模块化)
    • 5. 初始化参数能否全为0?

1. 神经网络结构

  • 输入层
  • 隐藏层:用于特征转换
  • 输出层:用于分类
  • 技巧:将网络中的参数写成矩阵形式,利用GPU加速

2. 训练步骤

  1. 确定神经网络的结构
  • 需要根据输入和输出的维度来确定结构,最关键的部分。
  • 注:考虑输入之间的内在关联,所有的类(class)使用同一个模型进行分类。
  1. 评估函数
  • 输出与正确结果的交叉熵。
  1. 选择最优函数
  • 梯度下降法。

3. 反向传播

概念

反向传播是一种在做梯度下降时的微分方法。

方式

从后向前计算微分,因为前面的微分需要后面的结果。

两个部分

  1. 梯度: ∇ f w = ∂ l ∂ w = ∂ z ∂ w ⋅ ∂ l ∂ z \nabla f_w = \frac{\partial l}{\partial w} = \frac{\partial z}{\partial w} \cdot \frac{\partial l}{\partial z} fw=wl=wzzl

  2. 正向传播: ∂ z ∂ w \frac{\partial z}{\partial w} wz ,即每一个神经元的输出。

  3. 反向传播:
    ∂ l ∂ z = ∂ a ∂ z ⋅ ∂ l ∂ a = σ ′ ( z ) [ w 3 ⋅ ∂ l ∂ z ′ + w 4 ⋅ ∂ l ∂ z ′ ′ ] \frac{\partial l}{\partial z} = \frac{\partial a}{\partial z} \cdot \frac{\partial l}{\partial a} = \sigma'(z) \left[ w_3 \cdot \frac{\partial l}{\partial z'} + w_4 \cdot \frac{\partial l}{\partial z''} \right] zl=zaal=σ(z)[w3zl+w4z′′l]

将正向传播和反向传播的结果相乘,得到L对w的偏微分。

与正向传播比较

  • 反向传播需要更多的内存,但效率更高。
  • 无需像正向传播那样每次计算微分时都要重新计算后续的结果,减少了栈空间的使用。

全连接反馈网络

  • 每一层的神经元输出全部进入下一层的输入。

4. 为什么深,而不是宽(模块化)

更深的网络:它的模型更加复杂,但这种复杂性是模块化的。

核心

  • 将复杂的问题分解为多个简单的问题。每一层的神经元处理相同级别的任务,其输出作为更高层次任务的数据来源。

好处

  • 每一层的输出都可以被深层的神经元重复利用,避免像浅层网络那样每次都重新计算,提高效率。
  • 深层的隐藏层能够更详细地提取特征,提取后的特征能更好地进行分类,且比人为指定的特征更接近最优解。
  • 每个基本分类器能够获得足够的训练示例,相比于平铺网络,较少的数据就能训练好。

  • 深度/平铺网络的参数量是一样的,复杂性指的是网络结构,而不是参数数量。

5. 初始化参数能否全为0?

  • 同一层的神经元是同构的,具有相同的输入和输出。如果初始参数设置为相同值,无论正向还是反向传播,它们的取值都会一样,导致学习过程无法打破对称性,最终训练结果会使同一层的参数都相同。
  • 因此,应该在初始化时随机赋值,以打破这种对称性。
http://www.lryc.cn/news/513875.html

相关文章:

  • 12.30-1-5学习周报
  • 【MySQL】数据操作
  • python数据分析:使用pandas库读取和编辑Excel表
  • 开源轻量级文件分享服务Go File本地Docker部署与远程访问
  • 异步背后的奥秘:事件循环
  • Springboot使用RabbitMQ实现关闭超时订单的一个简单示例
  • 小程序基础 —— 07 创建小程序项目
  • 【Golang 面试题】每日 3 题(十五)
  • Docker命令(用法说明详解)
  • leetcode 热题100(131. 分割回文串)c++
  • vs2022编译opencv 4.10.0
  • Bash 中的 2>1 | tee 命令详解
  • MySQL数据库的日志
  • DataCap 2024.4.1 版本发布:MongoDB 驱动支持、工作流引擎升级
  • 二十三种设计模式-单例模式
  • 【微服务】SpringBoot 国际化适配方案使用详解
  • 太阳能电池板缺陷识别数据集,使用yolo,coco json,pasical voc xml格式标注,可识别旁路二极管,电池故障,热点,2234张原始图片
  • 客户案例:基于慧集通平台集成打通小满CRM+金蝶云星空+钉钉
  • ubuntu 如何使用vrf
  • Debian-linux运维-ssh配置(兼容Jenkins插件的ssh连接公钥类型)
  • K8S详解(5万字详细教程)
  • Redis6为什么引入了多线程?
  • KMP 2024 年总结,Kotlin 崛起的一年
  • leecode188.买卖股票的最佳时机IV
  • 分布式消息队列RocketMQ
  • 诗韵--代码之外的生活:2025 元旦歌
  • SpringBoot项目启动的时候,指定jvm内存大小的3种方式
  • 学习vue3的笔记
  • MySQL UNION
  • day21-ubuntu入门