bundles / scipy 1.17.1 / scipy / optimize / _bracket / _bracket_minimum
function
scipy.optimize._bracket:_bracket_minimum
source: /scipy/optimize/_bracket.py :495
Signature
def _bracket_minimum ( func , xm0 , * , xl0 = None , xr0 = None , xmin = None , xmax = None , factor = None , args = () , maxiter = 1000 ) Summary
Bracket the minimum of a unimodal scalar function of one variable
Extended Summary
This function works elementwise when xm0, xl0, xr0, xmin, xmax, and the elements of args are broadcastable arrays.
Parameters
func: callableThe function for which the minimum is to be bracketed. The signature must be
func(x: ndarray, *args) -> ndarraywhere each element of
xis a finite real andargsis a tuple, which may contain an arbitrary number of arrays that are broadcastable withx.funcmust be an elementwise function: each elementfunc(x)[i]must equalfunc(x[i])for all indicesi.xm0: float array_likeStarting guess for middle point of bracket.
xl0, xr0: float array_like, optionalStarting guesses for left and right endpoints of the bracket. Must be broadcastable with one another and with
xm0.xmin, xmax: float array_like, optionalMinimum and maximum allowable endpoints of the bracket, inclusive. Must be broadcastable with
xl0,xm0, andxr0.factor: float array_like, optionalControls expansion of bracket endpoint in downhill direction. Works differently in the cases where a limit is set in the downhill direction with
xmaxorxmin. See Notes.args: tuple, optionalAdditional positional arguments to be passed to
func. Must be arrays broadcastable withxl0,xm0,xr0,xmin, andxmax. If the callable to be bracketed requires arguments that are not broadcastable with these arrays, wrap that callable withfuncsuch thatfuncaccepts onlyxand broadcastable arrays.maxiter: int, optionalThe maximum number of iterations of the algorithm to perform. The number of function evaluations is three greater than the number of iterations.
Returns
res: _RichResultAn instance of scipy._lib._util._RichResult with the following attributes. The descriptions are written as though the values will be scalars; however, if
funcreturns an array, the outputs will be arrays of the same shape.xl,xm,xr
xl, xm, xr
fl,fm,fr
fl, fm, fr
nfev
nfev
nit
nit
status
status
success
success
Notes
Similar to scipy.optimize.bracket, this function seeks to find real points xl < xm < xr such that f(xl) >= f(xm) and f(xr) >= f(xm), where at least one of the inequalities is strict. Unlike scipy.optimize.bracket, this function can operate in a vectorized manner on array input, so long as the input arrays are broadcastable with each other. Also unlike scipy.optimize.bracket, users may specify minimum and maximum endpoints for the desired bracket.
Given an initial trio of points xl = xl0, xm = xm0, xr = xr0, the algorithm checks if these points already give a valid bracket. If not, a new endpoint, w is chosen in the "downhill" direction, xm becomes the new opposite endpoint, and either xl or xr becomes the new middle point, depending on which direction is downhill. The algorithm repeats from here.
The new endpoint w is chosen differently depending on whether or not a boundary xmin or xmax has been set in the downhill direction. Without loss of generality, suppose the downhill direction is to the right, so that f(xl) > f(xm) > f(xr). If there is no boundary to the right, then w is chosen to be xr + factor * (xr - xm) where factor is controlled by the user (defaults to 2.0) so that step sizes increase in geometric proportion. If there is a boundary, xmax in this case, then w is chosen to be xmax - (xmax - xr)/factor, with steps slowing to a stop at xmax. This cautious approach ensures that a minimum near but distinct from the boundary isn't missed while also detecting whether or not the xmax is a minimizer when xmax is reached after a finite number of steps.
Aliases
-
scipy.optimize._bracket._bracket_minimum