MATLAB API - Solving a Model#
- gurobi(model)#
- gurobi(model, params)#
- This function optimizes the given model. The algorithm used for the optimization depends on the model type (simplex or barrier for a continuous model; branch-and-cut for a MIP model). Upon successful completion it will return a - structvariable containing solution information.- Please consult Variables and Constraints section in the reference manual for a discussion of some of the practical issues associated with solving a precisely defined mathematical model using finite-precision floating-point arithmetic. - Parameters:
- Example:
- result = gurobi(model, params); if strcmp(result.status, 'OPTIMAL'); fprintf('Optimal objective: %e\n', result.objval); disp(result.x) else fprintf('Optimization returned status: %s\n', result.status); end 
- Returns:
- The optimization result - The - gurobifunction returns a- struct, with the various results of the optimization stored in its fields. The specific results that are available depend on the type of model that was solved, the parameters used, and the status of the optimization. The following is a list of fields that might be available in the returned result. We will discuss the circumstances under which each will be available after presenting the list.- Model fields - status
- The status of the optimization, returned as a string. The desired result is OPTIMAL, which indicates that an optimal solution to the model was found. Other status are possible, for example if the model has no feasible solution or if you set a Gurobi parameter that leads to early solver termination. See the Status Code section for further information on the Gurobi status codes. 
- objval
- The objective value of the computed solution. Note that for multi-objective models - result.objvalwill be a vector, where- result.objval(i)stores the value for- model.multiobj(i).
- objbound
- Best available bound on solution (lower bound for minimization, upper bound for maximization). 
- objboundc
- The best unrounded bound on the optimal objective. In contrast to - objbound, this attribute does not take advantage of objective integrality information to round to a tighter bound. For example, if the objective is known to take an integral value and the current best bound is 1.5,- objboundwill return 2.0 while- objboundcwill return 1.5.
- mipgap
- Current relative MIP optimality gap; computed as \(\vert ObjBound-ObjVal\vert/\vert ObjVal\vert\) (where \(ObjBound\) and \(ObjVal\) are the MIP objective bound and incumbent solution objective, respectively). Returns - GRB_INFINITYwhen an incumbent solution has not yet been found, when no objective bound is available, or when the current incumbent objective is 0. This is only available for mixed-integer problems.
- runtime
- The elapsed wall-clock time (in seconds) for the optimization. 
- work
- The work (in work units) spent on the optimization. As opposed to the runtime in seconds, the work is deterministic. This means that on the same hardware and with the same parameter and attribute settings, solving the same model twice will lead to exactly the same amount of work in each of the two solves. One work unit corresponds very roughly to one second, but this greatly depends on the hardware on which Gurobi is running and on the model that has been solved. 
- itercount
- Number of simplex iterations performed. 
- baritercount
- Number of barrier iterations performed. 
- nodecount
- Number of branch-and-cut nodes explored. 
- maxvio
- Value of the maximal (unscaled) violation of the returned solution. 
- farkasproof
- Magnitude of infeasibility violation in Farkas infeasibility proof. Only available if the model was found to be infeasible. Please refer to Attribute section in the reference manual for details. 
 - Variable fields - x
- The computed solution. This vector contains one entry for each column of - A.
- rc
- Variable reduced costs for the computed solution. This vector contains one entry for each column of - A.
- vbasis
- Variable basis status values for the computed optimal basis. You generally should not concern yourself with the contents of this vector. If you wish to use an advanced start later, you would simply copy the - vbasisand- cbasisfields into the corresponding fields for the next model. This vector contains one entry for each column of- A.
- unbdray
- Unbounded ray. Provides a vector that, when added to any feasible solution, yields a new solution that is also feasible but improves the objective. Only available if the model is found to be unbounded. This vector contains one entry for each column of - A.
 - Linear constraint fields - slack
- The constraint slack for the computed solution. This vector contains one entry for each row of - A.
- pi
- Dual values for the computed solution (also known as shadow prices). This vector contains one entry for each row of - A.
- cbasis
- Constraint basis status values for the computed optimal basis. This vector contains one entry for each row of - A.
- farkasdual
- Farkas infeasibility proof. Only available if the model was found to be infeasible. Please refer to Attribute section in the reference manual for details. 
 - Quadratic constraint fields - qcslack
- The quadratic constraint slack in the current solution. This vector contains one entry for each quadratic constraint. 
- qcpi
- The dual values associated with the quadratic constraints. This vector contains one entry for each quadratic constraint. 
 - Solution Pool fields - pool
