Mathematica 9 is now available
THIS IS DOCUMENTATION FOR AN OBSOLETE PRODUCT.
SEE THE DOCUMENTATION CENTER FOR THE LATEST INFORMATION.
Mathematica > Mathematics and Algorithms > Optimization >

FindArgMax

FindArgMax[f, x]
gives the position xmax of a local maximum of f.
FindArgMax[f, {x, x0}]
gives the position xmax of a local maximum of f, found by a search starting from the point x=x0.
FindArgMax[f, {{x, x0}, {y, y0}, ...}]
gives the position {xmax, ymax, ...} of a local maximum of a function of several variables.
FindArgMax[{f, cons}, {{x, x0}, {y, y0}, ...}]
gives the position of a local maximum subject to the constraints cons.
FindArgMax[{f, cons}, {x, y, ...}]
starts from a point within the region defined by the constraints.
  • If the starting point for a variable is given as a list, the values of the variable are taken to be lists with the same dimensions.
  • cons can contain equations, inequalities or logical combinations of these.
  • FindArgMax first localizes the values of all variables, then evaluates f with the variables being symbolic, and then repeatedly evaluates the result numerically.
  • FindArgMax[f, {x, x0, x1}] searches for a local maximum in f using x0 and x1 as the first two values of x, avoiding the use of derivatives.
  • FindArgMax[f, {x, x0, xmin, xmax}] searches for a local maximum, stopping the search if x ever gets outside the range xmin to xmax.
  • Except when f and cons are both linear, the results found by FindArgMax may correspond only to local, but not global, maxima.
  • By default, all variables are assumed to be real.
  • For linear f and cons, xElementIntegers can be used to specify that a variable can take on only integer values.
Find a point {x} at which the univariate function -2x^2-3x+5 has a maximum:
Find a point {x, y} at which the function Sin[x]Sin[2y] has a maximum:
Find a point at which a function is a maximum subject to constraints:
Find a point {x} at which the univariate function -2x^2-3x+5 has a maximum:
In[1]:=
Click for copyable input
Out[1]=
 
Find a point {x, y} at which the function Sin[x]Sin[2y] has a maximum:
In[1]:=
Click for copyable input
Out[1]=
 
Find a point at which a function is a maximum subject to constraints:
In[1]:=
Click for copyable input
Out[1]=
With different starting points, get the locations of different local maxima:
Location of a local maximum of a two-variable function starting from x=2, y=2:
Location of a local maximum constrained within a disk:
Starting point does not have to be provided:
For linear objective and constraints, integer constraints can be imposed:
Or constraints can be specified:
This enforces convergence criteria ||x_k-x^*|| <= max(10^(-9),10^(-8)||x_k||) and ▽f(x_k)<=10^(-9):
This enforces convergence criteria ||x_k-x^*|| <= max(10^(-20),10^(-18)||x_k||) and ▽f(x_k)<=10^(-20):
Setting a high WorkingPrecision makes the process convergent:
Plot convergence to the local maximum:
Use a given gradient; the Hessian is computed automatically:
Supply both gradient and Hessian:
In this case the default derivative-based methods have difficulties:
Direct search methods which do not require derivatives can be helpful in these cases:
NMaximize also uses a range of direct search methods:
Steps taken by FindArgMax in finding the maximum of a function:
Set the working precision to 20; by default AccuracyGoal and PrecisionGoal are set to :
FindMaximum gives both the value of the maximum and the maximizer point:
FindArgMax gives the location of the maximum:
FindMaxValue gives the value at the maximum:
If the constraint region is empty, the algorithm will not converge:
If the maximum value is not finite, the algorithm will not converge:
Integer linear programming algorithm is only available for machine-number problems:
Sometimes providing a suitable starting point can help the algorithm to converge:
New in 7
Ask a question about this page  |  Suggest an improvement  |  Leave a message for the team