梯度下降(Gradient Descent)法

梯度下降法(Gradient Descent)是求解无约束最优化问题最常用的方法之一,它是一种迭代方法,每一步的主要操作就是求解目标函数的梯度向量,将当前位置的负梯度方向作为搜索方向。
直观的表示可用下图来表示:

这里每一个圈代表一个函数梯度,最中心表示函数极值点,每次迭代根据当前位置求得的梯度(用于确定搜索方向以及与步长共同决定前进速度)和步长找到一个新的位置,这样不断迭代最终到达目标函数局部最优点(如果目标函数是凸函数,则到达全局最优点)。
梯度下降法其本质就是在不停的求偏导、更新损失函数,直至收敛
1、 梯度
梯度向量求出来有什么意义???从几何意义来讲,就是函数变化增加最快的地方。具体来说,对于函数f(x,y),在点((x_0,y_0))沿梯度向量的方向就是((frac{partial f}{partial x_0},frac{partial f}{partial y_0})^T)的方向是f(x,y)增加最快的地方。或者说,沿着梯度向量的方向,更容易找到函数的最大值。反过来说,沿着梯度向量相反的方向,也就是(-(frac{partial f}{partial x_0},frac{partial f}{partial y_0})^T)的方向,梯度减少最快,也就是更容易找到函数的最小值。
2、梯度下降和梯度上升
在机器学习算法中,在最小化损失函数时,可以通过梯度下降法来一步步的迭代求解,得到最小化的损失函数,和模型参数值。反过来,如果我们需要求解损失函数的最大值,这时就需要用梯度上升法来迭代了。
梯度下降法和梯度上升法是可以互相转化的。比如我们需要求解损失函数f(θ)的最小值,这时我们需要用梯度下降法来迭代求解。但是实际上,我们可以反过来求解损失函数 -f(θ)的最大值,这时梯度上升法就派上用场了。
3、梯度下降算法详解
3.1 梯度下降的直观理解
首先来看看梯度下降的一个直观的解释。比如我们在一座大山上的某处位置,由于我们不知道怎么下山,于是决定走一步算一步,也就是在每走到一个位置的时候,求解当前位置的梯度,沿着梯度的负方向,也就是当前最陡峭的位置向下走一步,然后继续求解当前位置梯度,向这一步所在位置沿着最陡峭最易下山的位置走一步。这样一步步的走下去,一直走到觉得我们已经到了山脚。当然这样走下去,有可能我们不能走到山脚,而是到了某一个局部的山峰低处。
从上面的解释可以看出,梯度下降不一定能够找到全局的最优解,有可能是一个局部最优解。当然,如果损失函数是凸函数,梯度下降法得到的解就一定是全局最优解。

3.2 梯度下降的相关概念

  1. 步长(learning rate):步长决定梯度下降过程中,每一步沿梯度负方向前进的长度。用上面下山的例子,步长就是在当前这一步所在位置沿着最陡峭最易下山的位置走的那一步的长度。
  2. 特征(feature):指样本中输入部分,比如2个单特征的样本((x^{(0)},y^{(0))}),(x^{(1)},y^{(1))})),则第一个样本特征为(x^{(0)}),第一个样本输出为(y^{(0)})
  3. 假设函数(hypothesis function):在监督学习中,为了拟合输入样本,而使用的假设函数,记为(h_ heta(x))。比如对于单个特征的m个样本((x^{(i)},y^{(i)})(i = 1,2,...,m))可以采用拟合函数如下:(h_ heta(x)= heta_0+ heta_1x。)
  4. 损失函数(loss function):为评估模型拟合的好坏,通常用损失函数来度量拟合的程度。损失函数极小化,意味着拟合程度最好,对应的模型参数即为最优参数。在线性回归中,损失函数通常为样本输出和假设函数的差取平方。比如对于m个样本((x_i,y_i)(i=1,2,3...,m)),采用线性回归,损失函数为:

[J( heta_0, heta_1)=sum_{i=1}^m(h_ heta(x_i)-y_i)^2 ]

其中,(x_i表示第i个样本特征,y_i表示第i个样本对应的输出,h_ heta(x_i))为假设函数
3.3 梯度下降的详细算法
梯度下降法的代数方法描述

1、先决条件:确定优化模型的假设函数和损失函数

比如对于线性回归,假设函数表示为:(h_ heta(x_1, x_2, ...x_n) = heta_0 + heta_{1}x_1 + ... + heta_{n}x_{n}),其中>>( heta_i(i=0,1,2,...,n))为模型参数,(x_i(i=0,1,2...,n))为每个样本的n个特征值,增加一个特征(x_0=1),可简化为:

[h_ heta(x_0, x_1, ...x_n) = sumlimits_{i=0}^{n} heta_{i}x_{i} ]

