line_search#
- scipy.optimize.line_search(f, myfprime, xk, pk, gfk=None, old_fval=None, old_old_fval=None, args=(), c1=0.0001, c2=0.9, amax=None, extra_condition=None, maxiter=10)[源代码]#
查找满足强 Wolfe 条件的 alpha。
- 参数:
- f可调用 f(x,*args)
目标函数。
- myfprime可调用 f’(x,*args)
目标函数梯度。
- xkndarray
起始点。
- pkndarray
搜索方向。搜索方向必须是算法收敛的下降方向。
- gfkndarray, 可选
x=xk 的梯度值(xk 是当前参数估计)。如果省略,则会重新计算。
- old_fvalfloat, 可选
x=xk 的函数值。如果省略,则会重新计算。
- old_old_fvalfloat, 可选
x=xk 前一个点的函数值。
- argstuple, 可选
传递给目标函数的其他参数。
- c1float, 可选
用于 Armijo 条件规则的参数。
- c2float, 可选
用于曲率条件规则的参数。
- amaxfloat, 可选
最大步长
- extra_condition可调用, 可选
一个形如
extra_condition(alpha, x, f, g)
的可调用对象,返回一个布尔值。参数是建议的步长alpha
和对应的x
、f
和g
值。仅当此可调用对象返回True
时,线搜索才会接受alpha
的值。如果可调用对象为步长返回False
,则算法将继续进行新的迭代。仅当迭代满足强 Wolfe 条件时,才会调用此可调用对象。- maxiterint, 可选
要执行的最大迭代次数。
- 返回:
- alphafloat 或 None
x_new = x0 + alpha * pk
的 alpha,如果线搜索算法未收敛,则返回 None。- fcint
函数评估的次数。
- gcint
梯度评估的次数。
- new_fvalfloat 或 None
新函数值
f(x_new)=f(x0+alpha*pk)
,如果线搜索算法未收敛,则返回 None。- old_fvalfloat
旧函数值
f(x0)
。- new_slopefloat 或 None
新值处沿搜索方向的局部斜率
<myfprime(x_new), pk>
,如果线搜索算法未收敛,则返回 None。
注释
使用线搜索算法来强制执行强 Wolfe 条件。请参阅 Wright 和 Nocedal 的 ‘数值优化’,1999 年,第 59-61 页。
搜索方向 pk 必须是下降方向(例如,
-myfprime(xk)
)才能找到满足强 Wolfe 条件的步长。如果搜索方向不是下降方向(例如,myfprime(xk)
),则 alpha、new_fval 和 new_slope 将为 None。示例
>>> import numpy as np >>> from scipy.optimize import line_search
定义了目标函数及其梯度。
>>> def obj_func(x): ... return (x[0])**2+(x[1])**2 >>> def obj_grad(x): ... return [2*x[0], 2*x[1]]
我们可以找到满足强 Wolfe 条件的 alpha。
>>> start_point = np.array([1.8, 1.7]) >>> search_gradient = np.array([-1.0, -1.0]) >>> line_search(obj_func, obj_grad, start_point, search_gradient) (1.0, 2, 1, 1.1300000000000001, 6.13, [1.6, 1.4])