首页 > 其他 > 详细

Backtracking line search的理解

时间:2015-12-05 15:51:14      阅读:477      评论:0      收藏:0      [点我收藏+]

使用梯度下降方法求解凸优化问题的时候,会遇到一个问题,选择什么样的梯度下降步长才合适。

假设优化函数为技术分享,若每次梯度下降的步长都固定,则可能出现左图所示的情况,无法收敛。若每次步长都很小,则下降速度非常慢,需要很多轮的迭代,如右图所示。所以步长的选择和收敛速度是一个取舍关系。

技术分享 技术分享

于是,有了一种可调节步长的解法,称为backtracking line search。

假设我们当前的位置为Xc 并且要在d方向上寻找更优的解,那么问题就变为了估计Φ(t)的最小值,t是步长。

技术分享 技术分享

关于P的新的解是技术分享。那么怎么来估计这个步长呢?(直接把课件的幻灯片贴上来了)

技术分享

技术分享

也就是说,设f(x)在Xc的导数技术分享,再设两个变量r和c∈(0, 1).

因为r∈(0, 1),所以rv随着v的增大而趋向于0,也就是步长t逐渐减小,直到找到满足技术分享条件的rv。之前已经设定了技术分享,所以必定有技术分享技术分享

课件里给出了一段Matlab的伪代码,翻译过来差不多就是这样

function t = BLS(f,d,x,r,c)
% Backtracking line search
% Input :
% f: MATLAB file that returns function value
% d: The search direction
% x: current x
% r : backtrack step between (0,1) usually 1/2
% c: (0,1) usually 10^{-4}
% Output :
% t: adaptive step length


[fc, gc] = feval(f,x);
xc = x;
x = xc + t*d;
fk1 = feval(f,x);
t = 1;
while fk1 > fk + c*t*(gk*d)
t= t*r;
x
= xc + t*d;
fk1
= feval(f,x);
end

最后,课件里给出了寻找方向d的几种方法

技术分享

 

参考资料:

http://www.stat.cmu.edu/~ryantibs/convexopt/lectures/05-grad-descent.pdf

https://www.math.washington.edu/~burke/crs/408/lectures/L7-line-search.pdf

 

Backtracking line search的理解

原文:http://www.cnblogs.com/naive/p/5021527.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!