- When multiple solutions are found during the optimization call, these solutions are returned in this field. A struct array. When present, each struct has the following fields: - objval
- Stores the objective value of the \(i\)-th solution in - result.pool(i).objval. Note that when the model is a multi-objective model, instead of a single value,- result.pool(i).objval(j)stores the value of the \(j\)-th objective function for the \(i\)-th solution.
- xn
- Stores the \(i\)-th solution in - result.pool(i).xn. This vector contains one entry for each column of- A.
 - Note that to query the number of solutions stored, you can query the length of - result.pool.
- poolobjbound
- For single-objective MIP optimization problems, this value gives a bound on the best possible objective of an undiscovered solution. The difference between this value and - objboundis that the former gives an objective bound for undiscovered solutions, while the latter gives a bound for any solution.
 - What is Available When - The - statusfield will be present in all cases. It indicates whether Gurobi was able to find a proven optimal solution to the model. In cases where a solution to the model was found, optimal or otherwise, the- objvaland- xfields will be present.- For linear and quadratic programs, if a solution is available, then the - piand- rcfields will also be present. For models with quadratic constraints, if the parameter- qcpdualis set to 1, the field- qcpiwill be present. If the final solution is a basic solution (computed by simplex), then- vbasisand- cbasiswill be present. If the model is an unbounded linear program and the InfUnbdInfo parameter is set to 1, the field- unbdraywill be present. Finally, if the model is an infeasible linear program and the InfUnbdInfo parameter is set to 1, the fields- farkasdualand- farkasproofwill be set.- For mixed integer problems, no dual information (i.e. - pi,- slack,- rc,- vbasis,- cbasis,- qcslack,- qcpi,- ubdrayor- farkasdual) is ever available. When multiple solutions are found, the- pooland- poolobjboundfields will be present. Depending on the- statusfield value, the fields- nodecount,- objbound,- objbundcand- mipgapwill be available.- For continuous and mixed-integer models, under normal execution, the fields - runtime,- work,- itercountand- baritercountwill be available.
 
- gurobi_iis(model)#
- gurobi_iis(model, params)#
- Compute an Irreducible Inconsistent Subsystem (IIS). - An IIS is a subset of the constraints and variable bounds with the following properties: - It is still infeasible, and 
- If a single constraint or bound is removed, the subsystem becomes feasible. 
 - Note that an infeasible model may have multiple IISs. The one returned by Gurobi is not necessarily the smallest one; there may exist others with fewer constraints or bounds. - You can obtain information about the outcome of the IIS computation from the returned IIS result (described below). Note that this method can be used to compute IISs for both continuous and MIP models. - Parameters:
- Example:
- model = gurobi_read('examples/data/klein1.mps'); iis = gurobi_iis(model); 
- Returns:
- The - gurobi_iis()function returns a- struct, with various results stored in its fields. The specific results that are available depend on the type of model.- The returned - structwill always contain the following- fields:- minimal
- A logical scalar that indicates whether the computed IIS is minimal. It will normally be true, but it may be false if the IIS computation was stopped early (due to a time limit or a user interrupt). 
- Arows
- A logical vector that indicates whether a linear constraint appears in the computed IIS. 
- lb
- A logical vector that indicates whether a lower bound appears in the computed IIS. 
- ub
- A logical vector that indicates whether a upper bound appears in the computed IIS. 
 - If your model contains general constraints, the returned - structwill also contain the following- fields:- genconmax
- A logical vector that indicates whether a general MAX constraint appears in the computed IIS. 
- genconmin
- A logical vector that indicates whether a general MIN constraint appears in the computed IIS. 
- genconand
- A logical vector that indicates whether a general AND constraint appears in the computed IIS. 
- genconor
- A logical vector that indicates whether a general OR constraint appears in the computed IIS. 
- genconabs
- A logical vector that indicates whether a general ABS constraint appears in the computed IIS. 
- genconind
- A logical vector that indicates whether a general INDICATOR constraint appears in the computed IIS. 
- genconpwl
- A logical vector that indicates whether a general piecewise-linear function constraint appears in the computed IIS. 
- genconpoly
- A logical vector that indicates whether a polynomial function constraint appears in the computed IIS. 
- genconexp
- A logical vector that indicates whether a natural exponential function constraint appears in the computed IIS. 
- genconexpa
- A logical vector that indicates whether a exponential function constraint appears in the computed IIS. 
- genconlog
- A logical vector that indicates whether a natural logarithmic function constraint appears in the computed IIS. 
- genconloga
- A logical vector that indicates whether a logarithmic function constraint appears in the computed IIS. 
- genconlogistic
- A logical vector that indicates whether a logistic function constraint appears in the computed IIS. 
- genconpow
- A logical vector that indicates whether a power function constraint appears in the computed IIS. 
- genconsin
- A logical vector that indicates whether a SIN function constraint appears in the computed IIS. 
- genconcos
- A logical vector that indicates whether a COS function constraint appears in the computed IIS. 
- gencontan
- A logical vector that indicates whether a TAN function constraint appears in the computed IIS. 
 - If your model contains SOS constraints, the returned - structwill also contain the following- field:- sos
