Optimize Live Editor Task withfmincon
Solver
This example shows how to use the solver-basedOptimizeLive Editor task with thefmincon
solver to minimize a quadratic subject to linear and nonlinear constraints and bounds.
Consider the problem of finding [x1,x2] that solves
subject to the constraints
The starting pointx0
for this problem isx1= 3 andx2= 1.
Start Optimize Live Editor Task
Create a new live Script by clicking theNew Live Scriptbutton in theFilesection on theHometab.
Insert anOptimizeLive Editor task. Click theInserttab and then, in theCodesection, selectTask > Optimize.
For this example, choose the solver-based task.
For later use in entering problem data, selectInsert > Section Break. New sections appear above and below the task.
Enter Problem Data
Starting from the top of the task, enter the problem type and constraint types. Click theObjective > Quadraticbutton and theConstraints > Lower bounds,Linear inequality, andNonlinearbuttons. The task shows that the recommended solver is
fmincon
.目标函数
我们的目标function is simple enough to represent as an anonymous function. Position the cursor in the section above the task and enter this code.
fun = @(x)sum(x.^2);
Lower Bound
The problem contains the lower boundx1≥ 0.5. Express this bound as a variable
lb
. With the cursor at the end of the line defining the objective function, pressEnter, and enter the following code to specify the lower bound.lb = [0.5 -Inf];
Initial Point
With the cursor at the end of the line defining the lower bound, pressEnter, and enter the following code to set the initial point.
x0 = [3,1];
Linear Constraint
With the cursor at the end of the line defining the initial point, pressEnter, and enter the following code to set the linear constraint.
A = [-1,-1]; b = -1;
Run Section
The top section now includes five parameters.
Next, you need to run the section to place the parameters in the workspace as variables. To do so, click the left-most area of the section, which contains a bar of diagonal stripes. After you click this area, the bar becomes a solid bar, indicating the variables are now in the workspace. (Note: You can also pressCtrl+Enterto run the section.)
Set Problem Data
Enter the variables in theSelect problem datasection of the task. To specify the objective function, selectObjective function > Function handleand choosefun.
Set the initial pointx0.
Select下界>从工作区and selectlb.
Set the linear inequality constraint variables
A
andb
in theLinear inequalityarea.Now specify the nonlinear inequality constraints. In theSelect problem datasection, selectNonlinear > Local function, and then click theNewbutton. The function appears in a new section below the task. Edit the resulting code to contain the following uncommented lines.
function[c,ceq] = constraintFcn(x)% You can include commented code lines or not.% Be sure that just these uncommented lines remain:c = [-x(1)^2 - x(2)^2 + 1; -9*x(1)^2 - x(2)^2 + 9; -x(1)^2 + x(2); -x(2)^2 + x(1)]; ceq = [];end
In theSelect problem datasection, select theconstraintFcnfunction.
监测进展
In theDisplay progresssection of the task, selectText display > Each iterationso you can monitor the solver progress. SelectObjective valuefor the plot.
Your setup looks like this:
Run Solver and Examine Results
To run the solver, click the options button⁝at the top right of the task window, and selectRun Section.
The plot appears in a separate figure window and in the task output area.
To see where the solution variables are returned, look at the top of the task.
The final point and its associated objective function value appear in thesolution
andobjectiveValue
variables in the workspace. View these values by entering this code in the live editor section below the task.
solution, objectiveValue
PressCtrl+Enterto run the section.