博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
梯度下降(Gradient descent)
阅读量:6458 次
发布时间:2019-06-23

本文共 2121 字,大约阅读时间需要 7 分钟。

梯度下降(Gradient descent

    在有监督学习中,我们通常会构造一个损失函数来衡量实际输出和训练标签间的差异。通过不断更新参数,来使损失函数的值尽可能的小。梯度下降就是用来计算如何更新参数使得损失函数的值达到最小值(可能是局部最小或者全局最小)。

梯度下降计算流程

 假设我们模型中的参数为,损失函数为,则计算过程为

         

 其中为学习率。通过不断求参数的偏导数来更新函数,直到(1)中的参数不在发生变化,就达到收敛状态。由于(1)的表达形式比较繁杂,因此可以简化如(3);其中(2)称作梯度

        

梯度下降数学解释

  梯度下降的目的就是为了更新参数使达到极小值。这个的过程如图1-1所示,①我们先随机初始化参数,就相当于在图1-1上任意取一点;②如果我们想要更新参数取到极小值的话,对于这一点可以寻找该点附近下降最快的方向,并沿着该方向移动一定距离;③移动距离后到达另外一个点,重复步骤②,直到该点没有可下降的方向,就取到极小值;

 

图1-1 梯度下降直观图

方向导数

 上述的步骤②中,我们需要在某个点找到其附近下降最快的方向,这就需要先讨论方向导数;偏导数反应的是函数沿坐标轴变化率。但是,有时候我们考虑函数沿某个方向的变化率。便于讨论,以方向向量代替方向。而向量的本质就是其在各个坐标轴(更严格点可以称作标准正交基)上的投影的值。因此,计算方向导数,可以转化为求解该方向向量在各个坐标轴上的投影的偏导数的总和。因此,对于函数f(x,y)在点p(x0,y0)可微分,那么函数在该点的任意方向的方向导数为

           

  其中为方向x轴的余弦值,为方向跟y轴的余弦值。

梯度

  方向导数是函数f(x,y)在点p(x0,y0)任意方向的变化率,而当在点的变化率取到最大值的方向就称为梯度,记作

            

  其中i=(1,0),j=(0,1);f(x,y)在梯度方向上取得变化率最大值的证明如下:

 对于(4)可以拆解成为两个向量的内积,设,则

         

 

  其中都为定值;a就是梯度(5),b为方向的单位向量,即b方向相同;当a,b方向相同时,,(6)取到最大值。因此,当方向向量与梯度相同时,f(x,y)在点p(x0,y0)的方向导数最大。

学习率

  学习率控制着梯度下降收敛的速度,甚至影响到你的函数能否取到极小值。假设学习率跟损失函数值的关系如图1-2所示,当学习率设置的刚刚好(红色线段),那么刚好能够取到极小值,而且迭代次数也不多;当学习率设置太小的话(蓝色线段),也能够取到极小值,只是迭代的次数就增加;而但你的学习率设置过大的话(绿色线段),由于步长太大,无论如何都取不到极小值。

 

图1-2 学习率跟损失函数值的关系 

当损失函数的参数为一维或者二维才能够可视化出图1-2,如果有多维的参数的话,是无法可视化。因此,可以可视化迭代次数跟损失函数值之间的关系图,如图1-3所示。

 

图1-3 迭代次数跟损失函数值

自适应学习率   

    在迭代的过程中,学习率不应该是一成不变的。因为在刚开始迭代的时候,初始点跟最终的极小值之间是有较远的距离,因此此时可以学习率可以设置的大一些。但是当快接近极小值时,就应该减小学习率,以避免步长过大,错过极小值;

    一种简单的学习率设置如(7),随着迭代次数增加,的值就越来越小

     

    虽然(7)可以使得学习率随着迭代次数增加而减少,但是更理想的情况应该是,对不同的参数,应该设置不同的学习率。

Adagrad

     Adagrad是将学习率的取值跟之前所有偏微分值的均方值的根号有关系。以单个参数为例,具体的计算如下

           

 

  其中,为(7);表示对的偏导数;表示将先前所有对参数的偏导数的平方进行累加,并求均值,最后再取根号;

随机梯度下降(Stochastic Gradient Descent

  在进行梯度下降时,我们构造的损失函数为(10),此时我们是将所有的样本都考虑进来,在进行参数更新。

    

  而随机梯度下降则是每次随机选择一个样本x,就对参数进行更新。对应的损失函数为

     

  采用随机梯度下降的话,参数的更新速度会更快一些。假设我们有20个样本,那么对于随机梯度下降则是选择一个样本就更新一次参数,选择完20个样本也就更新20次;对于梯度下降的话,构造(10)就是构造20个(11),并将20个(11)进行累加,再进行参数更新,选择20个样本只完成一次更新。   

特征缩放(Feature Scaling

    不同的特征的取值范围往往是不同的,因此特征的取值变化对最终的输出结果也有不一样的效果。以(12)为例,若,显然y的取值受x2的影响更多;但如果实际中x1才是最重要的特征,就会导致最终的拟合效果不佳。

   

 不同的特征变化范围也会影响梯度下降的收敛速度,如图1-4。由于不同特征的取值范围就导致不同的参数应该采用不同的参数,否则收敛就会有难度;而将特征进行相同特征处理后,这个损失函数等高线呈圆形,采用相同的参数也可以完成收敛。

 

图1-4 特征缩放对收敛的影响

均值归一化

  对于单个特征来说,计算如下

   

 其中为的X均值,s为X的标准差(Standard Deviation 

参考资料

 

转载于:https://www.cnblogs.com/MrPan/p/9495016.html

你可能感兴趣的文章
我的毕设总结所用的技术和只是要点 基于stm32F4的AGV嵌入式控制系统的设计
查看>>
JMeter—断言
查看>>
C++的新类创建:继承与组合
查看>>
odoo 权限设置
查看>>
asp操作access提示“无法从指定的数据表中删除”
查看>>
git bash 风格调整
查看>>
bzoj4589 Hard Nim
查看>>
java实现pdf旋转_基于Java实现PDF文本旋转倾斜
查看>>
python time库3.8_python3中datetime库,time库以及pandas中的时间函数区别与详解
查看>>
贪吃蛇java程序简化版_JAVA简版贪吃蛇
查看>>
poi java web_WebPOI JavaWeb 项目 导出excel表格(.xls) Develop 238万源代码下载- www.pudn.com...
查看>>
linux 脚本map,Linux Shell Map的用法详解
查看>>
如何在linux系统下配置共享文件夹,如何在windows和Linux系统之间共享文件夹.doc
查看>>
linux操作系统加固软件,系统安全:教你Linux操作系统的安全加固
查看>>
linux中yum源安装dhcp,24.Linux系统下动态网络源部署方法(dhcpd)
查看>>
ASP.NET性能优化之分布式Session
查看>>
转载:《TypeScript 中文入门教程》 16、Symbols
查看>>
JavaScript、jQuery、HTML5、Node.js实例大全-读书笔记4
查看>>
C#技术------垃圾回收机制(GC)
查看>>
漫谈并发编程(三):共享受限资源
查看>>