TD3 - Simplex Algorithm

Download as pdf or txt
Download as pdf or txt
You are on page 1of 5

Optimization and Approximation ENS Lyon, 2018-2019

TD3 - Simplex algorithm


Indication of hardness: from (*) to (****).

1 Theory on the Simplex algorithm


Exercise 1 - Correctness of the Simplex algorithm. (**)
Consider the following LP in the standard form.

max cT x


 xB
I A =b
xN
x≥0

where b ≥ 0 and the vector xB is a basic feasible solution.

(a) Show that if x is a solution of the system (resp. of the system without the non-
negativity constraints) then x is still a solution after the new solution of the sys-
tem after the pivot operation (resp. of the system without the non-negativity con-
straints).
i.e. x satisfies the constraint before the pivot iff x satisfies the constraint after the
pivot.
(b) Prove the same for the objective function. Deduce that the value of the optimal
solution is not modified by a pivoting rule.
(c) Show that after a pivot operation, the vector b is still non negative.
(d) Deduce that if the Simplex algorithm starts from a BFS, then the current solution is
a BFS at any step.

Exercise 2 - Multiple optimal solutions. (**)

(a) Solve geometrically the following LP

max 4x1 + 14x2


Subject to:
2x1 + 7x2 ≤ 21
7x1 + 2x2 ≤ 21
x1 , x2 ≥ 0

What can you say about the set of optimal solutions?


(b) Solve it using the Simplex algorithm. What can you remark?

1
Optimization and Approximation ENS Lyon, 2018-2019

(c) Let c∗ be the objective function in an optimal tableau. Prove that if a LP has sev-
eral solutions then a non-basic variable MUST have coefficient 0 in the objection
function c∗ .
(d) Show that the above condition is sufficient if the LP is non degenerate.
(e) (***) Is it sufficient in general?

Exercise 3 - Non-necessarily optimal rule. (*)


Show on an example that choosing the entering variable having highest coefficient in z
(in the current objective function) does not guarantee that the increase of the constant
term of z is maximum amongst all possible pivots.

Exercise 4 - Infinite solutions

(a) Prove that if the ratio does not give any constraint, then the LP has an arbitrarily
optimal value.
max z = 2x1 + x2 max z = 3x1 + 2x2
subject to x1 + x2 ≤ 10
x1 − x2 ≤ 10 x2 ≤ 6
(b) 2x1 − x2 ≤ 40 3x1 + 2x2 = 18
x1 , x2 ≥ 0 x1 , x2 ≥ 0
Solve geometrically and with the Sim- Solve geometrically and with the Sim-
plex algorithm this LP. plex algorithm this LP.

2 Cycling and Running time


Exercise 4 - Cycling and points of the polytope. (***)
Assume that we have a cycling B1 , . . . , B` in an execution of the simplex algorithm. A
variable is busy if it leaves the basis in the cycle (or similarly if it enters).
1. Assume that the Simplex algorithm do not stricly improve the objective value at
step t. Then the two solutions correspond to the same point.
2. Deduce that if the simplex algorithm is cycling then all the busy variables equal 0.

Exercise 5 - Cycling example. (****)


max z = 10x1 − 57x2 − 9x3 − 24x4
subject to
1/2x1 − 11/2x2 − 5/2x3 + 9x4 ≤ 0
(1)
1/2x1 − 3/2x2 − 1/2x3 + x4 ≤ 0
x1 + x2 + x3 + x4 ≤ 1
x1 , x2 , x3 , x4 ≥ 0

2
Optimization and Approximation ENS Lyon, 2018-2019

The entering variable will be the one with the most negative coefficient in the objective
vector. The leaving variable will be the candidate for departing which has the smallest
subscript. Prove that there is a cycle !

Exercise 6 - Exponential number of steps (***)


Consider the following LP:
max xd
subject to
x1 − r1 =
x1 + s 1 = 1
xj − xj−1 − rj = 0 j = 2, . . . , d
xj + xj−1 + sj = 1 j = 2, . . . , d
xj , rj , sj ≥ 0 j = 1, . . . , d

(a) Prove that any basic feasible solution for the LP has the following properties:
• Each xi is in the basis.
• Exactly one of {rj , sj } is in the basis for each j = 1, 2, . . . , d.
(b) So we can associate to each bfs, the subset S of indices j in {1, 2, . . . , d} such that
rj is in the basis. We denote by xS the corresponding (uniquely) bfs. Prove that
if d ∈ S but d ∈ / S 0 , then for the corresponding basic feasible solutions’ we have
0 0
xd > xd . Moreover, if S = S 0 ∪ {d}, then xSd = 1 − xSd .
S S

Note that in particular each of these basis gives a different vertex of the polytope.
(c) Conclude that the Simplex algorithm might need an exponential number of steps.

Hint for (c): Apply induction.

3 Determining properties of polyhedra using LPs


Exercise 7 - Empty or bounded polyedra. (**)
Let P be a polyhedron (defined as an intersection of halfspaces you know). Explain
how you can determine using Linear Programs:
(a) if P is empty.
(b) if P is bounded.

Exercise 8 - Empty polyhedra (II) (**)


Determine if the following polyhedra is empty. If not, exhibit a vertex.
x1 − 6x2 + x3 − x4 = 5 3x1 − 2x2 + 4x3 ≥ 8
−2x2 + 2x3 − 3x4 ≥ 3 −2x2 + 2x3 ≥ 3
3x1 − 2x3 + 4x4 = −1 3x1 − 2x3 ≤ −1
x1 , x3 , x4 ≥ 0 x1 + x2 − x3 = 1
x2 free x1 , x2 x3 ≥ 0

3
Optimization and Approximation ENS Lyon, 2018-2019

Exercise 9 - Solutions of LPs. (**)


Find the necessary and sufficient conditions on the real values a, b, c such that the LP

max x1 + x2
subject to
ax1 + bx2 ≤ c
x1 , x2 ≥ 0

(a) has a unique optimal solution.


(b) is infeasible.
(c) is unbounded.

Exercise 10 - Included or not? (**)


The goal of the exercise is to solve the following problem:
Given two polyhedra

P1 = {x|Ax ≤ b}, P2 = {x|Cx ≤ d} (2)

Determine if P1 ⊆ P2 , or find a point in P1 that is not in P2 .

(a) Let P be a polyhedron and H be a open halfspace (i.e. a set satisfying H = {x/ct x >
b} for some c, b). How can you test if P ∩ H is empty? How can you find a point of
P ∩ H if it exists?
(b) Answer the initial question (if necessary, several calls to the Simplex Algorithm can
me made).

4 Simplex algorithm
Exercise 11 - Phase I/II. (*)
Using Phase I/II method, solve the following LPs:

4
Optimization and Approximation ENS Lyon, 2018-2019

max 1000x1 + 1200x2


subject to
10x1 + 5x2 ≤ 200
2x1 + 3x2 = 60
x1 ≤ 12
max 2x1 + 3x2 + x3
x2 ≥ 6
subject to
x1 , x2 ≥ 0
x1 + x2 + x3 ≤ 40
2x1 + x2 − x3 ≥ 10 Exercise - A last Simplex example
−x2 + x3 ≥ 10
max x1 + 2x2 − x3
x1 , x2 , x3 ≥ 0
subject to
2x1 + x2 + x3 ≤ 14
4x1 + 2x2 + 3x3 ≥ 28
2x2 + 5x2 + 5x3 ≥ 30
x1 , x2 , x3 ≥ 0

You might also like