对应于上面的假设函数,损失函数为:

[J( heta_0, heta_1..., heta_n) = frac{1}{2m}sumlimits_{j=0}^{m}(h_ heta(x_0^{(j)}, x_1^{(j)}, ...x_n^{(j)}) - y_j)^2 ]

2、算法相关参数初始化:主要是初始化( heta_0, heta_1..., heta_n),算法终止距离(varepsilon)以及步长(alpha)。在没有任何先验知识的时候,喜欢将所有的( heta)初始化为0,将步长初始化为1,。在调优的时候再优化。
3、算法过程:

1) 确定当前位置的损失函数的梯度,对于( heta_i)其梯度表达式为:

[frac{partial}{partial heta_i}J( heta_0, heta_1..., heta_n) ]

  1. 用步长乘以损失函数的梯度,得到当前下降的距离,即(alphafrac{partial}{partial heta_i}J( heta_0, heta_1..., heta_n))对应于前面登山例子中的某一步。
  2. 确定是否所有的(θ_i),梯度下降的距离都小于ε,如果小于ε则算法终止,当前所有的(θ_i(i=0,1,...n))即为最终结果。否则进入步骤4.
  3. 更新所有的θ,对于(θ_i),其更新表达式如下。更新完毕后继续转入步骤1.

[ heta_i = heta_i - alphafrac{partial}{partial heta_i}J( heta_0, heta_1..., heta_n) ]

以线性回归为例来具体描述梯度下降。

假设样本是:((x_1^{(0)},x_2^{(0)},...x_n^{(0)},y_0),(x_1^{(1)}, x_2^{(1)},...x_n^{(1)},y_1),...(x_1^{(m)},x_2^{(m)}, ...x_n^{(m)}, y_m))
损失函数如前面先决条件所讲的:(J( heta_0, heta_1..., heta_n)=frac{1}{2m}sumlimits_{j=0}^{m}(h_ heta(x_0^{(j)},x_1^{(j)}, ...x_n^{(j)})- y_j)^2)
则在算法过程步骤1中对于(θ_i) 的偏导数计算如下

[frac{partial}{partial heta_i}J( heta_0, heta_1..., heta_n)=frac{1}{m}sumlimits_{j=0}^{m}(h_ heta(x_0^{(j)}, x_1^{(j)}, ...x_n^{(j)}) - y_j)x_i^{(j)} ]

由于样本中没有x0上式中令所有的(x^j_0)为1.
步骤4中的( heta_i)的更新表达式如下:

[ heta_i= heta_i-alphafrac{1}{m}sumlimits_{j=0}^{m}(h_ heta(x_0^{(j)},x_1^{(j)}, ...x_n^{j}) - y_j)x_i^{(j)} ]

从这个例子可以看出当前点的梯度方向是由所有的样本决定的,加(frac{1}{m}) 是为了好理解。由于步长也为常数,他们的乘机也为常数,所以这里>(alphafrac{1}{m})可以用一个常数表示。
梯度下降法的矩阵方式描述

  1. 先决条件: 和3.3.1类似,需要确认优化模型的假设函数和损失函数。

对于线性回归,假设函数(h_ heta(x_1, x_2, ...x_n)= heta_0+ heta_{1}x_1+...+ heta_{n}x_{n})的矩阵表达式是:

[h_mathbf{ heta}(mathbf{X})=mathbf{X heta} ]

其中,假设函数(h_mathbf{ heta}(mathbf{X}))为m x 1的向量,里面有n+1个代数法的模型参数。X为mx(n+1)维的矩阵。m代表样本的个数,n+1代表样本的特征数。
损失函数表达式为:(J(mathbf heta)=frac{1}{2}(mathbf{X heta}-mathbf{Y})^T(mathbf{X heta}-mathbf{Y})),其中Y是样本的输出向量,,维度为mx1

  1. 算法相关参数初始化:和代数法一样
  2. 算法过程:
  1. 确定当前位置的损失函数的梯度,对于( heta)向量,其梯度表达式如下:

[frac{partial}{partialmathbf heta}J(mathbf heta) ]

  1. 用步长乘以损失函数的梯度,得到当前位置下降的距离,即(alphafrac{partial}{partial heta}J( heta))对于前面登山例子中的某一步
  2. 确定( heta)向量里面的每个值,梯度下降的距离都小于(varepsilon),如果小于(varepsilon)则算法停止,当前( heta)向量即为最终结果。否则进入第4步
  3. 更新( heta)向量,其更新表达式如下。更新完毕后继续转步骤1

[mathbf heta=mathbf heta-alphafrac{partial}{partial heta}J(mathbf heta) ]

以线性回归为例:

损失函数对于( heta)向量的偏导数计算如下:

