# Package glpk/GLPK.MIPSolve

This article is about a function from ApCoCoA-2. If you are looking for the ApCoCoA-1 version of it, see GLPK.MIPSolve. |

## GLPK.MIPSolve

Solves mixed integer problems.

### Syntax

GLPK.MIPSolve(Objective_f:POLY, EQ_Poly:LIST, LE_Poly:LIST, GE_Poly:LIST, Bounds:LIST, IntNum:LIST, Binaries:LIST, MinMax:STRING)

### Description

This function is similar to `GLPK.LPSolve`, but is also able to solve mixed integer problems.

@param

*Objective_f*: A linear polynomial which is equivalent to the linear objective function.@param

*EQ_Poly*: List of linear polynomials, which are equivalent to the equality-part in the list of conditions.@param

*LE_Poly*: List of linear polynomials, which are equivalent to the lower or equal-part in the list of conditions.@param

*GE_Poly*: List of linear polynomials, which are equivalent to the greater or equal-part in the list of conditions.@param

*Bounds*: List of lists with two elements. Each List contains the lower and upper bounds for each variable. You can choose between INT or RAT for the type of each bound, if you type in a (empty) string, then it means minus infinity (first place) or plus infinity (second place).@param

*IntNum*: List of variables, which should be integer.*Note*: For each variable in this list, the borders get rounded (lower bound: up and upper bound: down). In the case that the lower rounded bound becomes greater then the upper rounded bound, glpk returns: Solution Status: INTEGER UNDEFINED - Value of objective function: 0.@param

*Binaries*: List of variables, which should be binaries (0 or 1).@param

*MinMax*: Minimization ("Min") or maximization ("Max"), that's the question.@return List of linear polynomials, the zeros of the polynomials are the points where the optimal value of the objective function is achieved

#### Example

-- We want to maximize the Function y = - 1/2x, -- with the two conditions y ≤ 6 - 3/4x and y ≥ 1 - x and the bounds 0 ≤ x ≤ 6 and 1/3 ≤ y ≤ 4. -- We prename the input of GLPK.MIPSolve-function. Use S ::= QQ[x,y]; OF := (1/2)*x + y; LE := [(3/4)*x + y - 6]; GE := [x + y - 1]; Bounds:=[[0,6], [1/3,4]]; IntNum:=[x,y]; GLPK.MIPSolve(OF, [], LE, GE, Bounds, IntNum, [], "Max"); -- [2, 4] EQ := [x,y] GLPK.MIPSolve(OF, EQ, LE, GE, Bounds, IntNum, [], "Max"); -- []

### See also