数学原理解释resnet缓解梯度弥散问题

2023-11-10 02:20

本文主要是介绍数学原理解释resnet缓解梯度弥散问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

数学原理解释resnet缓解梯度弥散问题

  • 前言
    • 产生梯度弥散的原因
    • 残差结构
    • 激活函数缓解梯度弥散
    • 总结

前言

本文是一位职场小白在百度实习面试被虐,发现基本的大公司都会问到网络的数学原理解释,之后学习很多的博客。对残差网络的一些深入理解,开始写人生的第一篇博客,如有差错,还请各位大佬多多指正,多多交流

产生梯度弥散的原因

深度学习的本质是找到一个复杂的函数来拟合输入数据和输出数据之前的转换关系。简单的说:y = f(x),这里的x和y可能是向量,也可能是矩阵。复杂的网络就是函数f。

在深度学习中常见预处理:去均值,归一化。这样做的原因是能够使输入的数据之间方差更小,通俗的将就是每一次输入的数据都比较一致,模型就能够更快的收敛。也就是更快的学习到x——》y之间的转换关系f。达到类似效果的有初始化(xavier,何凯明),batch_normalization。

讲了以上怎么多关键引出的就是神经网络中流动的数据大多是均值为0,方差为1的数据分布。而神经网路的学习过程就是进行链式求导,这个不熟悉的话,想必大家都知道高中学习的符合函数求导吧 。原理是一样的,这样多个0-1之间的数字相乘就会越乘越小,导致梯度->0

残差结构

在上面的段落我们讲过,梯度弥散本质的原因是多个0-1之间小数相乘的结果。很简单的思维就是我们其中的一些数字变大,从0.1增大到0.9,类似于这种的操作。不就可以缓解了吗?

是的,残差网络就是怎么简单的原因,下面通过一个例子来更清晰的了解:

此时我们对权重w2进行求导梯度值为 y1+x,相比不加残差结构在梯度值上多加了一个x,达到了0.1到0.9的变化,因此在一定程度上缓解了梯度弥散的问题
此时我们对权重w2进行求导梯度值为 y1+x,相比不加残差结构在梯度值上多加了一个x,达到了0.1到0.9的变化,因此在一定程度上缓解了梯度弥散的问题

至于为什么不直接从0.1增大到9,个人觉得是数据的分布更离散,模型学习的会更困难, 收敛速度更慢。

激活函数缓解梯度弥散

在神经网络初期的时候使用的激活函数都是sigmoid激活,而sigmoid的梯度值在[4,+∞],[-∞,-4这两个区间趋近与0。所以后期有更换relu激活函数来缓解这个问题,我觉得目前用这个来回答不是很合理,上文也提起过,后来提出的BN,xavier初始化等方法都会将输出的数据分布调整为正太分布,而sigmoid 在0之间的梯度值接近线性函数的梯度值

总结

所以综上所述,对于梯度弥散的问题,残差结构是最直接的解决办法,而激活函数要针对于具体的数据分布

这篇关于数学原理解释resnet缓解梯度弥散问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/379854

相关文章

JAVA Calendar设置上个月时,日期不存在或错误提示问题及解决

《JAVACalendar设置上个月时,日期不存在或错误提示问题及解决》在使用Java的Calendar类设置上个月的日期时,如果遇到不存在的日期(如4月31日),默认会自动调整到下个月的相应日期(... 目录Java Calendar设置上个月时,日期不存在或错误提示java进行日期计算时如果出现不存在的

Mybatis对MySQL if 函数的不支持问题解读

《Mybatis对MySQLif函数的不支持问题解读》接手项目后,为了实现多租户功能,引入了Mybatis-plus,发现之前运行正常的SQL语句报错,原因是Mybatis不支持MySQL的if函... 目录MyBATis对mysql if 函数的不支持问题描述经过查询网上搜索资料找到原因解决方案总结Myb

Nginx错误拦截转发 error_page的问题解决

《Nginx错误拦截转发error_page的问题解决》Nginx通过配置错误页面和请求处理机制,可以在请求失败时展示自定义错误页面,提升用户体验,下面就来介绍一下Nginx错误拦截转发error_... 目录1. 准备自定义错误页面2. 配置 Nginx 错误页面基础配置示例:3. 关键配置说明4. 生效

Springboot3统一返回类设计全过程(从问题到实现)

《Springboot3统一返回类设计全过程(从问题到实现)》文章介绍了如何在SpringBoot3中设计一个统一返回类,以实现前后端接口返回格式的一致性,该类包含状态码、描述信息、业务数据和时间戳,... 目录Spring Boot 3 统一返回类设计:从问题到实现一、核心需求:统一返回类要解决什么问题?

maven异常Invalid bound statement(not found)的问题解决

《maven异常Invalidboundstatement(notfound)的问题解决》本文详细介绍了Maven项目中常见的Invalidboundstatement异常及其解决方案,文中通过... 目录Maven异常:Invalid bound statement (not found) 详解问题描述可

idea粘贴空格时显示NBSP的问题及解决方案

《idea粘贴空格时显示NBSP的问题及解决方案》在IDEA中粘贴代码时出现大量空格占位符NBSP,可以通过取消勾选AdvancedSettings中的相应选项来解决... 目录1、背景介绍2、解决办法3、处理完成总结1、背景介绍python在idehttp://www.chinasem.cna粘贴代码,出

SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)

《SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)》本文总结了SpringBoot项目整合Kafka启动失败的常见错误,包括Kafka服务器连接问题、序列化配置错误、依赖配置问题、... 目录一、Kafka服务器连接问题1. Kafka服务器无法连接2. 开发环境与生产环境网络不通二、序

SpringSecurity中的跨域问题处理方案

《SpringSecurity中的跨域问题处理方案》本文介绍了跨域资源共享(CORS)技术在JavaEE开发中的应用,详细讲解了CORS的工作原理,包括简单请求和非简单请求的处理方式,本文结合实例代码... 目录1.什么是CORS2.简单请求3.非简单请求4.Spring跨域解决方案4.1.@CrossOr

nacos服务无法注册到nacos服务中心问题及解决

《nacos服务无法注册到nacos服务中心问题及解决》本文详细描述了在Linux服务器上使用Tomcat启动Java程序时,服务无法注册到Nacos的排查过程,通过一系列排查步骤,发现问题出在Tom... 目录简介依赖异常情况排查断点调试原因解决NacosRegisterOnWar结果总结简介1、程序在

解决java.util.RandomAccessSubList cannot be cast to java.util.ArrayList错误的问题

《解决java.util.RandomAccessSubListcannotbecasttojava.util.ArrayList错误的问题》当你尝试将RandomAccessSubList... 目录Java.util.RandomAccessSubList cannot be cast to java.