[frac{partial}{partialmathbf heta}J(mathbf heta)=mathbf{X}^T(mathbf{X heta}-mathbf{Y}) ]

步骤4中θ向量的更新表达式如下:

[mathbf heta=mathbf heta-alphamathbf{X}^T(mathbf{X heta}-mathbf{Y}) ]

这里面用到了矩阵求导链式法则,和两个个矩阵求导的公式。

[公式1:frac{partial}{partialmathbf{x}}(mathbf{x^Tx}) =2mathbf{x};;x为向量 ]

[公式2: abla_Xf(AX+B) = A^T abla_Yf,;; Y=AX+B,;;f(Y)为标量 ]

3.4 梯度下降的算法调优

在使用梯度下降时,需要进行调优。哪些地方需要调优呢?

  1. 算法步长选择。
  2. 算法参数的初始值选择。
  3. 归一化。于样本不同特征的取值范围不一样,可能导致迭代很慢,为了减少特征取值的影响,可以对特征数据归一化,也就是对于每个特征x,求出它的期望(overline{x})和标准差std(x),然后转化为:

[frac{x - overline{x}}{std(x)} ]

这样特征的新期望为0,新方差为1,迭代速度可以大大加快。

4 梯度下降大家族(BGD,SGD,MBGD)
4.1 批量梯度下降法(Batch Gradient Descent)
批量梯度下降法,是梯度下降法最常用的形式,具体做法也就是在更新参数时使用所有的样本来进行更新,这个方法对应于前面3.3.1的线性回归的梯度下降算法,也就是说3.3.1的梯度下降算法就是批量梯度下降法。 

[ heta_i= heta_i-alphasumlimits_{j=1}^{m}(h_ heta(x_0^{(j)},x_1^{(j)},...x_n^{(j)})-y_j)x_i^{(j)} ]

由于我们有m个样本,这里求梯度的时候就用了所有m个样本的梯度数据。
4.2 随机梯度下降法(Stochastic Gradient Descent)
随机梯度下降法,其实和批量梯度下降法原理类似,区别在与求梯度时没有用所有的m个样本的数据,而是仅仅选取一个样本j来求梯度。对应的更新公式是:

[ heta_i= heta_i-alpha(h_ heta(x_0^{(j)},x_1^{(j)},...x_n^{(j)})-y_j)x_i^{(j)} ]

随机梯度下降法,和4.1的批量梯度下降法是两个极端,一个采用所有数据来梯度下降,一个用一个样本来梯度下降。自然各自的优缺点都非常突出。对于训练速度来说,随机梯度下降法由于每次仅仅采用一个样本来迭代,训练速度很快,而批量梯度下降法在样本量很大的时候,训练速度不能让人满意。对于准确度来说,随机梯度下降法用于仅仅用一个样本决定梯度方向,导致解很有可能不是最优。对于收敛速度来说,由于随机梯度下降法一次迭代一个样本,导致迭代方向变化很大,不能很快的收敛到局部最优解。
那么,有没有一个中庸的办法能够结合两种方法的优点呢?有!这就是小批量梯度下降法。
4.3 小批量梯度下降法(Mini-batch Gradient Descent)
小批量梯度下降法是批量梯度下降法和随机梯度下降法的折衷,也就是对于m个样本,我们采用x个样子来迭代,1<x<m。一般可以取x=10,当然根据样本的数据,可以调整这个x的值。对应的更新公式是:

[ heta_i= heta_i-alphasumlimits_{j=t}^{t+x-1}(h_ heta(x_0^{(j)},x_1^{(j)},...x_n^{(j)})-y_j)x_i^{(j)} ]

5 梯度下降法和其他无约束优化算法的比较
在机器学习中的无约束优化算法,除了梯度下降以外,还有前面提到的最小二乘法,此外还有牛顿法和拟牛顿法。
梯度下降法和最小二乘法相比,梯度下降法需要选择步长,而最小二乘法不需要。梯度下降法是迭代求解,最小二乘法是计算解析解。如果样本量不算很大,且存在解析解,最小二乘法比起梯度下降法要有优势,计算速度很快。但是如果样本量很大,用最小二乘法由于需要求一个超级大的逆矩阵,这时就很难或者很慢才能求解解析解了,使用迭代的梯度下降法比较有优势。
梯度下降法和牛顿法/拟牛顿法相比,两者都是迭代求解,不过梯度下降法是梯度求解,而牛顿法/拟牛顿法是用二阶的海森矩阵的逆矩阵或伪逆矩阵求解。相对而言,使用牛顿法/拟牛顿法收敛更快。但是每次迭代的时间比梯度下降法长。

参考:https://www.cnblogs.com/pinard/p/5970503.html

原文地址:https://www.cnblogs.com/whiteBear/p/12727080.html