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.
Details and Options
data:image/s3,"s3://crabby-images/080d9/080d9cd772a6f0cc2c210d657e745e7289cf5217" alt=""
data:image/s3,"s3://crabby-images/cd828/cd82897e978c49546f9644e150dbd57deebf3b38" alt=""
- FindArgMax[…,{x,y,…}] is effectively equivalent to {x,y,…}/.Last[FindMaximum[…,{x,y,…},…].
- 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.
- The constraints cons can be any logical combination of:
-
lhs==rhs equations lhs>rhs or lhs>=rhs inequalities {x,y,…}∈reg region specification - FindArgMax first localizes the values of all variables, then evaluates f with the variables being symbolic, and then repeatedly evaluates the result numerically.
- FindArgMax has attribute HoldAll, and effectively uses Block to localize variables.
- 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, x∈Integers can be used to specify that a variable can take on only integer values.
- FindArgMax takes the same options as FindMaximum.
List of all options
data:image/s3,"s3://crabby-images/5739d/5739d9a625e3897f8b00b67456629ee0f1076a45" alt=""
Examples
open allclose allBasic Examples (4)
Scope (12)
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:
Find points in two regions realizing the maximum distance:
Find the maximum such that the rectangle and ellipse still intersect:
Find the maximum for which
contains the given three points:
Use to specify that
is a vector in
:
Options (7)
AccuracyGoal & PrecisionGoal (2)
This enforces convergence criteria and
:
This enforces convergence criteria and
:
data:image/s3,"s3://crabby-images/e3f27/e3f2781327aec37d4b03595ae7dac5544811d9b3" alt=""
Setting a high WorkingPrecision makes the process convergent:
Gradient (1)
Method (1)
In this case the default derivative-based methods have difficulties:
data:image/s3,"s3://crabby-images/99fef/99fefe4bf6af2d66a6209e34c0dc5665d2bed35b" alt=""
data:image/s3,"s3://crabby-images/7ce9d/7ce9d8fd89ad5fa0d04b770567758eb0ae290b4a" alt=""
Direct search methods that do not require derivatives can be helpful in these cases:
NMaximize also uses a range of direct search methods:
StepMonitor (1)
Steps taken by FindArgMax in finding the maximum of a function:
WorkingPrecision (1)
Set the working precision to ; by default AccuracyGoal and PrecisionGoal are set to
:
Properties & Relations (1)
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:
Possible Issues (4)
If the constraint region is empty, the algorithm will not converge:
data:image/s3,"s3://crabby-images/03f90/03f90b7d60fcf7ff63bfde0df0df01d8500d0551" alt=""
If the maximum value is not finite, the algorithm will not converge:
data:image/s3,"s3://crabby-images/cf78a/cf78a78408b48a9cdc63db387c7aaaa79339aea2" alt=""
data:image/s3,"s3://crabby-images/8fdbf/8fdbf267580fd0df3b5b356750e12e4c9dff3f67" alt=""
Integer linear programming algorithm is only available for machine-number problems:
data:image/s3,"s3://crabby-images/0e9bd/0e9bd1c72cd76584b9b07830ea8ac7ae9da3336e" alt=""
Sometimes providing a suitable starting point can help the algorithm to converge:
data:image/s3,"s3://crabby-images/5d31d/5d31d0ef0fc806b8db3ae0af70ca8abbb6ce1964" alt=""
Text
Wolfram Research (2008), FindArgMax, Wolfram Language function, https://reference.wolfram.com/language/ref/FindArgMax.html (updated 2014).
CMS
Wolfram Language. 2008. "FindArgMax." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 2014. https://reference.wolfram.com/language/ref/FindArgMax.html.
APA
Wolfram Language. (2008). FindArgMax. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/FindArgMax.html