跳转到内容

User:Gaussrz/BFGS算法

维基百科,自由的百科全书

这是本页的一个历史版本,由Gaussrz留言 | 贡献2021年5月12日 (三) 08:13 (通过翻译页面“Broyden–Fletcher–Goldfarb–Shanno algorithm”创建)编辑。这可能和当前版本存在着巨大的差异。

(差异) ←上一修订 | 最后版本 (差异) | 下一修订→ (差异)

数值优化中BFGS算法是一种求解无约束非线性优化问题的迭代算法[1]和相关的Davidon–Fletcher–Powell算法类似,BFGS通过利用曲率信息对梯度进行预处理来确定下降方向。曲率信息通过维护一个使用广义的割线法逐步近似的关于损失函数Hessian矩陣来获得。


算法

从起始点和初始的Hessian矩阵,重复以下步骤,会收敛到优化问题的解:

  1. 通过求解方程,获得下降方向
  2. 方向上进行一维的优化(线搜索),找到合适的步长。如果这个搜索是完全的,则在实际应用中,不完全的搜索一般就足够了,此时只要求满足Wolfe条件

表示要最小化的目标函数。可以通过检查梯度范数 来判断收敛性。如果初始化为,第一步将等效于梯度下降,但接下来的步骤会受到近似于Hessian矩阵的调节。

  [[Category:优化算法与方法]]

  1. ^ Fletcher, Roger, Practical Methods of Optimization 2nd, New York: John Wiley & Sons, 1987, ISBN 978-0-471-91547-8