- A logical vector that indicates whether an SOS constraint appears in the computed IIS 
 - If your model contains quadratic constraints, the returned - structwill also contain the following- field:- quadcon
- A logical vector that indicates whether a quadratic constraint appears in the computed IIS. 
 
 - To write the result of the IIS computation into an .ilp file format, set the ResultFile parameter before calling the - gurobifunction.- Example:
- params.resultfile = 'infeas_submodel.ilp' result = gurobi(model, params) 
 
- gurobi_feasrelax(model, relaxobjtype, minrelax, penalties)#
- gurobi_feasrelax(model, relaxobjtype, minrelax, penalties, params)#
- This function computes a feasibility relaxation for the input - modelargument. The feasibility relaxation is a model that, when solved, minimizes the amount by which the solution violates the bounds and linear constraints of the original model. You must provide a penalty to associate with relaxing each individual bound or constraint (through the- penaltiesargument). These penalties are interpreted in different ways, depending on the value of the- relaxobjtypeargument.- For an example of how this function transforms a model, and more details about the variables and constraints created, please see this section. - Parameters:
- model – The model - structmust contain a valid Gurobi model. See the model argument section for more information.
- relaxobjtype – The approach used to impose penalties on violations. If you specify - relaxobjtype=0, the objective for the feasibility relaxation is to minimize the sum of the weighted magnitudes of the bound and constraint violations. If you specify- relaxobjtype=1, the objective for the feasibility relaxation is to minimize the weighted sum of the squares of the bound and constraint violations. If you specify- relaxobjtype=2, the objective for the feasibility relaxation is to minimize the weighted count of bound and constraint violations. In all cases, the weights are taken from- penalties.lb,- penalties.uband- penalties.rhs. You can provide the special penalty value- Infto indicate that the corresponding bound or constraint cannot be relaxed.
- minrelax – The - minrelaxargument is a boolean that controls the type of feasibility relaxation that is created. If- minrelax=false, optimizing the returned model gives a solution that minimizes the cost of the violation. If- minrelax=true, optimizing the returned model finds a solution that minimizes the original objective, but only from among those solutions that minimize the cost of the violation. Note that- gurobi_feasrelaxmust solve an optimization problem to find the minimum possible relaxation when- minrelax=true, which can be quite expensive.
- penalties – - The - penaltiesargument is a struct array, having the following optional fields (default: all- Inf):- lbPenalty for violating each lower bound. There should be as many values as variables into the model. Note that artificial variables may have been created automatically by Gurobi for range constraints.
- ubPenalty for violating each upper bound. There should be as many values as variables into the model. Note that artificial variables may have been created automatically by Gurobi for range constraints.
- rhsPenalty for violating each constraint. There should be as many values as constraints into the model.
 - To give an example, if a constraint with - penalties.rhsvalue- pis violated by 2.0, it would contribute- 2*pto the feasibility relaxation objective for- relaxobjtype=0,- 2*2*pfor- relaxobjtype=1, and- pfor- relaxobjtype=2.
- params – The params - struct, when provided, contains a list of modified Gurobi parameters. See the params argument section for more information.
 
- Returns:
- A - structcontaining two fields:- result.model, a struct variable, as described in the model argument section.- result.feasobj, a scalar. If- minrelax==truethis is the relaxation problem objective value, 0.0 otherwise.
- Example:
- model = gurobi_read('stein9.mps'); penalties.lb = ones(length(model.lb),1); penalties.ub = ones(length(model.ub),1); penalties.rhs = ones(length(model.rhs),1); feasrelaxresult = gurobi_feasrelax(model, 0, false, penalties); 
 
- gurobi_relax(model)#
- gurobi_relax(model, params)#
- Create the relaxation of a MIP model. Transforms integer variables into continuous variables, and removes SOS and general constraints. - Parameters:
- Returns:
- A - modelstruct variable, as described in the model parameter section.
- Example:
- model = gurobi_read('stein9.mps'); relaxed = gurobi_relax(model);