Sensitivity analysis for production planning model of an oil company Thesis Yu Da

Transcription

Sensitivity analysis for production planning model of an oil company Thesis Yu Da
Sensitivity analysis for production
planning model of an oil company
Thesis
By Yu Da
Supervised by Assoc. Professor Tibor Ill´
es
E¨otv¨os Lor´and University
Faculty of Natural Sciences
2004
ACKNOWLEDGEMENT
I take occasion to thank MOL RT. for giving me the opportunity so that
I could join in the research work and, besides, for supporting me by a ten
month scholarship.
I am beholden to Assoc. Prof. Ills Tibor, my supervisor, who let me take
part in the project of MOL RT. and gave me many pieces of good advice.
Last but not least, I thank my friends, Csizmadia Zsolt, Nagy Mariann,
Mincsovics Gergely for their help.
1
CONTENTS
Contents
Introduction
3
1 Linear Programming Problems
1.1 The primal and dual linear programming problems
1.2 The basis and basic solution . . . . . . . . . . . . .
1.3 Duality Theory for Linear Programming . . . . . .
1.4 The Geometry of Linear Programming Problems . .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
4
. 4
. 7
. 8
. 11
2 Linear Programming Pivot Algorithms
2.1 Simplex Method and its variants . . . . . . . . . . . . . . . . .
2.2 Criss-Cross Method . . . . . . . . . . . . . . . . . . . . . . . .
2.3 Monotonic Build-Up Simplex Algorithm . . . . . . . . . . . .
13
13
16
17
3 Degeneracy in Linear Programming
3.1 The Case of Degeneracy . . . . . . . . . . . . .
3.1.1 (Primal) Degeneracy and Nondegeneracy
3.1.2 Dual Degeneracy and Nondegeneracy . .
3.2 Geometry of Degeneracy . . . . . . . . . . . . .
3.3 Anti cycling Pivot Rule . . . . . . . . . . . . . .
3.3.1 Perturbation method . . . . . . . . . . .
3.3.2 Lexicographic Methods . . . . . . . . . .
3.3.3 Bland Pivoting Rule . . . . . . . . . . .
3.4 The Alternative optimal Solutions . . . . . . . .
19
19
19
20
21
23
25
27
33
35
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
4 Parametrical Linear Programming
4.1 The Parametric Cost Problem . . . . . . . . . . . . . . . . .
4.2 Parametric Right-Hand-Side problem . . . . . . . . . . . . .
4.3 Resolution of Cycling in The Parametric Simplex Algorithms
4.3.1 Resolution of Cycling in the Parametric Right-HandSide Simplex Algorithm . . . . . . . . . . . . . . . .
4.3.2 Resolution of Cycling in the Parametric Cost Simplex
Algorithm . . . . . . . . . . . . . . . . . . . . . . . .
.
.
.
.
.
.
.
.
.
39
. 39
. 45
. 47
. 48
. 49
5 Sensitivity Analysis
51
5.1 The Fundamental Principle of the Sensitivity
Analysis . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51
5.2 The sensitivity analysis of coefficients of the
objective function . . . . . . . . . . . . . . . . . . . . . . . . . 52
2
CONTENTS
5.3
5.4
The sensitivity analysis of constant on the right-hand-side
The sensitivity analysis of data in the matrix . . . . . . . .
5.4.1 The change of one matrix element . . . . . . . . . .
5.4.2 Adding a new variable . . . . . . . . . . . . . . . .
5.4.3 Adding a new constraint . . . . . . . . . . . . . . .
6 Analysis of an oil production planning model
6.1 Short analysis about the structure and size of the model
6.2 Flow Chart of solution by the PIMS . . . . . . . . . . . .
6.3 The oil industrial product planning model . . . . . . . .
6.4 Problems about the model and the appropriate analysis .
6.4.1 Local optimum and alternative optimal solution .
6.4.2 Infeasibility and being unbounded . . . . . . . . .
6.5 Model collecting . . . . . . . . . . . . . . . . . . . . . . .
6.6 User documentation about the analyzing program . . . .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
55
57
57
59
59
.
.
.
.
.
.
.
.
63
63
66
68
69
72
74
75
77
INTRODUCTION
The optimization or mathematical programming is the branch of mathematics dealing with methods of optimization of some decision variables which
are restricted by given constraints. Interest in optimization methods and
their applications has become very widespread. They are used in almost all
area of the industry. Still, the applications must not be isolated from theory,
otherwise the solutions can be inaccurate, inexact or even turn aside from the
truth. Therefore, it is always necessary for all the applied mathematicians to
give mathematical arguments and analysis for each step of resolution process
in order to approximate the real life problems in a correct way.
In this thesis, a production planning model of an oil company and related topics, like solution methods, important properties of the problem etc.
are introduced. This is a typical example for applying optimization in the
real life. In order to discuss the model in-depth, the specification of linear
programming, linear programming pivot algorithms, degeneracy are studied in the first three sections. Afterwards, sensitivity analysis, parametric
programming are presented.
Computer programs have become essential tools by modelling and analyzing as in the case studied. In the last part of this thesis the documentation
of our program are included, with which it is possible to analyze the model
and the solutions. Our program is an LP modelling and analyzing tool for
general purpose. The linear programming problem can be described by defining it’s constraints and variables. The program uses the mps file format, as
the models were given in this format. With the program we can modify the
model description, e.g. any value given in the model can be altered, the order
of the variables can be changed, the objective function can be transformed to
a constraint. With the program we can read the solutions of the model and
check, whether the solution really satisfies the constraint conditions. Furthermore, if the solution is outside of the feasible solution set the right-hand
side can be changed by a single click to make it feasible.
1. LINEAR PROGRAMMING PROBLEMS
1
4
Linear Programming Problems
In this section we introduce two forms of linear programming problems, primal and dual. One say that a linear optimization problem consists of optimizing, a linear function over a certain domain. The domain is given by a
set of linear constraints. Here we give the definitions of basic solution, basis, duality, etc. The feasibility problem is shown, the duality theorems are
discussed, and the connection between the geometry and algebra of linear
programming problems are also talked in this section.
1.1
The primal and dual linear programming problems
Linear programs are usually stated and analyzed in the standard forms:

min cT x 
Ax = b
(P )

x ≥ 0
where c is vector in Rn , b is a vector in Rm , A is an m × n real matrix
with rank(A) = m, and x ∈ Rn is the unknown vector..We call this problem
as the primal linear programming problem.
Simple devices can be used to transform any linear program to this form.
For example, given the problem
min cT x
Ax ≤ b
we can convert the inequality constraints to equalities by adding a vector of
slack variable s and writing:

min cT x

Ax + s = b
.

s ≥ 0
For the standard formulation, we will assume throughout that m ≤ n.
Otherwise, the system Ax = b contains redundant rows is infeasible.
Given the data c, b and A, which define the standard primal problem,
using that we can give another closely related problem:

max yT b

AT y + s = c
(D)

s ≥ 0
5
1. LINEAR PROGRAMMING PROBLEMS
where y ∈Rm and s ∈Rn A is an m × n real matrix with rank(A) = m. This
problem is called the dual linear programming problem.
If the solution set of the given linear programming problem in primal
form is denoted by P, then P , which is called as primal feasible solution set,
can be defined as follows:
P = {x ∈ Rn : Ax = b, x ≥ 0}
and also if we denote the solution set of linear programming problem in dual
form by D, the dual feasible solution set, then
D := (y, s) ∈ Rm+n |yA + s = c , s ≥ 0 .
The linear programming problem in standard form may be written in
tableau form in the pivot algorithms, in next section we will talk more about
linear programming pivot algorithms :
A
c
b
∗
First let us recall some basic concepts of linear algebra, which are necessary for understanding pivot algorithms. For more detail see [4].
Let ai ∈ Rm be the ith column of the matrix A. Denote the set of indices
belonging to vectors ai by I. Then I = {1, 2, ..., n} .
Definition 1 A linear combination of the vectors {ai |i ∈ I } is any vector
b ∈ Rm of the form
X
b=
λi ai
i∈I
where λi ∈ R, for all i ∈ I.
Using this definition the generating system is definable, which can express
any vector in the set.
Definition 2 Let IG ⊂ I be given. The set {ai |i ∈ IG } is called a generating
system of {ai |i ∈ I } if any ai , i ∈ I G (I G = I \ IG ) can be expressed as a
linear combination of vectors {ai |i ∈ IG } . That means the set {ai |i ∈ I } is
spanned by the vectors {ai |i ∈ IG } .
6
1. LINEAR PROGRAMMING PROBLEMS
Suppose, that IG ⊂ I contains the indices of a generating system. Then
X
aj =
aij ai , for j ∈ I G .
i∈IG
Using this previous expression we can produce the following tableau, which
is called short pivot tableau:
IG
aj
..
.
IG
ai
· · · aij
..
.
···
Now, let us introduce the primal full pivot tableau, which is used in
solving the primal linear programming problems.
IG
ai
IG
aj
..
.
..
.
· · · aij
..
.
..
.
IG
ai
1
0
··· 0
..
.
0
...
···
1
..
.
0
..
···
0
.
0
1
In the tableau, the aij 6= 0 element is called a pivot element, the row
i ∈ IG is called pivot row, while column j ∈ I G is called pivot column. A
pivot operation and pivot step is uniquely defined by the pivot element. The
primal pivot operation consists of
• a series of elementary row operations on primal pivot tableau, to transform the pivot column into one containing an entry of 1 in the pivot
row (i ∈ IG ) and an entry 0 in all the other rows.
• exchange the unity vector obtained in the pivot column (j ∈ I G ) by
−akj /aij when k 6= i and with 1/aij when k = i.
• IG := (IG \ {i}) ∪ {j} and I G := (I G \ {j}) ∪ {i} .
The result of the pivot operation can be summarized in the following
theorem.
7
1. LINEAR PROGRAMMING PROBLEMS
Theorem 3 If ars 6= 0 then ar , r ∈ IG can be exchanged with as , s ∈ I G in
the following way:
1. a0sr =
1
ars
is
2. a0ir = − aars
a
rj
3. a0sj = − ars
4. a0ij = aij −
0
i ∈ IG , i 6= s
0
j ∈ IG , j 6= r
arj ais
ars
0
0
i ∈ IG , i 6= s, j ∈ I G , j 6= r
The proof can be find in [2][1].
1.2
The basis and basic solution
Assume, that a IG ⊂ I generating system is given. Obviously, if there exists
another set IG0 , that IG ⊂ IG0 ⊂ I, then IG0 is also a generating system. But
if IG is linear dependent, then IG0 can not be linear independent.
Definition 4 The set {ai ∈ Rn : i ∈ I} of vectors, where |I| ≥ 2, is said to
be linearly independent, if there does not exist vector ar , r ∈ I which can be
expressed as a linear combination of the vectors {ai ∈ Rn : i ∈ I\ {r}} .
Thus, if |I| =
6 ∞, then the smallest generating system is linearly independent.
Definition 5 If a system of vectors {ai |i ∈ IB } IB ⊆ I is a linearly independent and also generating system of {ai |i ∈ I } , then it is called a basis.
Let A be an m × n real matrix (m ≤ n) and the matrix A has m linearly independent columns. Let us define by IB the set of indices of such m
columns, and by AB the corresponding m × m submatrix of A. In this case
AB is nonsingular, therefore invertible. The columns of A which indices are
not in the IB form an m × (n − m) submatrix AN of A, the corresponding
index set is denoted by IN .
If a nonhomogeneous linear equation is given as Ax = b then we may
split the unknowns into two different vector according to the index sets IB
and IN . The vector xB contains those variables which indices are in IB ,
so, the xB is the corresponding basic vector, while xN the nonbasic vector.
Thus, x = (xB , xN ). In the similarly way, c = (cB , cN ), in which cB is the
row vector of the basic cost coefficients. Then the nonhomogeneous linear
equation can be expressed as
8
1. LINEAR PROGRAMMING PROBLEMS
AB xB + AN xN = b
Using the invertibility of AB we can solve the equation as
−1
xB = A−1
B b − AB AN xN
−1
If xN = 0 and xB = A−1
B b then the solution x = (AB b, 0) is called
as primal basic solution corresponding to the given basis AB . If A−1
B b ≥ 0
then the basic solution x = (xB , xN ) is called as basic feasible solution and
the AB is called as primal feasible basis. We denote BFS for basic feasible
solution.
m
The vector y =A−T
is called dual basic solution. Then the
B cB ∈ R
T −T
vector sN = cN − AN AB cB and if the condition sN ≤ 0, is satisfied, then
AB is called dual feasible basis, and the solution (y, s) is called dual feasible
solution.
The solutions are optimal if they are both primal and dual feasible.
An equivalent form to the standard form in linear programming problem
with the consideration for the definition in above is:

T −T
min z = cTB A−1
B b+ cN − AN AB cB xN 
−1
(P )
xB + A−1
B AN xN = AB b

xB , xN
≥
0
The pivot tableau, which belongs to AB basis, is as follows:
1.3
A−1
B A
A−1
B b
T
cN − (cTB A−1
B A)
−cTB A−1
B b
Duality Theory for Linear Programming
The primal and the dual problems are generally two distinct linear programming problems. (It is notable, that there is a small class of linear programming problems called self-dual linear programs. Any linear programming
problem in this class is equivalent to its dual.) However, there is close relation between them.
Theorem 6 (Weak duality theorem). Let us consider a primal-dual pair of
linear programming problems and let x ∈ P and (y, s) ∈ D. In the primaldual pair of linear programming problems, let x be a primal feasible solution
and (y, s) the dual feasible solution. Then cT x ≥ bT y, thus xT s ≥ 0, and
equality holds only if x(c − AT y) = 0.
9
1. LINEAR PROGRAMMING PROBLEMS
Corollary 7 The primal objective value of any primal feasible solution is an
upper bound to the maximum value of the dual objective in the dual problem.
The dual objective value of any dual feasible solution is a lower bound to the
minimum value of the primal objective in the primal problem. If the primal
problem is feasible and its objective function is unbounded below on the primal
feasible solution set, then the dual problem cannot have a feasible solution. If
the dual problem is feasible and its objective function is unbounded above on
the dual feasible solution set, then the primal problem cannot have a feasible
solution.
If the solution set of the given linear programming problem in primal
form is denoted by P ∗ , then P ∗ , which is called as primal optimal solution
set, can be defined as follows:
P ∗ : = x∗ ∈ P : cT x∗ ≤ cT x, ∀x ≥ 0
If we denote the optimal solution set of linear programming problem in dual
form by D∗ , the dual optimal solution set.
D∗ := (y∗ , s∗ ) ∈ D : bT y∗ ≥ bT y, ∀(y, s) ∈ D .
Assume, we have x
¯ ∈ P, (¯
y, ¯
s) ∈ D and cT x
¯ = bT y
¯, thus x
¯T ¯
s = 0. In
∗
∗
this case x
¯ ∈ P and (¯
y, ¯
s) ∈ D . Let us define the optimal value as ζ.
Consequently
P ∗ = x ∈ Rn |Ax = b, x ≥ 0, cT x = ζ .
The optimal criterion with the basic solution is: if AB is primal and dual
feasible basis then
−1
∗
T −1
T
∗
x = (xB , xN ) = (A−1
B b, 0) ∈ P and (y, s) = (cB AB , c − (cB AB A) ) ∈ D .
On the other hand, if the basis is infeasible, we have following criteria.
Primal infeasibility criterion: if
A−1
B b
i
< 0,
and
A−1
B A
(i)
≥ 0 i ∈ IB
then the primal problem cannot have a feasible solution, thus P = ∅.
10
1. LINEAR PROGRAMMING PROBLEMS
Let us consider it in the pivot tableau. According to the pivot tableau
belong to AB basis and the primal infeasibility criterion, it is depicted as
following:
i
⊕ ... ⊕
Dual infeasibility criterion: if
T
< 0,
c − (cTB A−1
B A)
j
and
−
A−1
B A
j
≥ 0 j ∈ IN
then dual problem cannot have a feasible solution, thus D = ∅.
Let us consider it in the pivot tableau. According to the pivot tableau
belong to AB basis and the dual infeasibility criterion, it is depicted as following:
:
:
−
j
In conclusion, we have the following optimality criterion. For the detailed
proof, see[1][3][2].
Theorem 8 (Sufficient optimality criterion) If x∗ and (y∗ , s∗ ) are a pair
of primal and dual feasible solutions satisfying cT x∗ = bT y∗ , then x∗ is an
optimal feasibility solution of the primal and (y∗ , s∗ ) is an optimal solution
of the dual.Thus (x∗ )T s∗ = 0, and x∗ ∈ P ∗ , (y∗ , s∗ ) ∈ D∗ .
The converse of this sufficient optimality criterion is the strong duality
theorem.
Theorem 9 (The strong (fundamental) duality theorem) In a primal-dual
pair of linear programming problems, if either the primal or the dual problem has an optimal solution, then the other does also, and the two optimal
objective values are equal.
1. LINEAR PROGRAMMING PROBLEMS
11
Consider the primal and dual problems discussed in the weak duality
theorem, we saw that the minimum value of cT x is greater than or equal to
the maximum value of bT y. In the strong duality theorem, it stated, that the
minimum value of cT x is equal to the maximum value of bT y. This explains
the names weak, strong duality theorems.
The optimality criterion can also be formed as follows:
Ax = b x ≥ 0
y A+s = c s ≥ 0
xT s = 0
T
1.4
The Geometry of Linear Programming Problems
Let us take a look at an important relationship between the algebraical and
geometrical viewpoints of linear programming problems, it will help us to understand the problems and the solution methods more better. The feasible
solution set of an linear programming problem defined by the linear constraints is geometrically a convex polyhedron, an intersection of halfspaces.
In order to introduce the relationship, it is necessary to define the extreme
points, which play an important role in solving problems related to convex
polyhedra.
Definition 10 Let Γ be a convex subset of Rn . A point x ∈ Γ is called an
extreme point of Γ if it is impossible to express it as a convex combination
of two other distinct points in Γ. That means, x is an extreme point of Γ
iff x1 , x2 ∈ Γ and 0 < λ < 1 such that x = λx1 + (1 − λ)x2 implies that
x = x1 = x2 .
An extreme point of the convex subset are the points that do not lie on
a straight line between two other points in the set.
In many linear programming literatures, extreme points defined in an
algebraic way are called basic feasible solutions. Here we have theorem to
explain the connection. Before that let us give a definition of basic feasible
solutions in another form.
Definition 11 Let K be the set of feasible solutions of (P). The feasible solution x ∈ K is called basic feasible solution for (P) iff the set of column vectors
of A that x uses is linearly independent, that the {aj : j, such that xj > 0}
is linearly independent set.
1. LINEAR PROGRAMMING PROBLEMS
12
In the following theorem, we will see, that extreme point and basic feasible
solution are the same, only defined from different viewpoints
For more detail and proof about the following theorem see [3] [2] [1]
Theorem 12 Let K be the set of feasible solutions of (P). Assume, x ∈ K
is an extreme point iff it is a basic feasible solutions of (P).
On the other hand, if we assume, that the optimal value of problem (P)
is finite, then the optimal value is taken at extreme point as well.
The extreme points:
2. LINEAR PROGRAMMING PIVOT ALGORITHMS
2
13
Linear Programming Pivot Algorithms
In this chapter we introduce three pivot algorithms for linear programming
problems. Simplex Method, which was developed by George B. Danzing(1947),
is used today widely in many linear optimization application areas. CrissCross Method was worked out by Tam´as Terlaky(1986)[5]. The last one is the
Monotonic Build-Up Simplex Algorithm For Linear Programming (1991)[7],
which is established by Kurt M. Anstericher and Tam´as Terlaky.
2.1
Simplex Method and its variants
This is an algorithm that can be used to solve any LP in standard form.
Althrough, there are example, e.g. Klee-Minty problem, for which simplex
method use exponencially many iterations, but it is used the most widespread
nowadays.
For the simplex method, suppose the start feasible basic vector is denoted
as (x1 , ..., xm ).
Definition 13 The primal linear programming problem is in canonical form
if the following two conditions are satisfied:
1. b ≥ 0
2. the matrix A contain an m × m unity submatrix where A ∈ Rm×n ,
b ∈ Rm , c ∈ Rn , x ∈ Rn .
Primal Simplex Method
Let the primal linear programming problem be given in the canonical
form.
2. LINEAR PROGRAMMING PIVOT ALGORITHMS
14
Initialization
AB is an primal feasible basis;
IB and IN index set of the basic and nonbasic indices
begin
while Ic := {i : c¯i < 0} =
6 ∅ do
choose the entering arbitrary variable r ∈ Ic
if Ir := {i ∈ IB : a
¯ir < 0} = ∅ then
STOP D = ∅, the
dual infeasibility criterion
is satisfied
else K := arg min ¯bj /¯
ajr , such that a
¯jr > 0
choose the leaving arbitrary variable s ∈ K
Pivot on a
¯sr
endif
endwhile
STOP: the solution is optimal
end
Let introduce a definition, which is used in the algorithm.
Definition 14 The (¯bs /¯
asr ) = min ¯bj /¯
ajr , such that a
¯jr > 0 is called minimum ratio test.
b
Obviously, that 0 ≤ a¯blrl ≤ a¯jrj for all j ∈ Ir , thus the value of the
objective function is decreasing after each pivot iteration. Let us see the
following pivot tableau before the pivot iteration:
..
.
..
.
··· a
¯lr
..
.
c¯r
···
· · · ¯bl
z0
Suppose we chose a
¯lr as the pivot element, according to the algorithm,
we have c¯r < 0, a
¯lr > 0 and ¯bl ≥ 0. After the pivot iteration, we obtain
new
z
= z0 − c¯r¯bl /¯
alr , since c¯r¯bl /¯
alr ≤ 0 that results in z new ≥ z0 .
Since we reading out with negative sign the value of the objective function,
therefore the increase here means decrease in reality. Hence in each iteration,
objective value does not increase.
2. LINEAR PROGRAMMING PIVOT ALGORITHMS
15
The primal simplex algorithm start with a primal feasible basis and move
to a terminal basis by walking through a sequence of primal feasible bases
along the edges of the set of feasible solutions. All the bases with the possible
exception of the terminates basis obtained in the primal algorithm are dual
infeasible. At each pivot iteration, the primal algorithm makes an attempt
to reduce dual infeasibility while retaining primal feasibility
However, the dual simplex algorithm does just the opposite.
Dual Simplex Method
The dual simplex method starts with a dual feasible, but not certain a
primal feasible basis. At each pivot iteration, this algorithm tries to reduce
primal infeasibility while retaining dual feasibility. If a primal feasible basis
is reached, the dual simplex algorithm terminates.
Initialization
AB is an dual feasible basis;
IB and IN index set of the basic and nonbasic indices
begin
while Ir := i : ¯bi < 0 6= ∅ do
choose the arbitrary leaving variable r ∈ Ir
if Ic := {i ∈ IN : a
¯ri < 0} = ∅ then
STOP P = ∅, the primal infeasibility criterion is satisfied.
else K := arg min {−¯
cj /¯
arj , such that a
¯rj < 0}
choose the arbitrary entering variable s ∈ K
Pivot on a
¯rs
endif
endwhile
STOP: the solution is optimal
end
According to the primal method, for the dual simplex algorithm, we define
also the dual simplex minimum ratio test, which is used in the algorith.
Definition 15 The minimum ratio
−(¯
cs /¯
ars ) = min {−¯
cj a
¯rj , such that a
¯rj < 0}
is called dual simplex minimum ratio test.
There are a lot of specialized literature discuss about simplex methods.
Here we do not want to go in detail. Let us see the next poivot algorithm,
Criss Cross method.
2. LINEAR PROGRAMMING PIVOT ALGORITHMS
2.2
16
Criss-Cross Method
This algorithm is introduced by Tam´as Terlaky[5]. However, it is not known,
whether Criss-Cross algorithm perform numerically well or not, but this is
the first algorithm which solves general primal linear programming problem
in one phase starting from any, not necessarily primal or dual feasible basis.
If the basic solution is optimal we are ready, else a primal or dual infeasible variable is chosen. After pivoting we obtain a new basis, in which
this variable becomes both primal and dual feasible. The process is repeated
until optimality is reached or the condition of primal or dual infeasibility is
established(see,[6]).
Criss-Cross Algorithm:
Let the initial basis AB , be given. Let IB and IN denote the basic and
nonbasic indices, respectively, (I = IB ∪ IN ).
Initialization
AB is an arbitrary initial basis;
IB and IN index set of the basic and nonbasic indices
begin
while I¯ := i : ¯bi < 0 or c¯i < 0 6= ∅ do
r := mini∈I¯ i
if (r ∈ IN ) then
if Ir := {i ∈ IB : a
¯ir > 0} = ∅ then
STOP D = ∅, the dual infeasibility criterion is satisfied
else s := minj∈Ir j and IB := ((IB \ {s}) ∪ {r})
Pivot on (s, r) position
endif
else (r ∈ IB )
if Ir := {i ∈ IN : a
¯ri < 0} = ∅ then
STOP P = ∅, the primal infeasibility criterion is satisfied
else s := minj∈Ir j and IB := ((IB \ {r}) ∪ {s})
Pivot on (r, s) position
endif
endif
endwhile
STOP the current solution solves the problem
end
Now, there are more variations about the proof about criss-cross type
pivot rules. E.g. see [8].
2. LINEAR PROGRAMMING PIVOT ALGORITHMS
2.3
17
Monotonic Build-Up Simplex Algorithm
This algorithm begins with a basic feasible solution, and any nonbasic variable having a negative reduced cost, the pivot rule produces a sequence of
pivots such that ultimately the originally chosen nonbasic variable enters the
basis and all reduced costs which were originally nonnegative remain nonnegative. The pivot rule thus monotonically builds up to a dual feasible, and
hence optimal basis. For more details see [7]
The MBU Pivot Rule
Given any feasible basis. For (P) problem the pivot rule is:
Initialization
AB is an arbitrary initial basis;
IB and IN index set of the basic and nonbasic indices
begin
while I¯ := {i : c¯i < 0} =
6 ∅ do
choose s ∈ I¯ as driving variable; θ1 := 1, θ2 := 0
while θ1 > θ2 ∅ do
if a
¯is ≤ 0, i = 1, ..., m, then
STOP D = ∅, the dual infeasibility criterion is satisfied
else let r := arg mini ¯bi /¯
ais : a
¯is > 0 and θ1 = |¯
cs | /¯
ars
endif
if a
¯rj ≥ 0, for every j, with c¯j ≥ 0, then Pivot on (s, r) position
θ2 = +∞.
else let t := arg minj {¯
cj /¯
arj : c¯j ≥ 0 and a
¯rj < 0} and θ2 = c¯t / |¯
art |
endif
if θ1 > θ2 then
pivot on a
¯rt and xt as the blocking variable
else pivot on a
¯rs
endif
endwhile
endwhile
STOP the current solution solves the problem
end
The result of a pivot in the last ”if” in the algorithm will be a basis which
is neither primal nor dual feasible. This pivot selection can also be viewed as
”dual” pivot, since the purpose of such a pivot is to maintain as much dual
feasibility as currently exists.
The Dual MBU Pivot Rule
2. LINEAR PROGRAMMING PIVOT ALGORITHMS
18
The dual MBU rule can easily be derived from he primal rule, and has
the ”build-up” feature with respect to the number of nonnegative primal
variables. Assume an initial dual feasible basis is available.
Initialization
AB is an arbitrary initial basis;
IB and IN index set of the basic and nonbasic indices
begin
while I¯ := i : ¯bi < 0 6= ∅ do
choose r ∈ I¯ as driving row; θ1 := 1, θ2 := 0
while θ1 > θ2 ∅ do
if a
¯rj ≥ 0, i = 1, ..., m,then
STOP P = ∅, the dual infeasibility criterion is satisfied
else let s := arg minj {¯
cj / |¯
arj | : a
¯rj < 0} and θ1 = ¯br /¯
ars
endif
if a
¯is ≤ 0, for every j, with ¯bi ≥ 0, then
θ2 = +∞.
else let q := arg mini ¯bi /¯
ais : ¯bi ≥ 0 and a
¯is > 0 and θ2 = ¯bq /¯
aqs
endif
if θ1 > θ2 then
pivot on a
¯qs and q as the blocking row
else pivot on a
¯rs
endif
endwhile
endwhile
STOP the current solution solves the problem
end
Certain, there are also many other linear programming algorithms, for
example, interior point method, ellipse method. Some of them can be applied
more effective, others can give us exact theory background. About that I do
not want to go into details. However, all the pivot algorithms can occur
degeneracy, which is talked in next section.
3. DEGENERACY IN LINEAR PROGRAMMING
3
19
Degeneracy in Linear Programming
In the proceeding section several linear programming pivot algorithms are
introduced. However, all of them have the same weak point, the degeneracy,
which can occur the algorithm into cycling, so that it will not terminated for
ever. It’s description can be find in many literature, e.g. [11][3][1], etc.
In the first part of this section we are going to discuss about the degeneracy in detail, also in geometry sense. After that several anticycling pivot
rule are introduced. Final, one important attribute of degeneracy, alternative
optimal solutions are talked about.
3.1
The Case of Degeneracy
In the fist section, we have given the Linear programming problem in the
standard form as:

min cT x 
Ax = b
(P )

x ≥ 0
where c and x are vectors in Rn , b is a vector in Rm , and A is an m × n real
matrix rank(A) = m.
The degeneracy in linear programming can also be classified in primal
and dual.
3.1.1
(Primal) Degeneracy and Nondegeneracy
A basic feasible solution (BFS) of a linear programming problem in standard
form is said to be (primal) degenerate if the value of at least one of the basic
variables is zero. Suppose x∗ is a BFS of (P), and the rank of A is m. Since
any set of m + 1 or more column vectors in Rm is linearly dependent, the
number of positive variables x∗j cannot exceed m. The solution x∗ is said to
be a nondegenerate BFS of (P) or primal nondegenerate BFS, if exactly m of
the x∗j are positive. If the number of positive x∗j is less than m, x∗ is known
as a primal degenerate BFS of (P).
If x∗ is a nondegenerate BFS of (P), the column vectors of A corresponding to positive x∗j form a basis of (P) for which x∗ is the associated basic
solution.
If x∗ is a degenerate BFS of (P), the set of column vectors of A corresponding to positive x∗j is linearly independent, but does not consist of
enough vectors to form a basis. It is possible to expand this set with some
more column vectors of A to a basis.
3. DEGENERACY IN LINEAR PROGRAMMING
20
Hence a nondegenerate BFS has a unique basis associated with it. A
degenerate BFS may have many bases associated with it.
A primal feasible basis AB of (P) is said to be a primal nondegenerate
basis if A−1
B b > 0.
It is said to be a primal degenerate basis if at least one of the components
in the vector A−1
B b is zero. Let us see it in the pivot tableau:
i
...
+
+
0
+
..
.
+
In a degenerate BFS, if we perform the standard pivot operation to improve the objective value, the minimum ratio can turn out to be zero. When
this happens, the pivot operation just changes the basic vector, but the BFS
corresponding to it and the objective value remain unchanged. In the next
pivot step might the same happens and after a series of such pivot steps, it
might return to the basic vector which started these degenerate pivot steps,
e.g. AB1 → AB2 → ... → AB1 . In such a case, it is said that the algorithm
cycle due to degeneracy.
In a nondegenerate BFS the values of all the basic variables are positive.
Therefore, the minimum ratio in a pivot step from a nondegenerate BFS
is always positive and such a step in the course of the simplex algorithm
is guaranteed to result in a strict decreasing in the objective value. Since
the objective value never increases in the course of the algorithm, once a
strict decrease in it occurs, we will never go back to any previous basis in
subsequent steps. The cycling can never begin with a nondegenerate BFS.
3.1.2
Dual Degeneracy and Nondegeneracy
A basis AB of (P) is said to be dual degenerate, if the reduced costs coefficient
of at least one nonbasic variable is zero in the canonical tableau with respect
to the basis AB .
A basis AB of (1) is said to be dual nondegenerate, if the reduced costs
coefficient of all the nonbasic variable are nonzero in the canonical tableau
with respect to the basis AB .
3. DEGENERACY IN LINEAR PROGRAMMING
21
−, −..0..−, −
j
A linear programming problem is said to be dual nondegenerate if in every
solution (y∗ , s∗ ) for y∗T A + s∗ = c in which the variables are y and s∗ , at
least n-m of the s∗j are nonzero; otherwise, it is dual degenerate. If (P) is dual
nondegenerate, then the reduced cost coefficients of all the nonbasic variables
will be nonzero in the canonical tableau with respect to any bases for (P).
A sufficient condition for (P) to have a unique optimal solution is that
there exist an optimal basis for (P) that is dual nondegenerate.
Suppose an optimal solution is obtained when an linear programming
problem is solved. If some of the nonbasic variables have zero reduced cost
coefficients in the final optimal canonical tableau, that means there is dual
degeneracy. In this case, alternative optimal solutions for the problem can be
obtained by bringing a nonbasic variable with zero reduced costs coefficients
into the basis . We will discuss about the alternative optimal solution later.
3.2
Geometry of Degeneracy
A primal feasible basis AB of (P) is said to be a primal nondegenerate basis if
all the components in the vector A−1
B b are nonzero. The linear programming
problem is said to be totally (primal) nondegenerate if every basis for (P) is
nondegenerate.
Equivalently, (P) is totally nondegenerate if b cannot be expressed as a
linear combination of any subset of m − 1 of less column vectors of A, that
is, if b does not lie in any subspace that is the linear hull of a set of m − 1
or less column vectors of the matrix A.




1 0 0 0
1




Example 16 A =  0 1 0 1 , b =  −1 
0 0 1 1
0
In this example, b can be expressed as a linear combination of a1 and a2 .
Hence, this problem is primal degenerate. Also any bases for this problem
22
3. DEGENERACY IN LINEAR PROGRAMMING
that includes a1 and a2 as basic vectors is a degenerate basis. The problem
becomes primal nondegenerate if b does not lie on any of these four planes
in the picture.
x3
A3=(0,0,1)
A1=(1,0,0)
x1
b=(-1,1,0)
A2=(0,1,0)
A4=(1,0,-1)
x2
The problem (P) is degenerate if b is in a subspace that is the linear
Pm−1hull
of a set of m − 1 or less column vectors of A. There are at most r=1 nr
subsets of column vectors of A with m − 1 or less column vectors in them.
The linear hull of each of these subsets if a subspace of dimension m − 1 or
less. The problem (P) is degenerate if b lies in one of these subspaces. When
A is fixed, the set of all b that make (P) degenerate is the set of all b that lie
in a finite number of subspaces of dimension m − 1 or less. Thus almost all
b will make (P) nondegenerate. Also if (P) is degenerate, there are methods
what would make (P) nondegenerate. For example b can be perturbed to a
point in its neighborhood that is not in any of the finite number of subspaces.
We will discuss these methods later.
We know, that if a basic solution is nondegenerate, it suits an unique
feasible basis, however if it is degenerate, it will be determined by more
feasible bases. As a consequence of this relationship, a linear programming
problem with given standard form has maximum (nm ) feasible bases, so the
number of its bases solution can not exceed (nm ), hence the polyhedron will
not have more than (nm ) vertices.
As we know, P ∗ = x ∈ Rn |Ax = b, x ≥ 0, cT x = ζ . So, the set of
optimal solutions of an linear programming problem is a convex polyhedron.
It is easily to proof, that if the problem has more optimal value, then it
is dual degenerate.
23
3. DEGENERACY IN LINEAR PROGRAMMING
Theorem 17 Let us assume that a problem (P) is given. Suppose that the
optimal value has been obtained at several vertices, then the convex combination of these optimal solutions is also an optimal solution. In this case the
problem (P) is dual degenerate.
How many optimal solutions does a linear programming problem have,
the following corollary will give an answer for this question.
Corollary 18 Let us assume that a problem (P) is given and that the feasible
solution set, P is bounded. If there is at least two optimal solutions, then
these are infinite number of optimal solutions, too.
3.3
Anti cycling Pivot Rule
We know, if the linear programming problem is degeneracy, then the algorithm may cycle. That means, the algorithm goes through a series of bases,
and return to the basis which started the degenerate pivot steps. Therefore,
the iteration will never end. To prevent this phenomenon several methods are
found. E.g. perturbation method, lexicographic method, or Bland pivoting
rule.
At first let us see a cycling example.
Example 19 Let us see an example for cycling and perturbation method:
maximize
subject to
10x1 − 57x2 − 9x3 − 24x4
0.5x1 − 5.5x2 − 2.5x3 + 9x4 + x5 = 0
0.5x1 − 1.5x2 − 0.5x3 + x4 + x6 = 0
x1 + x7 = 1
The initial tableau is:
1.
x5
x6
x7
c
x1
x2
x3
x4 x5 x6 x7
0.5 −5.5 −2.5
9 1 0 0
0.5 −1.5 −0.5
1 0 1 0
1
0
0
0 0 0 1
10 −57
−9 −24 0 0 0
b
0
0
1
0
The pivot rules:
(1) The entering variable will always be the nonbasic variable that has
the largest positive coefficient in the object function row.
24
3. DEGENERACY IN LINEAR PROGRAMMING
(2) If two or more basic variables compete for leaving the basis, then the
candidate with the smallest subscript will be made to leave.
Now, the entering variable should be x1
After the first iteration:
2. x1
x2 x3
x4
x5 x6 x7
x1
1 −11 −5
18
2 0 0
x6
0
4
2
−8 −1 1 0
x7
0
11
5 −18 −2 0 1
c 0
53 41 −204 −20 0 0
After the
3. x1
x1
1
x2
0
x7
0
c 0
b
0
0
1
0
second iteration:
x2
x3
x4
x5
x6 x7
0
0.5 −4 −0.75
2.75 0
1
0.5 −2 −0.25
0.25 0
0 −0.5
4
0.75
13.25 1
0
41 −98 −6.75 −13.25 0
After the third iteration:
4.
x1 x2 x3 x4
x5
x6 x7
x3
2 0 1 −8 −1.5
5.5 0
x2
−1 1 0
2
0.5 −2.5 0
x7
1 0 0
0
0
0 1
c −29 0 0 18
15 −93 0
b
0
0
1
0
After the fourth iteration:
5.
x1 x2 x3 x4
x5
x6 x7
x3
−2
4 1 0 0.5 −4.5 0
x4 −0.5 0.5 0 1 0.25 −1.25 0
x7
1
0 0 0
0
0 1
c −20 −9 0 0 10.5 −70.5 0
b
0
0
1
0
After the fifth iteration:
6. x1
x2
x3 x4
x5
x6 x7
x5 −4
8
2 0
1 −9 0
x4 0.5
1.5 −0.5 1
0 −1 0
x7
1
0
0 0
0
0 1
c 22 −93 −21 0 10.5 −24 0
b
0
0
1
0
After the sixth iteration:
b
0
0
1
0
25
3. DEGENERACY IN LINEAR PROGRAMMING
7.
x5
x6
x7
c
x1
x2
x3
x4 x5 x6 x7
0.5 −5.5 −2.5
9 1 0 0
0.5 −1.5 −0.5
1 0 1 0
1
0
0
0 0 0 1
10 −57
−9 −24 0 0 0
b
0
0
1
0
Since the basic variables after the sixth iteration are same than the initial
basis, the method will go through the same six iterations again and again.
This is known as cycling. The cycling can occur only in the presence of
degeneracy: since the value of the objective function increases with each
nondegenerate iteration and remains unchanged after each degenerate one,
all the iterations in the sequence leading from a basic variables set to itself
must be degenerate.
3.3.1
Perturbation method
Suppose a degenerate linear programming problem is given, one method to
avoid algorithm cycling is to modify the data a little. Such methods are
called perturbation methods.
The basic variables currently at zero would most likely assume small
nonzero values if the initial right-hand side b, changed slightly. If the change
is very small, the problem could be considered unchanged for all practical
purpose.
One such perturbation that makes (P) nondegenerate is to replace b by
b(ε) = b + (ε, ε2 , ..., εm )T ,
where ε is an arbitrarily small positive number.
Theorem 20 Given any b ∈ Rm , there exists a positive number ε0, such
that whenever 0 < ε < ε0,

min cT x

Ax = b(ε)
(P )
 ε
x ≥ 0
the perturbed problem(Pε ) is primal nondegenerate.
Proof : Let AB1 , AB2 ,...,ABl be all the bases for (Pε ). Then l =
the bases number.
r
r
r
Let A−1
Br = (β ij ). Since ABp is regular (β i1 , ...β im ) 6= 0, i = 1...m.
¯ r = A−1 b. Then
Let b
Br
n
m
is
26
3. DEGENERACY IN LINEAR PROGRAMMING

A−1
Br b(ε)


=


−
br1 +β r11 ε + ... + β r1m εm
..
.
−






brm +β rm1 ε + ... + β rmm εm
for i = 1...m, and r = 1...l, the polynomial, ¯bri + β ri1 η + ... + β rim η m is a
nonzero polynomial in η. Therefore, it has at most m roots. If ε is not equal
to one of these roots, then ¯bri +β ri1 ε + ... + β rim εm 6= 0. The collection of the
roots of all these polynomials in η is a finite set consisting of at most lm2
real numbers. Hence, it is possible to choose a positive number ε0 such that
the roots set contains no element belonging to the open interval 0 < ε < ε0 .
By the construction of the set and the positive number ε0 , it is clear that
in any basic solution of (Pε ) all the bases variables are nonzero and, hence,
that (Pε ) is nondegenerate whenever 0 < ε < ε0 . Suppose (P ) is degenerate. The general strategy is as follows. Replace b
by b(ε) and get the perturbed problem. We know that there exists a positive
number ε0 such that for all 0 < ε < ε0 (Pε ) is nondegenerate. Thus for all
ε that are positive but arbitrarily small, (Pε ) can be solved by applying the
simplex algorithm with no possibility of cycling occurring. It is not necessary
to give ε any specific value as long as it is treated as arbitrarily small, which
will mean that it is strictly smaller than any other positive number with
which it may be compared during the course of the algorithm.
Theorem 21 If AB is a feasible basis for (Pε ), then AB is a feasible basis
for (P ), as well.
−1
¯
Proof : Let A−1
B = (β ij ) and b = AB b. Then


¯

A−1
B b(ε) = 
¯b1 + β ε + ... + β εm
11
1m
¯bm + β m1 ε + ... + β mm εm




Suppose AB is a infeasible basis for (P ), that means, there are some i ,
¯bi < 0, then there exists such small ε, for which ¯bi + β ε + ... + β εm < 0, so
i1
im
¯ ≥ 0 for all i. So AB must be a feasible
we obtain a contradiction. Hence b
basis for (P).
3. DEGENERACY IN LINEAR PROGRAMMING
3.3.2
27
Lexicographic Methods
The perturbation and the lexicographic methods are closely related to each
other. The lexicographic method can be seen as an implementation of the
perturbation method.
Definition 22 A vector a = (a1 , ..., an ) is said to be lexico-positive if a 6= 0
and if the first nonzero component of a is positive. Let us indicate this by
a 0. The vector a is said to be lexico-negative (a ≺ 0) if −a 0. Given
two vectors a = (a1 , ..., an ) and b = (b1 , ..., bn ), a b if a − b 0.
Theorem 23 AB is a feasible basis for (Pε ), with arbitrarily small ε ⇐⇒
(¯bi , β i1 , ...β im ) 0
for all i.
Proof : AB regular implies, that (β i1 , ...β im ) 6= 0, i = 1...m. So the
vector (¯bi , β i1 , ...β im ) is nonzero for all i. When ε is arbitrarily small, the
sign of ¯bi + β i1 ε + ... + β im εm is the same as the sign of the first nonzero
coefficient in this polynomial, the first nonzero component in (¯bi , β i1 , ...β im ).
So ¯bi + β i1 ε + ... + β im εm is positive if the first nonzero component in the
vector (¯bi , β i1 , ...β im ) is positive. With this theorem it is easy to test the feasibility of a basis for (Pε ).
There is no need to give any specific value to ε. There is required only the
right hand-side vector and the inverse of the basis to test the feasibility.
−1
¯
Let AB be a basis for (P), A−1
B = (β ij ), b = AB b. The basis AB is
¯ ≥ 0, the basis AB is called lexico (primal) feasible if
(primal) feasible, if b
¯
(bi , β i1 , ...β im ) 0 for each i = 1 to m. If AB is a nondegenerate feasible basis
¯ > 0, and obviously AB is automatically a lexico feasible basis for
for (P), b
(P). If AB is a degenerate feasible basis for (P), it is lexico feasible iff the
first nonzero entry in (β i1 , ...β im ) is strictly positive for every i such ¯bi = 0.
In conclusion, every feasible basis for perturbated problem(Pε ) for arbitrarily
small ε is automatically lexico feasible to (P). Conversely a feasible basis for
(P) is feasible for (Pε ) for arbitrarily small ε iff it is lexico feasible for (P).
Lexico Primal Simplex Algorithm.
Suppose AB is a feasible basis for (Pε ), A−1
B = (β ij ) and the nonbasic
variable xj will be brought into the basic vector. ¯
aj = A−1
B aj is the pivot
column. If a
¯ij > 0 for some i, then there is a unique lexico minimum among
the nonempty set of vectors
¯bi , β i1 , ...β im /¯
aij : i, such that a
¯ij > 0 .
3. DEGENERACY IN LINEAR PROGRAMMING
28
Assume, that
¯bi , β , ...β
aij = ¯bk , β k1 , ...β km /¯
akj i 6= j,
i1
im /¯
then
¯bi , β , ...β
¯ij /¯
akj ¯bk , β k1 , ...β km ,
i1
im = a
but the A−1
B is nonsingular matrix.
The minimum ratio in the pivot step in solving (Pε ) is as follows
−
m
/¯
aij : i, such that a
¯ij > 0
min
bi +β i1 ε + ... + β im ε
Thus when ε is small, the pivot row is uniquely determined, independent
from the actual value of ε.
Lexico Primal Simplex Minimum Ratio Pivot Row Choice Rule:
Initialization
AB is a primal feasible basis, i.e., xB ≥ 0;
the entering variable is xj
begin
aij : i, such that a
¯ij > 0 ) = 1 then
If (I0 := min ¯bi /¯
STOP then the minimum is unique, the pivot row is determined.
else p := 1
whileIp = min {β in /¯
aij : i ∈ In−1 } =
6 1 do
n := n + 1 (the next row)
endwhile
endif
STOP: the pivot row is determined
end
−1
¯
Let A−1
B = (β ij ) , b = AB b and cB is the row vector of basic cost
coefficients. The appropriate dual solution is y = cTB A−1
B and the object
T¯
value is cB b. The corresponding basic vector


¯b1 + β ε + ... + β εm
11
1m




xB = 

..


.
¯bm + β m1 ε + ... + β mm εm
all nonbasic variables are zero. The objective value
z¯0 = z¯ + y1 ε + ... + ym εm
3. DEGENERACY IN LINEAR PROGRAMMING
29
Suppose the nonbasic variable xj is the entering variable for this pivot
step. Let us denote the objective value after the pivot step with z1 , then we
obtain
m
c¯j β jt
c¯j (¯bj + β j1 ε + ... + β jm εm )
c¯j ¯bj X t
= z¯ +
+
ε (yt +
)
z1 = z¯0 +
a
¯ij
a
¯ij
a
¯ij
t=1
For arbitrarily small ε, z1 < z¯0 . Consequently,
c¯j β j1
c¯j β jm
c¯j ¯bj
z¯ +
, y1 +
, ...ym +
≺ (¯
z , y1 , ...ym ) .
a
¯ij
a
¯ij
a
¯ij
Remark 1 A basis is feasible to (Pε ) if the values of all the bases variables
are lexico positive. When this happens, we say that the basis is lexico feasible.
The algorithm begins with a lexico feasible basis and all the bases in the
course of the algorithm will be lexico feasible.
The termination criteria and the pivot column choice are the same as
under the regular simplex method.
When a leaving variable has been selected, the pivot row is chosen by
the the lexico minimum ratio rule. It determines the entering basis variable
uniquely.
There is a strict lexico decrease in the vector (¯
z , y1 , ...ym ) after each pivot
step. Hence a basis that appeared once can never reappear and cycling cannot
occur. The algorithm must terminate after a finite number of pivot steps.
When the simplex algorithm terminates, the terminal tableau is a terminal
tableau for (Pε ) for all ε < ε0 .
The terminal basis for (Pε ) obtained by the simplex algorithm with the
lexico minimum ratio rule is also a terminal basis for (P ).
Example 24 Now let us see, how we solve the previous cycling problem with
the perturbation method:
The initial tableau should be:
1.
x5
x6
x7
c
x1
x2
x3
x4 x5 x6 x7
b
0.5 −5.5 −2.5
9 1 0 0
ε
0.5 −1.5 −0.5
1 0 1 0
ε2
1
0
0
0 0 0 1 1 + ε3
10 −57
−9 −24 0 0 0
0
30
3. DEGENERACY IN LINEAR PROGRAMMING
The entering variable is again x1 . The constraints x5 ≥ 0, x6 ≥ 0, and
x7 ≥ 0 limit the increase of x1 to 2ε, 2ε2 and 1 + ε3 . Since 2ε2 < 2ε < 1 + ε3 ,
ε , the leaving variable is x6 .
2.
x5
x1
x7
c
x1
x2 x3
x4 x5
x6 x7
b
0 −4 −2
8 1 −1 0
ε − ε2
1 −3 −1
2 0
2 0
2ε2
0
3
1 −2 0 −2 1 1 − 2ε2 + ε3
0 −27
1 −44 0 −20 0
20ε2
3.
x5
x1
x3
c
x1
x2 x3
x4 x5
x6 x7
b
2
0
2 0
4 1 −5
2 2+ε − 5ε + 2ε3
1
0 0
0 0
0
1
1 + ε3
0
3 1 −2 0 −2
1
1 − 2ε2 + ε3
0 −30 0 −42 0 −18 −1
1 + 18ε2 + ε3
This is the optimal tableau for the perturbed problem. It may be converted into the optimal basis for the original problem by simply disregarding
all the terms involving ε.
The lexicographic method is that implementation of the perturbation
method in which ε is symbol, and quantities are compared by the lexicographic rule. It is always possible to choose the leaving variable by the
lexicographic rule: there is always one that is lexicographically smaller than
or equal to all the others. At any time, when the terms involving ε are
deleted, then the tableau for the perturbed problem reduces to a tableau for
the original problem.
Theorem 25 The simplex algorithm terminates, if the leaving variable is
selected by the lexicographic rule in each iteration.
Proof : We should prove that nondegenerate problem will be constructed.
Therefore, we need only consider an arbitrary row:
X
xk = (r0 + r1 ε + ... + rm εm ) −
dj xj
j ∈I
/ B
and prove that at least one of the m + 1 numbers r0 , r1 , ..., rm is different
from 0. If dj = 1 and di = 0 for all basic variables xi i 6= k, results:
n+m
X
j=1
dj xj = r0 + r1 ε + ... + rm εm
31
3. DEGENERACY IN LINEAR PROGRAMMING
The slack variables, xn+i = bi + εi −
n
P
aij xj
(i = 1, 2, ...m).
j=1
We get the equation
n
X
dj xj +
j=1
m
X
dn+i bi + εi −
i=1
n
X
!
aij xj
= r0 + r1 ε + ... + rm εm
j=1
which holds for all choices of numbers x1, x2, ..., xn and ε, ..., εm . Write it as
!
n
m
m
m
X
X
X
X
dj −
dn+i aij xj +
(dn+i − ri ) εi = r0 −
dn+i bi
j=1
i=1
i=1
i=1
consider that the coefficient of each xj , εi, according to the right-hand side,
must equal zero. Thus
dn+i = ri
i = 1, 2, ..., m
m
P
dj =
dn+i aij j = 1, 2, ..., n
i=1
If all the numbers r1 , ..., rm were equal to zero, then dn+i = 0 for all i =
1, 2, ..., m and dj = 0 for all j = 1, 2, ..., n,treat in contradiction with the fact
that dk = 1. 2
Lexico Dual Simplex algorithm
At first, we shall eliminate a variable from a positively dependent pair of
variables. We say, that two variables xp and xq are positively dependent if
there exists a α > 0 constant, that the column vector of xp in the original
tableau is α times the column vector of xq . Let y = xp +αxq , eliminate both
xp and xq from the problem and introduce y into the problem. The result
is an LP with variables less than (P). If y
¯ is the value of y in an optimal
solution of the reduced problem, then replace y
¯ in that solution by x
¯p and
x
¯q , that x
¯p +α¯
xq = y
¯. Especially x
¯p = 0 and x
¯q = y
¯. Thus if the LP contains
a positively dependent pair of variables, one of the variables in the pair can
be deleted by setting it equal to zero.
If (P) is not totally dual nondegenerate, the dual simplex algorithm applied on (P), starting with a dual feasible basic vector, can cycle.
The basis AB and the corresponding basic vector xB are dual feasible for
(P) if c¯j ≥ 0 for each j = 1 to n.
The basis AB and the corresponding basic vector xB are said to be lexico
dual feasible for (P) iff (¯
cj , ≥ a
¯1j , ..., a
¯mj ) 0 for each j = 1 to n.
Obviously, if (P) is totally dual nondegenerate, every dual feasible basis
for (P) is lexico dual feasible and vice versa. If (P) is not totally dual nondegenerate, a basis AB is lexico dual feasible for (P) only if all of the reduce
3. DEGENERACY IN LINEAR PROGRAMMING
32
cost coefficients are nonnegative. And the topmost nonzero entry in every
column of the canonical tableau is strictly positive in every column, in which
the reduce cost coefficient is zero.
In order to resolve dual degeneracy in the Dual Simplex Algorithm the
pivot column choice rule is to apply. The initial basis and all the bases obtained during this algorithm are lexico dual feasible. Pivot Column Choice
Rule to Resolve Dual Degeneracy in the Dual Simplex Algorithm:
Initialization
xB lexico dual feasible basic vector AB is a corresponding basis.
the leaving variable is xr
begin
If (I0 := min {¯
cj /¯
arj : j, such that a
¯rj < 0}) = 1 then
STOP then the minimum is unique, the pivot row is determined.
else s := 1
whileIs = min {¯
ani /¯
arj : j ∈ In−1 } =
6 1 do
n := n + 1 (the next column)
endwhile
endif
STOP: the pivot column is determined
end
In this algorithm is the pivot row chosen according to the dual simplex algorithm discussed in the second section, suppose it is row r. If the primal
infeasibility criterion is satisfied, (¯
ar1 , ..., a
¯rn ) ≥ 0, then the problem is infeasible. On the other hand, if there exists j, that a
¯rj < 0, then the entering
variable is xs , that
(¯
cj , a
¯1j , ..., a
¯mj )
(¯
cs , a
¯1s , ..., a
¯ms )
= lexico min
, j, that a
¯rj < 0
−¯
ars
−¯
arj
If the lexico minimum is not unique, let S := {i, i tied for it} . The set of all
variables xj for j ∈ S are pairwise positively dependent in this case. Select
any one of the variables xs for some s ∈ S as the entering variable into the
basic vector xB , set all other xj for j ∈ S, j 6= s equal to zero. Delete them
and the corresponding column vectors. The column vector of xs is the pivot
column.
If xB is a lexico dual feasible basic vector, and the pivot column is chosen
by the above procedure, then the basic vector obtained after this pivot remains also lexico dual feasible. The vector (−¯
z , ¯b1 , ..., ¯bm ) undergoes a strict
lexico decrease in the pivot step. If (P) is solved by the dual simplex algorithm, which starts with a lexico dual feasible basic vector, determines the
3. DEGENERACY IN LINEAR PROGRAMMING
33
pivot column in each pivot step by this procedure, then cycling cannot occur
and the algorithm must terminate after a finite number of pivot steps. And
it satisfies one of the termination conditions in the dual simplex algorithm.
3.3.3
Bland Pivoting Rule
In the preceding section we have discussed the lexico minimum ratio rule.
One disadvantage of that is it may require the entries in the basic inverse in
each step. If the problem is solved using the product form of the inverse, computing the basic inverse is computationally expensive. Another method for
resolving degeneracy has been developed by R.G.Bland[9]. In this method,
both the pivot entering nonbasic variable and the leaving basic variable are
selected uniquely by the rule. The method requires that a ordering of the
variables in problem be chosen before the algorithm is initiated. According
to Bland, this ordering can be arbitrary, but once it is selected, it is fixed and
cannot be changed after the algorithm is initiated. But, the recent research
showed, that the order of the variables need not to be fixed in the beginning,
let us just thinking about the new criss-cross algorithm[8].
In each pivot step, the entering nonbasic variable and the leaving basic
variable are chosen to be the first variables that are eligible to enter and leave
the basic vector in that step, when the variables are examined in the specific
ordering chosen for the variables.
Without any loss of generality we assume that the specific ordering chosen for the variables is the natural order x1 , x2 , ..., xn . In this case, Bland’s
entering and leaving variable choice rule is called the least subscript or least
index rule.
Theorem 26 (R.G.Bland) The simplex method terminates when the entering and leaving variables are selected by the least index rule in each iteration.
Proof : We need to show that cycling can not occur, when the smallest
subscript rule is used. Because if the simplex method fails to terminate, then
it must cycle.
Suppose the algorithm cycle on the basis sequence of iterations AB0 , AB1 ,
AB2 , ..., ABk , such that AB0 = ABk in a sequence of degenerate iteration. Let
xl have the largest subscript among the variables, which are nonbasic variable in some bases and basic variable in some bases. In the basis sequence
AB0 , AB1 , AB2 , ..., ABk there is a basis AB , where xl was the leaving variable,
and xs was the entering variable. Because of the assumption, that the algorithm is cycling. In the sequence AB0 , AB1 , AB2 , ..., ABk , AB0 , AB1 , AB2 , ...,
34
3. DEGENERACY IN LINEAR PROGRAMMING
ABk , there have to be another basis A∗B , where xl was the leaving variable.
Therefore, we can record AB as
X
x i = bi −
aij xj (i ∈ IB )
j ∈I
/ B
and the objective function value
z=v+
X
cj xj
j ∈I
/ B
The iterations between AB and A∗B are degenerate, so the objective function
z has same value v. Thus, z may be recorded as
z=v+
n+m
X
c∗j xj ,
j=1
c∗j = 0 whenever j ∈ IB∗ . This equation will be satisfied by every solution of
AB , especially xj = 0, j ∈
/ IB and j 6= s, xi = bi − ais xs (i ∈ IB ), z = v + cs xs
for every xs .
Thus we obtain
X
v + cs xs = v + c∗s xs +
c∗i (bi − ais xs )
i∈IB
therefore
(cs − c∗s +
X
c∗i ais )xs =
i∈IB
X
c∗i bi
i∈IB
for every xs . The right-hand side of the last equation is a constant independent of xs , conclusion
X
cs − c∗s +
c∗i ais = 0.
i∈IB
xs is entering variable in AB , according to the entering variable choice
rule cs > 0. The vector xs is not entering variable in IB∗ and s > l, so we have
c∗s ≤ 0. Therefore we get c∗r ars < 0 for some r ∈ IB . As r ∈ IB , so c∗r 6= 0,
so r ∈
/ IB , since xl has the largest subscript, r ≤ l. But r 6= l, because xl is
leaving variable in AB , als > 0 and so c∗l als > 0. Now r < l and xr is not
entering variable in A∗B . Thus c∗r ≤ 0, we have c∗r ars < 0 above, we obtain
ars > 0.
As all the iterations between AB and A∗B are degenerate, both of the two
bases write down same solution. xr is zero in both pivoting tableau of the
two bases, because xr is nonbasic variable in A∗B , so br = 0. Thus xr should
3. DEGENERACY IN LINEAR PROGRAMMING
35
be the leaving variable in AB , but we choose the xl , even though r < t. Here
we get the contradiction. The difference between the lexicographic minimum ratio version and the
Bland’s version of the simplex algorithm is: The lexicographic minimum ratio
starts with an initial lexico primal feasible basic vector, the entering variable
is random, but the leaving variable must be chosen by the lexico minimum
ratio test. On the other hand, the Bland’s pivoting rule begins with any
feasible basis, in each pivot iteration the entering or the leaving variables are
uniquely selected by the rule.
3.4
The Alternative optimal Solutions
Suppose an optimal solution is obtained when an linear programming problem is solved. Let xs be a nonbasic variable in the final optimal canonical
tableau, if reduce cost c¯s = 0, and if the operation of bringing xs into the basic vector involves a nondegenerate pivot step, this step yields an alternative
optimal BFS. The alternative optimal bases are obtained by bringing into an
optimal basic vector any nonbasic variable with a zero reduce cost coefficient.
Therefore, the sufficient condition for (P) to have a unique optimal solution
is:
Theorem 27 If there exists an optimal basic vector for an linear programming problem, whose reduce cost coefficients of all the nonbasic variables are
strictly positive, then the corresponding BFS is the unique optimal solution
of this LP.
The set of optimal solutions of the primal problem is
P ∗ := x ∈ Rn |Ax = b, x ≥ 0, cT x = ζ .
• If P ∗ = , then it does not have any optimal solution.
• If P ∗ 6= , then the linear programming problem has any optimal solution.
• If |P ∗ | =1,then it has a unique optimal solution.
• If |P ∗ | ≥2,then it has alternative optimal solution.
3. DEGENERACY IN LINEAR PROGRAMMING
Example 28 Let us see
4x1
x1
maximize
2x1
subject to
x1
The initial full
1. x1 x2
s1
1 −1
1
1
2
1
c 4
3
36
the following linear programming problem
+ 3x2 − x3 + x4
− x2 + 2x3 + x4 ≤ 8
+ x2 + x3 − x4 = 10
+ x2 − x3 + x4 = 16
x1 , x2 , x, x4 ≥ 0
tableau is:
x 3 x 4 s1
b
2
1 1 8
−1
1 0 10
1 −1 0 16
−1
1 0 0
Consider, the objective function is maximal, using the least script pivoting
rule, the variable x1 shall enter the basis, because c¯1 = 4 > 0. The leaving
variablecan be determined
by ratio test:
16
,
=
min
{8,
10, 8} = 8. So the pivot element is a
¯11.
min 18 , 10
1 2
2. x1 x2 x3 x4 s1
b
x1
1 −1
2
1
1
8
0
2 −3
0 -1
2
0
3 −3 −3 −2
0
c 0
7 −9 −3 −4 −32
3.
x1
x2
c
x1 x2 x3 x4
s1
b
1 0
1
0
1/3
8
0 0 −1
2
1/3
2
0 1 −1 −1 −2/3
0
0 0 −2
4
2/3 −32
4.
x1
x4
x2
c
x1 x2
x3 x4
s1
b
1 0
1 0
1/3
8
0 0 −1/2 1
1/6
1
0 1 −3/2 0 −1/2
1
0 0
0 0
0 −36
The basic variables are x1 , x4 , x2 . The nonbasic variables are x3 , s1 . The
optimal basic solution is x¯1 = (8, 1, 0, 1) and the optimal objective function
value is 36. In this pivot tableau the reduce cost coefficients are zero, the
optimal solution is dual degenerate, thus, there exists alternative optimal
solutions. If we pivot continuously, with the entering variable x3 :
3. DEGENERACY IN LINEAR PROGRAMMING
5.
x3
x4
x2
c
37
x1 x2 x3 x4
s1
b
1 0 1 0 1/3
8
1/2 0 0 1 1/3
5
3/2 1 0 0
0
13
0 0 0 0
0 −36
The solution can be read from this pivot tableau: x¯2 = (0, 13, 8, 5). But
if the entering variable is s1 , the optimal solution will be x¯3 = (6, 4, 0, 0).
5/ .
x1
s1
x2
c
x 1 x 2 x 3 x 4 s1
b
1 0 −2 −2 0
6
0 0 −3
6 1
6
0 1 −3
3 0
4
0 0
0
0 0 −36
Further more, the convex combination of the optimal basic solutions are
also optimal solutions of the original problem. For instance:
1
1
x¯ = x¯1 + x¯2 = (4, 7, 4, 3)
2
2
and the corresponding value of object function is 36.
Consider the pivot ordering is as follows: x2 ≺ x3 ≺ x1 ≺ x4 ≺ s1 , then
we have:
10 . x2 x3 x1 x4 s1
b
s1 -1
2 1
1 1 8
1 -1 1
1 0 10
1
1 2 −1 0 16
c 3 −1 4
1 0 0
20 .
s1
x2
c
30 .
s1
x2
x3
c
x 2 x 3 x 1 x 4 s1
b
0
1 2
2 1
8
1 −1 1
1 0
10
0
2 1 −2 0
16
3
2 1 −2 0 −30
x2 x3
0 0
1 0
0 1
0 0
x 1 x 4 s1
b
3/2
3 1
15
3/2
0 0
13
1/2 −1 0
3
0
0 0 −36
In this pivot table, we can read out the another optimal solution x¯4 =
(0, 13, 3, 0) vector.
3. DEGENERACY IN LINEAR PROGRAMMING
38
Assume a linear programming problem is given, if it is dual degenerate,
then it has alternative optimal solution. There are some methods, using
them the alternative optimal solutions can be found.
1. Several data in the problem should be modified a little. So-called perturbation method.
2. The ordering of linear programming problem data should be modified,
in other words, the rows and columns in pivot table should be permutated. Fukuda and Namiki showed the result in linear complementarity
problem. [10]
3. Assume the objective value of a linear programming problem is obtained, then the objective function can be fixed with the objective
value. We add this as a constraint condition to the other condition.
Then we get a optimal solution set in a implicit way.
4. Assume the objective value of a linear programming problem is obtained, if the problem is dual degenerate. We can pivot continuous to
get other alternative solutions.
4. PARAMETRICAL LINEAR PROGRAMMING
4
39
Parametrical Linear Programming
In linear programming problems that are arising from applications, the numerical data often represent only rough estimates of quantities that are inherently difficult to predict. It often happens that the coefficients of the
objective function or the right-hand-side constants are not precisely known
at the time the problem is being solved. For example, market prices may
fluctuate, supplies of raw materials and demands for finished products are
often unknown in advance, and production may be effected by a variety of
accidental events such as machine breakdowns. Each variation changes its
objective function, and thus, creates a new problem. Since each of these new
linear programming problems might possibly represent the actual situation,
it is useful to find out how the optimal solutions vary with the changes in
data. The special literature can be find in [3][1][11].
Since we are dealing only with linear models here, it is assumed that the
coefficients of the objective function or the right-hand-side constants vector
vary linearly with the parameters. Let us see the case where there is only
one parameter λ. Such problems, in which are more parameters, are much
more difficult problems. The two types of parametrical linear programming
are parametric cost problem and parametric right-hand-side problem.
4.1
The Parametric Cost Problem
The problem to be solved is of the following form:

min zλ (x) = (c+λc0 )T x 
(Pobj )
Ax = b

x ≥ 0
where c and x are vectors in Rn , b is a vector in Rm , the matrix A is an m ×
n real matrix assume, rank(A) = m. The λ is a parameter, that takes real
values.
In (Pobj ) if z(x) = cT x and z 0 (x) = c0T x, then zλ (x) = z(x) + λz 0 (x). For
any fix value of λ, (Pobj ) is a standard linear programming problem. If AB
is a feasible basis for (Pobj ), it is an optimal basis for a specified value of
λ if all the reduce cost coefficients are nonnegative for that value of λ. The
updating operation can be carried out by treating each cost coefficient as a
function of λ,without giving any specific value for it. All of there reduce cost
coefficients will turn out to be functions of λ, and AB is an optimal basis for
all values of λ that keep all the relative cost coefficients be nonnegative. In
the tableau we write the parametric objective function in two rows. One row
40
4. PARAMETRICAL LINEAR PROGRAMMING
contains the constant terms of the objective function, corresponding to z(x).
The another row contains all the coefficients of λ in the objective function,
corresponding to z 0 (x). As followings:
a11
..
.
· · · a1j
..
.
· · · a1n
..
.
b1
..
.
am1
c1
c01
· · · amj
· · · cj
· · · c0j
· · · amm
· · · cn
· · · c0n
bm
0
0
The question of the feasibility of (Pobj ) does not depend on λ , since λ
affects only the objective function in (Pobj ). Thus if (Pobj ) is infeasible for
some λ , it is infeasible for all values of λ and it terminates.
The parametric cost simplex algorithm begins with an optimal basis for
(Pobj ) for some fixed value of the parameter λ, for example λ = 0 and then
solves (Pobj ) for all values of λ, using only primal simplex pivot steps.
Assume, for specified value of λ (= λ0 ), the problem is solved. Let
xB = (x1 , ..., xm ), associated with the basis AB , be an optimal basic vector. If
cB , c0B are the cost vectors associated with the basic vector xB , y = cTB A−1
B
−1
A
and y0 = c0T
.
The
relative
cost
coefficient
of
x
as
a
function
of
the
j
B B
parameter λ is c¯j = cj − yT a·j and c¯0j = c0j − y0T a·j
If the parameter λ satisfies the condition
c¯j + λ¯
c0j ≥ 0
for all
j.
Then the basis AB is still the optimal basis. Therefore a necessary condition
for AB to be an optimal basis is
c¯j ≥ 0
∀j
such c¯0j = 0
The optimality criterion for AB to be optimal.¯
c0 is c¯j + λ¯
cj ≥ 0 for all j.
0
0
0
If c¯j > 0, consequently λ ≥ c¯j /¯
cj . If c¯j < 0, then λ ≤ c¯j /¯
c0j . Let
o
n
−¯
c
λB = min c¯0 j : j, such that c¯0j < 0
j
=
λB
=
+∞ n
min
−¯
cj
c¯0j
if c¯0j ≥ 0 for all j
o
: j, such that c¯0j > 0
= −∞
if c¯0j ≤ 0 for all j
Definition 29 The interval λ : λB ≤ λ ≤ λB = λB , λB is called as the
optimal interval, AB is an optimal basis.
The value λB is called as the lower characteristic value of the basis AB .
The value λB is called as the upper characteristic value of the basis AB .
41
4. PARAMETRICAL LINEAR PROGRAMMING
If λB < λB , the optimal interval of the basis AB is empty and AB can
never be an optimal basis.
If the optimality interval of a basis AB is nonempty, for the λ ∈ λB , λB ,
an optimal basic feasible solution is:
The basic vector:
xB
All nonbasic variables
Optimal objective value
Optimal dual solution
=
=
=
=
¯ = A−1 b
b
B
0
z¯ + λ¯
z0
y + λy 0
Therefore, in the optimal interval, the optimal solution is the same, but
the optimal objective value is a linear function of λ.
If the λ outside the optimality interval of AB , then AB is not an optimal
basis for the linear programming problem.
Assume, λ > λB , AB is a primal feasible basis for the parametric problem
(Pobj ) with an nonempty optimal interval. Suppose, λB is finite and index
0
ck /¯
ck . When λ > λB , then c¯k + λ¯
c0k <
k attains the minimum, then λB = −¯
0, therefore xk has to be brought into the basic vector. If the a
¯ik ≤ 0
for all i, then the dual infeasibility criterion is satisfied, that means, the
parametric objective function z(x) is unbounded below on the set of feasible
solutions, when λ > λB . If the unboundedness criterion is not satisfied, using
the simplex algorithm, suppose xr is the leaving variable, xk is the entering
variable. We obtain a new basis AB¯ . The optimal interval of AB¯ is another
interval that has its left end point same with λB , the right end point of the
previous basis AB¯ . Similar is the situation, in which λ < λB .
Remark 2 To obtain optimal solutions of (PCP) for λ > λB , after the
entering variable xk is determined, the leaving variable has to be determined
by the primal simplex minimum ratio test in order to retain primal feasibility.
When there is a tie, the leaving basic variable can be chosen arbitrarily among
those eligible, but this could result in cycling at the value of λ = λB . The
algorithm could then keep going indefinitely through a cycle of feasible bases,
everyone of which is only optimal for λ = λB . We will return to this problem
a bit later.
Example 30 Let us solve the following parametric linear programming problem:
42
4. PARAMETRICAL LINEAR PROGRAMMING
max (3 − 6λ)x1 + (2 − 5λ)x2 + (5 + 2λ)x3
x1 + 2x2 + x3 ≤ 430
3x1
+ 2x3 ≤ 460
subject
x1 + 4x2
≤ 420
xj ≥ 0
(j = 1, 2, 3)
At first let λ = 0, then the initial pivot tableau is:
1.
x1
x2
x3
x4
x5
x1
x5
x6
1
3
1
2
0
4
1
2
0
1
0
0
0
1
0
0 430
0 460
1 420
−3 −2 −5
6
5 −2
0
0
0
0
0
0
c
c0
x6
b
0
0
2.
x1
x2
x3
x4
x5
x6
b
x2
x5
x6
1/2
3
−1
1
0
0
1/2
2
−2
1/2
0
−2
0
1
0
0
0
1
215
460
−440
c
c0
−2
7/2
0
−4
1
0 −9/2 −5/2
0
0
0
430
0 −1075
3.
x1
x2
x3
x4
x5
x6
b
x2
x3
x6
−1/4
3/2
2
1
0
0
0
1
0
1/2 −1/4
0
1/2
−2
1
0
0
1
110
230
20
c
c0
4
41/4
0
0
0
1
0 −5/2
2
9/4
0 1350
0 −40
Now, in case λ = 0 we obtain the optimal solution x∗1 = (0, 100, 230, 0, 0, 20)T .
If the following conditions are satisfied, the optimal solution is also optimal
for the parametric problem.



 c¯1
c¯4


 c¯5
+ λ¯
c01
=
4 +
+ λ¯
c04
=
1 −
+ λ¯
c05
=
2 +
41
λ
4
5
λ
2
9
λ
4
≥ 0 ⇒
λ
≥
≥ 0 ⇒
λ
≤
≥ 0 ⇒
λ
≥
−4
41/4
−1
−5/2
−2
9/4
43
4. PARAMETRICAL LINEAR PROGRAMMING
n
o
−4 −2
and λ1B = max 41/4
, 9/4 = − 16
.
41
16 2 Thus in the case, that all λ are in the interval − 41 , 5 , the optimal solution of original parametric LP problem is x∗1 , the value of objective function
is z1∗ = 1350 − 40λ.
1
Consequently, λB = min
n
−1
−5/2
o
=
2
5
If λ > 25 , then c¯4 + λ¯
c04 ≥ 0 condition is not satisfied, we shall bring the x4
into the basic vector, according to the minimum ratio rule x2 is the leaving
basic variable, so we obtain the following pivot tableau:
4.
x1
x2
x3
x4
x3
x6
−1/2
3/2
1
12
0
4
c
c0
9/2
9
-2
5
x4
x5
x6
b
0
1
0
1 −1/2
0
1/2
0
0
0
0
1
200
230
420
0
0
0
0
0 1150
0 460
5/2
1
The current optimal solution is x∗2 = (0, 0, 230, 200, 0, 420)T , according to
the definition of λB and λB :
−9/2 2 −5/2
2
2
λB = +∞ and λB = max
, ,
.
9
5
1
we obtain also the value of objective function is z2∗ = 1150 + 460λ, for all
λ ∈ 25 , +∞ .
If λ < −16
, then c¯1 + λ¯
c01 ≥ 0 condition is not satisfied, we shall bring
41
the x1 into the basic vector, according to the minimum ratio rule x6 is the
leaving basic variable, so we obtain the following pivot tableau:
4.
x1
x2
x3
x4
x5
x6
b
x2
x3
x1
0
0
1
1
0
0
0
1
0
1/4
3/2
−1
−1/8
−1/4
1/2
1/8
−3/4
1/2
205/2
215
10
c
c0
0
0
0
0
0
5
0
-2
1310
0 31/4 -23/8 -41/8 -285/2
44
4. PARAMETRICAL LINEAR PROGRAMMING
The current optimal solution is x∗3 = (10, 205/2, 215, 0, 0, 0)T . If the following conditions are satisfied, the optimal solution is also optimal for the
parametric problem.


c01 = 5 + 31
λ ≥ 0
 c¯1 + λ¯
4
23
0
c¯4 + λ¯
c4 =
λ ≥ 0
8


41
0
c¯5 + λ¯
c5 = -2 − 8 λ ≥ 0
according to the definition of λB and λB :
2
16
0
3
,
=−
and
λB = min
−23/8 −41/8
41
λ3B
= max
−5
31/4
=−
20
.
31
we obtain also the value of objective function is z3∗ = 1310 − 285/2λ, for all
16
λ ∈ − 20
,
−
.
31
41
, then c¯4 + λ¯
c04 ≥ 0 condition is not satisfied, we shall bring
If λ < −20
31
the x1 into the basic vector, according to the minimum ratio rule x6 is the
leaving basic variable, so we obtain the following pivot tableau:
5.
x1
x2
x3
x4
x2
x4
x1
0
0
1
1
0
0
−1/6
2/3
2/3
0
1
0
c
c0
0
0
0 −10/3
0 −31/6
x5
x6
b
−1/12
1/4
−1/6 −1/2
1/3
0
205/2
215
10
0
5/6
1/2
1780/3
0 −19/12 −5/4 −3760/3
The current optimal solution is x∗4 = (460/3, 200/3, 0, 430/3, 0, 0)T , according to the definition of λB and λB :
−1/2
20
10/3 5/6
4
λB = min −
,
,−
=−
and λ3B = −∞.
31/6 19/12
5/4
31
20
we obtain also the value of objective function is z4∗ =, for all λ ∈ −∞, − 31
.
Now we have solved the whole parametric LP problem, the solution is in
the following tableau:
45
4. PARAMETRICAL LINEAR PROGRAMMING
optimal interval the optimal solution the value of objective function
1780
−∞, − 20
( 460
, 200
, 0)T
− 3760
λ
31
3
3
3
3
20 16 , 215)T
λ
− 31 , − 41
(10, 205
1310 − 285
2
2
16 2 − 41 , 5
(0, 100, 230)T
1350 − 40λ
2
,
+∞
(0, 0, 230)T
1150 + 460λ
5
4.2
Parametric Right-Hand-Side problem
Now let us see another type parametric linear programming problem, so
called parametric right-hand-side problem.

 min z(x) = cT x
Ax = b+λb0
(Pb )

x ≥
0
In the parametric right-hand-side problem, the constraints involve the
parameter λ. However, it can be verified from standard results in linear
algebra that if either b and b0 or both do not lie in the linear hull of the
columns of A, then Ax = b + λb0 has a solution for at most a single value of
the parameter λ. This is a trivial case, hence we assume that both b and b0
are in the linear hull. Therefore, if a constraint in Ax = b + λb0 is redundant
for some value of λ, then it is redundant for all values of λ, and it can be
eliminated. Thus we can assume rank(A) = m.
We write the parametric right-hand-side problem in the original tableau:
a11
..
.
am1
c1
· · · a1j
..
.
· · · a1n
..
.
b1
..
.
b01
..
.
· · · amj
· · · cj
· · · amm
· · · cn
bm
0
b0m
0
The parametric right-hand-side simplex algorithm begins with an optimal
basis for (Pb ) for some fixed value of the parameter λ, for example λ = 0 and
then solves (Pb ) for all values of λ, using only dual simplex pivot steps.
Let xB is an optimal basic vector for some specified value of λ = λ0 and
the AB is the associated optimal basis. Let cB be the corresponding reduce
¯ = A−1 b, b
¯ 0 = A−1 b0 , and z¯ = cB A−1 b, z¯0 = cB A−1 b0 . Since
cost vector, b
B
B
B
B
AB is an optimal basis when λ = λ0 , therefore AB is dual feasible. The
parameter λ appears only in the right-hand-side constant vector, hence dual
4. PARAMETRICAL LINEAR PROGRAMMING
46
feasibility of a basis is independent of λ. Thus, AB is an optimal basis for the
parametric right-hand-side problem for all values of λ for which it is primal
¯ b
¯ 0 ≥ 0.
feasible, that is, for all λ satisfying b+λ
The basis AB is primal feasible when λ = λ0 , we must have ¯bi +λ¯b0i ≥ 0
for all i. Therefore a necessary condition for AB to be an optimal basis is
¯bj ≥ 0
∀j
such ¯b0j = 0
The optimality criterion for AB to be optimal is ¯bi +λ¯b0i ≥ 0 for all i.
If ¯b0i > 0, consequently λ ≥ ¯bi /¯b0i . If ¯b0i < 0, then λ ≤ ¯bi /¯b0i . Let
n
o
−¯bi
0
¯
λB = min ¯b0 : i, such that bi < 0
i
= +∞ n
if ¯b0i ≥ 0 for all i
o
−¯bi
0
¯
λB = min ¯b0 : i, such that bi > 0
i
= −∞
if ¯b0 ≤ 0 for all i
i
if λB > λB , AB will never be
a primal feasible basis for any λ. Contrary, if
λB ≤ λB then the λB , λB interval is called characteristic interval or the
optimal interval of the basis AB . For all values of λ in this optimal interval,
the BFS xB is an optimal solution. In this interval, the optimal objective
value and the values of the basic variables in the optimal BFS vary linearly
in λ.
If λB is finite and we have to solve the problem in case λ > λB , with
the assumption, that index k attains the minimum in the definition of λB ,
then λB = −¯bk /¯b0k and for such λ, which λ > λB , ¯bk +λ¯b0k < 0. If the primal
infeasibility criterion (¯
arj ≥ 0 for all j) is satisfied, then the problem is
infeasible whenever λ > λB . In spite of that, if the primal infeasibility
criterion is not satisfied, then we can make a dual simplex pivot step in
the rth row. It gives a consecutive optimal basis AB˜ , whose characteristic
interval to the right of λB . The same procedure is repeated with the new
basis AB˜ until optimal solutions are obtained for all required λ > λB
Return to the original basis AB , suppose λB is finite, we have to solve
the problem in case λ < λB and t attains the maximum in the definition of
λB . The primal infeasibility criterion (¯
atj ≥ 0 for all j) is not satisfied for
λ < λB , a dual simplex pivot step is made in the t th row, and the procedure
continued in a similar manner.
Remark 3 As pointed out in the preceding remark about the parametric cost
simplex algorithm, in trying to get optimal solutions for λ > λB , if there is a
tie in the dual simplex minimum ratio test for the choice of the pivot column,
4. PARAMETRICAL LINEAR PROGRAMMING
47
and the choice is made arbitrarily, cycling can occur at that value of λ = λB
here, too. The same thing can happen when trying to get optimal solutions
for λ < λB .
Methods for resolving this problem of cycling will be discussed later.
Lemma 31 Every parametric right-hand-side problem is the dual of a parametric cost problem and vice versa.
Let us see some properties of the optimal objective value function in
parametric linear programming problems.
Theorem 32 The optimal objective value in a parametric right-hand-side
linear programming problems is
(1) a piecewise linear convex function of the parameter, if the objective
function is being minimized in the problem
(2) a piecewise linear concave function of the parameter, if the objective
function is being maximized in the problem.
Theorem 33 The optimal objective value in a parametric cost linear programming problems is
(1) a piecewise linear concave function of the parameter, if the objective
function is being minimized in the problem
(2) a piecewise linear convex function of the parameter, if the objective
function is being maximized in the problem.
For the proof of these Theorem or Lemma, see [1].
4.3
Resolution of Cycling in The Parametric Simplex
Algorithms
Consider the parametric right-hand-side linear programming problem. Let
us solve it with simplex algorithm. For solving this problem, the parametric
right-hand-side simplex algorithm starts with a basis AB that is optimal
for a fixed value of λ, and determines the optimality interval of AB. If
λB 6= +∞, let J = i : i ties for the minimum in the definition of λB . It
selects an r ∈ J and performs a dual simplex pivot step in row r in the
4. PARAMETRICAL LINEAR PROGRAMMING
48
canonical tableau with respect to the basis AB . This yields an adjacent basis
AB˜ that is also optimal for λ = λB . The lower characteristical value of the
basis AB˜ is λB , and the algorithm continues with AB˜ . However, cycling may
occur at λ = λB .
4.3.1
Resolution of Cycling in the Parametric Right-Hand-Side
Simplex Algorithm
Let I = {1, 2, ..., m}
and xB be an optimal basic vector, for which the optimality interval is λB , λB . The method for resolving cycling in the parametric right-hand-side simplex algorithm requires the use of the lexico dual simplex algorithm, what we have discussed in the third section. Assume, the initial basic vector xB is lexico dual feasible. The AB is the
associated basis, and
¯ = A−1 b, b
¯ 0 = A−1 b0 . Suppose λB < +∞, let T = i : i such ¯bi +λ¯b0i = 0
b
B B
and J = i : i such ¯bi +λ¯b0i = 0 and ¯b0i < 0 , the set of i that tie for the minimum in determining λB . So J ⊂ T. As long as λ = λB , any pivot step
performed in rows i ∈ T , beginning with xB will not change the primal basic solution, because when the basic variable in the pivot row is zero in the
basic solution, the pivot step is a primal degenerate pivot step that leaves
the primal basic solution unchanged. Denote xB˜ is any dual feasible basic
vector containing all the variables xj for j ∈ I\T as basic variables. Suppose
˜ and b
˜ 0 are the associated right-hand-side constant vectors. As conclusion,
b
the basic solution with respect to xB˜ at λ = λB is
˜ b
˜ 0 = b+λ
¯ Bb
¯0
xB˜ = b+λ
and all of the nonbasic variables are equal 0. For all i ∈ T, ˜bi +λB ˜b0i = 0, and
for i ∈
/ T, ˜bi +λB ˜b0i > 0. Thus the upper characteristic value associated with
xB˜ is > λB if ˜b0i > 0 for all i ∈ T. In order to obtain optimal solutions for
values of λ > λB , we consider the subproblem at λ = λB as follows:

P T

min
c¯i xi



i∈I\T
/
P T
0
¯
a
¯ji xi = bj
j∈T
(SP RHSP )

i∈I\T
/


xi
≥ 0
i∈
/ I\T 
The (xi : i ∈
/ I ∩ T ) vector is a dual feasible basic vector for (SPRHSP). The
subproblem can be solved by the lexico dual simplex algorithm in a finite
number of steps without the possibility of cycling. If this process terminates
by satisfying the primal infeasibility criterion in some row, that same row
satisfies the primal infeasibility criterion for the original problem for values
4. PARAMETRICAL LINEAR PROGRAMMING
49
¯ B . On the other hand, if it terminates with an optimal basic vector,
of λ > λ
(xj : j ∈ D), then the basic vector (xj : j ∈ D ∪ (I\T )) is an optimal basic
vector for the original problem at λ = λB , for which the upper characteristic
¯B .
value is > λ
However, it is not necessary to solve the subproblem separately. It can
be carried out on the original problem itself. At each pivot, it is necessary to
check whether the updated b0j ≥ 0 for all j ∈ T . If so, the subproblem pivots
are done and we resume the parametric right-hand-side simplex algorithm.
If not we continue the subproblem pivots by selecting the pivot row as any
arbitrary row in which the present updated b0j ≥ 0, and the pivot column
is choosed by the lexico dual simplex minimum ratio test. After at most a
finite number of such subproblem pivots steps at λ = λB this procedure will
¯ B , or find
either determine, that the original problem is infeasible for λ > λ
an optimal basis for it at λ = λB , for which the upper characteristic value is
¯ B . And then the parametric right-hand-side simplex algorithm
greater than λ
can be continued in the same way.
In similar way we can use the method to determine optimal solutions for
λ < λB .
4.3.2
Resolution of Cycling in the Parametric Cost Simplex Algorithm
Let I = {1, 2, ..., m}
and xB be an optimal basic vector, for which the optimal interval is λB , λB . The method for resolving cycling in the parametric cost simplex algorithm requires the use of the lexico primal simplex
algorithm, what we have discussed in the third section. Assume, the initial basic vector xB is lexico feasible. The AB is the associated basis, and
¯
c = c − cB A−1
c0 = c0 − c0B A−1
B A, furthermore ¯
B A. Suppose λB < +∞, let
0
c0i = 0 and c¯0i < 0}, the
T = {i : i such c¯i +λ¯
ci = 0} and J = {i : i such c¯i +λ¯
set of i that tie for the minimum in determining λB . So J ⊂ T. Denote xB˜
is any primal feasible basic vector containing all the variables xj for j ∈ T
as basic variables. Suppose ˜
c and ˜
c0 are the associated updated cost vectors.
So, for all j ∈ T, c˜j +λ˜
c0j = 0, and c˜j +λ˜
c0j > 0 if j ∈
/ T . The vector xB˜ is
another optimal basic vector at λ = λB value. Thus the upper characteristic
value associated with xB˜ is greater than λB if c˜0j > 0 for all j ∈ T. In order
to obtain optimal solutions for values of λ > λB , we consider the subproblem
at λ = λB as follows:
50
4. PARAMETRICAL LINEAR PROGRAMMING
min
P
a
¯Tji xi
c¯Ti xi
i∈T




≥ 0



P
= ¯bj
i∈T
xi
i∈T
(SP CP )
The vector (xi : i ∈
/ I) is a lexico primal feasible basic vector for (SPCP). The
subproblem can be solved by the lexico primal simplex algorithm in a finite
number of steps without the possibility of cycling. If this process terminates
by satisfying the primal infeasibility criterion in some column, that same
column satisfies the unboundedness criterion for the original problem for
¯ B . On the other hand, if it terminates with an optimal basic
values of λ > λ
vector, the same basis is an optimal basis for the original problem (Pb ) at
¯B .
λ = λB , for which the upper characteristic value is greater than λ
It is not necessary to solve the subproblem separately. It can be carried
out on the original problem itself. At each pivot, it is necessary to check
whether the updated c0j ≥ 0 for all j ∈ T . If so, the subproblem pivots
are done and we resume the parametric cost simplex algorithm. If not we
continue the subproblem pivots by selecting the pivot row as any arbitrary
row in which the present updated b0j ≥ 0, and the pivot column by the
lexico primal simplex minimum ratio test. After at most a finite number of
such subproblem pivots steps at λ = λB this procedure will either determine
that the original problem is unbounded below in the original problem (Pb )
¯ B , or find an optimal basis for it at λ = λB , for which the upper
for λ > λ
¯ B . And then the parametric cost simplex
characteristic value is greater than λ
algorithm can be continued in the same way.
In similar way the method can be used to determine optimal solutions for
λ < λB .
51
5. SENSITIVITY ANALYSIS
5
Sensitivity Analysis
Suppose we have a linear programming problem in practice, which is given
in standard form (P), and an optimal solution is obtained for it. The data
in A, c, b are estimated from practical considerations. Sometimes after the
final optimal solution has been obtained, they have to be changed, other way,
extra constraints or variables have to be added into the model.
The chapter Sensitivity analysis deals with the problem of obtaining an
optimal solution of the modified problem, which starts with the optimal
solution of the original problem. It is also called postoptimality analysis.
Now let us consider the problem, in which only one data changes once a
time. If several changes have to be made, make them one at a time. For
more detail about this topic, see [1][11][3].
In the previous section we have already seen two types of postoptimality
analysis, parametric right-hand-side problem and the parametric cost problem. In this section we discuss various other types of postoptimality analysis.
At first, let us see the fundamental principle of the sensitivity analysis.
Then we will discuss about the sensitivity analysis in coefficient of objective
function, right-hand-side, and matrix.
5.1
The Fundamental Principle of the Sensitivity
Analysis
Assume, a linear programming problem is given in standard form (P).
From the first section, we know, if a basic solution x = (A−1
B b, 0) satisfied
the following two conditions, then it is a optimal solution for the problem
(P).
xB = A−1
B b ≥ 0.
sN = cN − ATN A−T
B cB ≤ 0.
(feasibility)
(optimality)
Let us recall the pivot table in this case.
A−1
B A
A−1
B b
T
cN − (cTB A−1
B A)
−cTB A−1
B b
If the data in the pivot tableau satisfied the previous conditions, then the
basic solution is optimal, and the correspond basis AB is an optimal basis.
Sometimes we have to modify the data in the problem, so it is useful
to find out how the optimal solutions and the optimal basis vary with the
5. SENSITIVITY ANALYSIS
52
changes in data. For instance, the change in b can influence, whether the
xB = A−1
B b ≥ 0 is satisfied yet. The change in c has an effect, whether the
optimality condition sN ≤ 0 is granted still, and the change in data in A
can influence on both of the two conditions. To analysis how these modified
data affect on the optimal solutions, is the job of sensitivity analysis. The
analysis bases on the obtained solution and basis, this is why, it is also called
postoptimality analysis.
The basic theory of sensitivity analysis is to check, whether the two conditions are satisfied still after the change of the data. Summarize the task of
sensitivity analysis is:
Find out the change limits of data, in other words the stable interval, so
that remain the optimal solution or optimal basis.
If the change of data exceed the limits in the previous point, bases on
the original optimal solution or basis, how to obtain the new optimal
solution quickly.
As mentioned above, in practical problem, the following data or condition
modify frequently
1. the coefficient of the objective function, cj
2. the right-hand-side constant, bi
3. the data in matrix aij, consisting introducing an additional constraint
or new variable.
In following, we will discuss about the effect of the changes of data on
optimal solution.
5.2
The sensitivity analysis of coefficients of the
objective function
From the pivot tableau, we can read out, that the change of coefficients in
the objective function may vary the sj ,it may effect, whether the optimality
condition is satisfied. There are two possibilities in this area. First, when
the corresponding variable is in basis, and second, when the corresponding
variable is nonbasic.
Suppose xr is a variable that is not in the optimal basis AB . Assuming
that all the other cost coefficients except cr remain fixed at their specified
values, determine the interval of values of cr , within which AB remains an
53
5. SENSITIVITY ANALYSIS
optimal basis. If the cost coefficient of nonbasic variable xr is changed from
cr into cr + ∆cr , then the basis AB remains an optimal basis as long as
c¯0r = cr + ∆cr − cTB A−T
¯r ≤ 0,
B a
consequently,
∆cr ≥ −¯
cr .
The reduced cost coefficients of all the other variables are independent of
the value of cr , hence they remain nonnegative. If the new value of cr is not
in the closed interval [−¯
cr , +∞], xr is the only nonbasic variable that has
a negative reduced cost coefficient in the modified problem. We shall bring
xr into the basis and continue the algorithm until a terminal basis for the
modified problem is obtained.
Example 34 Suppose the optimal solution for the following linear programming problem is obtained, [11].
min
−x1 − 5x2 − 3x3 − 4x4
2x1 + 3x2 + x3 + 2x4 ≤ 800
5x1 + 4x2 + 3x3 + 4x4 ≤ 1200
subject to
3x1 + 4x2 + 5x3 + 3x4 ≤ 1000
xj ≥ 0
(j = 1, 2, 3, 4)
and we have the optimal tableau:
opt
x1
x5
x4
x2
c
x2
x3
x4
1/4
2
−3/4
0 −13/4
0
−2
1
11/4
13/4
0
11/4
x5
x6
x7
b
0
1
0
1
1/4 −1
0
1 −1
0 −3/4
1
100
200
100
0
0
1/4
1
1300
The questions are:
(1) To remain the current optimal basis, what is the stable interval of the
value of c1 and c3 ?
(2) If the value of c1 change to 5, what is the optimal solution?
From the optimal table, we can read out, that c¯1 = 13
and c¯3 = 11
. To
4
4
remain the optimal basis, ∆cr ≥ −¯
cr has to be satisfied. So we get ∆c1 ≥ − 13
4
13
17
0
0
and ∆c3 ≥ − 11
,
namely
c
=
c
+
∆c
≥
−1
−
=
−
and
c
=
c
+
∆c
≥
1
1
3
3
1
3
4
4
4
11
23
−3 − 4 = − 4 .
54
5. SENSITIVITY ANALYSIS
If c01 = −5 < − 17
, then it is in outside of the stable interval, the optimal
4
solution can not be the same. The newvalue ofthe reduce cost coefficient is
1/4


0
0
T −1
c¯1 = c1 − cB AB a
¯1 = −5 − (0, −4, −5) 
2  = − 43 < 0, so the nonbasic
−3/4
variable x1 should be the entering variable
x1
x2
x3
x4
x5
x6
x7
b
100
200
100
x5
x4
x2
1/4
2
−3/4
0 −13/4
0
−2
1
11/4
0
1
0
1
1/4 −1
0
1 −1
0 −3/4
1
c
−3/4
0
0
0
11/4
1/4
1
1300
continuous the simplex algorithm, we obtain the new optimal table:
x1
x2
x3
x4
x5
x6
x7
b
75
100
175
x5
x1
x2
0
1
0
0 −3 −1/8
0 −1
1/2
1
2
3/8
1
1/8 −7/8
0
1/2 −1/2
0 −3/8
5/8
c
0
0
0
2
3/8
5/8
5/8 1375
Now, suppose all the cost coefficients except cp , which is a basic cost
coefficient, remain fixed at their present value. Determine the interval of
values of cp for which AB remains an optimal basis. Since cp is a basic
cost coefficient, any change in cp changes the dual solution corresponding to
the basis AB , and all the reduce cost coefficients. Suppose cp changes into
c0p = cp + ∆cp , because p ∈ IB , thus
(cB + ∆cB )T A−1
B A =
−1
= cTB A−1
B A + (0, ..., ∆cp , ..., 0)AB A
T
ap1 , a
¯p2 , ..., a
¯pn ),
= cTB A−1
B A + ∆cp (¯
and
c¯0p = cp − cTB A−1
¯p − ∆cp a
¯pj = c¯p − ∆cp a
¯pj
B a
(j = 1, 2, ..., n).
If we want, that the optimal solution remains, then the following condition
has to be satisfied:
¯pj ≥ 0
c¯0p = c¯p − ∆cp a
(j = 1, 2, ..., n).
55
5. SENSITIVITY ANALYSIS
From that we can obtain, if a
¯pj < 0, then ∆cp ≥ c¯p /¯
apj and if a
¯pj > 0, then
∆cp ≤ c¯p /¯
apj . Therefore,
max {¯
cp /¯
apj |¯
apj < 0} ≤ ∆cp ≤ min {¯
cp /¯
apj |¯
apj > 0} .
j
j
If the changed data is not in the interval any more, then we shall continue
the algorithm.
Example 35 For the previous example the stable interval of basic variable
x2 is:
13/4 1/4
11/4 1
max
,
≤ ∆c2 ≤ min
,
−3/4 −3/4
11/4 1
thus − 13 ≤ ∆c2 ≤ 1, if the − 16
≤ c02 ≤ −4, then the optimal solution remains.
3
5.3
The sensitivity analysis of constant on the righthand-side
In the linear programming problem (P) suppose we want to determine the
interval of values of one of the right-hand-side constants, assume br , for which
the basis AB remains optimal.
−1
Due to xB = A−1
B b and z = cB AB b, the changing of bi influences the primal feasibility of the original optimal solution and the optimal value. Hence,
AB remains dual feasible.
Suppose the right-hand-side constant br changes into b0r = br + ∆br and
assume the other data in the problem stay fixed, then the solution changes
according into
x0B = A−1
B (b + ∆b),
in which b = (b1 , b2 , .br .., bm )T and ∆b = (0, ..., ∆br , ..., 0)T . In this case,


0
 .. 
 . 

−1 
−1
−1
−1
−1
0
xB = AB (b + ∆b) =AB b+AB ∆b =AB b+AB  ∆br  =
 . 
 .. 
0
 ¯   −1
  ¯

b1
a1r ∆br
b1 + a−1
1r ∆br
..
..
 ..  
 

.
.
 .  
 

 ¯   −1
  ¯

∆b
=  bi  +  air ∆br  =  bi + a−1
r ,
ir
 .  
 

..
..
 ..  
 

.
.
−1
−1
¯bm
¯bm + a ∆br
amr ∆br
mr
5. SENSITIVITY ANALYSIS
56
−1
−1
th
in which (a−1
row in inverse matrix A−1
1r , a2r , ..., amr ) is r
B . If the optimal
basis AB remains optimal, then the feasibility condition x0B ≥ 0 has to be
satisfied, or in other words,
¯bi + a−1 ∆br ≥ 0
(i = 1, 2, ..., m).
ir
−1
¯ −1
From that we can conclude, if a−1
ir > 0, then ∆br ≥ −bi /air and if air < 0,
then ∆br ≤ −¯bi /a−1
ir . Therefore,
¯
¯
bi −1
bi −1
max − −1 air > 0 ≤ ∆br ≤ min − −1 air < 0 .
air
air
Remark, that in the optimal pivot table, the inverse matrix A−1
B can be
read out in the place of initial basis.
After b changed into b + ∆b, if the optimal basis is not changed, then
the optimal value is:
∗
−1
z0 = cTB A−1
B (b + ∆b) = z + cB AB ∆b
If the changed data is not in the interval any more, then we shall continue
the dual simplex algorithm, until a new optimal basis is obtained.
Example 36 Let us continous the previous example 35, from the optimal
pivot tableau, the A−1
B can be read out:


1
1/4 −1


A−1
1 −1  .
B =  0
0 −3/4
1
Then the stable interval of value of b1 , b2 , b3 ,are:
≤ ∆b1 ≤ +∞, namely,
max − 100
1
−100
≤ ∆b1 ≤ +∞;
100
, − 200
≤ ∆b2 ≤ min − −3/4
, namely, −200 ≤ ∆b1 ≤ 400
;
max − 100
1/4
1
3
max − 100
≤ ∆b3 ≤ min − 100
, − 200
, namely, −100 ≤ ∆b3 ≤ 100.
1
1/4
1
If ∆b3 = −150, then the original optimal solution will be not more optimal, not evenly primal feasible.

x0B

x5


=  x4  = A−1
B (b + ∆b) =
x3



 
250
1
1/4 −1
800
 



=  0
1 −1   1200  =  350  ,
850
−50
0 −3/4
1
57
5. SENSITIVITY ANALYSIS
and


250


z0 = cB A−1
B (b + ∆b) = (0, −4, −5)  350  = −1150
−50
Let us write down these new data into pivot tableau instead of the previous
data, then we get the following pivot table:
x1
x2
x3
x4
x5
x6
x7
b
x5
x4
x2
1/4
2
−3/4
0 −13/4
0
−2
1
11/4
0
1
0
1
1/4 −1
0
1 −1
0 −3/4
1
250
350
−50
c
13/4
0
0
0
1150
11/4
1/4
1
This pivot table is dual feasible, but not primal feasible, let us make a dual
pivot iteration
x1
x5
x4
x2
c
x2
x3
x4
x5
1/4
1/3 −7/3
1
4/3
5/3
1 −4/3 −11/3
0
1
0
0
3 −1/3
11/3
x6
x7
b
1
0
0
0 −2/3
0
1/3
1 −4/3
700/3
850/3
200/3
0
0
4/3 3400/3
Now we get x0∗ = (0, 0, 0, 850
, 700
, 200
, 0)T
3
3
3
and the optimal value is z 0∗ = 3400/3.
5.4
The sensitivity analysis of data in the matrix
This analysis deal with the change of one matrix element, adding constraints,
or adding variables to the linear programming problem. Let us discuss them
one after another.
5.4.1
The change of one matrix element
According to in which column the altered element is the case can be categorized in the following: changes in the coefficients in a nonbasic column vector
or in a basic column.
Changes in the coefficients in a nonbasic column vector
Let xj be a variable that is not in the optimal basis of the given linear
programming problem. And aij is one of the coefficients in the column vector
58
5. SENSITIVITY ANALYSIS
of xj . The question is, if all the other data in the problem except aij remain
fixed at their present values, what is the stable interval of values of aij within
which AB remains an optimal basis. Since xj is a nonbasic variable, a change
in aij does not affect the primal feasibility of AB . A change in aij can only
change the reduce cost coefficient of xj .
aj + ∆¯
aj , then
Suppose the coefficients of xj , ¯
aj changes into ¯
a0j = ¯
aj ,
aj + ∆¯
aj ) = c¯j − cTB A−1
a0j = cj − cTB A−1
c¯0j = cj − cTB A−1
B ∆¯
B (¯
B ¯
f orj = 1, 2, ..., n
the value of c¯0j has to be nonnegative, so that AB remains an optimal basis,
in other word,
cTB A−1
aj ≤ c¯j
(j = 1, 2, ..., n).
B ∆¯
Especially, if ∆¯
aj = (0, ..., ∆aij , ..., 0)T ,

−1
cTB AB
−1
1
, ..., cTB AB
0
..
.



T −1
,
...,
c
A
B B m  ∆aij
i
 .
 ..
0




¯j ,
 = cTB A−1
B i ∆aij ≤ c


from that, we obtain
if
cTB A−1
B
if
−1
cTB AB
i
i
> 0,
then ∆aij ≤ c¯j / cTB A−1
B
< 0,
−1
then ∆aij ≥ c¯j / cTB AB
i
i
.
That determines a closed interval for ∆aij , as long as ∆aij is in this
interval AB remains an optimal basis. But if it is outside this interval, make
the change, bring xj into the basis, and continue with the application of the
algorithm until a new optimal basis is obtained.
Changes in the coefficients in a basic column vector
Suppose xj is a basic variable, the change of its coefficients ¯
aj , can have
.
Therefore
it
influences
on not
effect on both basis AB and the inverse A−1
B
only the optimality of the solution, but also the feasibility, both of the two
condition discussed in the beginning of this section. Here we won’t introduce
the general solution, in this case, the solution depends on the chaged pivot
table.
59
5. SENSITIVITY ANALYSIS
5.4.2
Adding a new variable
Suppose a new variable xn+1 has to be added to a given linear programming
problem, the corresponding cost value is cn+1 , and column vector in the
matrix is an+1 = (a1,n+1 , a2,n+1 , ..., am,n+1 )T . Then we shall attach xn+1 as
an nonbasic variable, and add the following column to the original optimal
table,


a
¯1,n+1
 a

 ¯2,n+1 
¯
an+1 = A−1
a
=


..
B n+1


.
a
¯m,n+1
and
an+1 ,
c¯n+1 = cn+1 − cTB A−1
B ¯
in this way, we obtain the new pivot tableau.
A−1
B A
¯
an+1
A−1
B b
T
cN − (cTB A−1
B A)
c¯n+1
−cTB A−1
B b
If c¯n+1 ≥ 0, then the original optimal solution remains optimal, otherwise
continue with the application of the algorithm until a new optimal basis is
obtained.
5.4.3
Adding a new constraint
Consider the linear programming problem (P) and the optimal basis AB for
it. Suppose the additional constraint is
am+1,1 x1 + am+1,2 x2 + ... + am+1,n xn ≤ bm+1,
in which am+1,j (j = 1, 2, ..., n) and bm+1 are constant.
Let P 0 denote the set of feasible solutions of the modified problem, then
P 0 ⊂ P. Then z(x∗ ) = min {z(x) : x ∈ P} ≤ min {z(x) : x ∈ P 0 }. Hence,
if x∗ ∈ P 0 , the x∗ satisfies the additional constraint, x∗ remains optimal to
the modified problem. On the other hand, x∗ does not satisfy the additional
constraint, then
x∗n+1 = −(am+1,1 x∗1 + am+1,2 x∗2 + ... + am+1,n x∗n ) + bm+1 < 0
in which, xn+1 is the slack variable corresponding to the new additional
constraint.
60
5. SENSITIVITY ANALYSIS
The modified problem is
min
subject to
n
P
z(x) =
cj xj + 0xn+1
j=1
A
0
x
b
.
=
(m+1)
xn+1
bm+1
a
1
xj ≥ 0
(for all j)
To solve that we shall add one row and one column to the original optimal
tableau, that the slack variable xn+1 can be added as a basic variable. In the
column according to the xn+1 there is only one ”1” in the row according to
the basic variable xn+1 , and in the same row, the constants am+1,j have to
be written under the corresponding variable xj (j = 1, 2, ..., n).
In the bigger pivot tableau, pivot iteration should be made in the (i, i)
position, i ∈ IB is basic index, because the new row destroys the unit matrix
in the pivot tableau. Notice, this pivot tableau is obtained by adding a
row and a column to the original optimal table. This is why all of the
computation are only in the new row. After these pivot steps a new pivot
table is obtained. From this pivot table, we can read out, that the reduced
cost coefficients remain the same, thus the modified problem is still dual
feasible. If A−1
B bm+1 ≥ 0, then it is still primal feasible, it means also, that
the optimal solution remains optimal. But if it is negative, then we can solve
the problem by using the dual simplex algorithm.
To understand more about this problem and the method, let us consider
the following example.
Example 37 Let us add the constraint
4x1 + 2x2 − 2x3 + 4x4 ≤ 600
to the example in subsection 5.2. The original optimal table is:
opt
x1
x5
x4
x2
c
x2
x3
x4
1/4
2
−3/4
0 −13/4
0
−2
1
11/4
13/4
0
11/4
x5
x6
x7
b
0
1
0
1
1/4 −1
0
1 −1
0 −3/4
1
100
200
100
0
0
1/4
Now let us add a row and a column into it.
1
1300
61
5. SENSITIVITY ANALYSIS
x1
x2
x3
x4
0 −13/4
0
−2
1
11/4
x5
x6
x7
x8
b
0
1
0
1
1/4 −1
0
1 −1
0 −3/4
1
0
0
0
100
200
100
x5
x4
x2
1/4
2
−3/4
x8
4
2
−2
4
0
0
0
1
0
c
13/4
0
11/4
0
0
1/4
1
0
1300
x3
x4
x5
x6
x7
x8
b
After the pivoting:
x1
x2
x5
x4
x2
x8
1/4
2
−3/4
−5/2
0 −13/4
0
−2
1
11/4
0
1/2
0
1
0
0
1
1/4 −1
0
1 −1
0 −3/4
1
0 −5/2
2
0
100
0
200
0
100
1 −400
c
13/4
0
0
0
0
x1
x2
11/4
x3
x4
x5
1/4
x6
1
x7
x8
b
60
40
220
160
x5
x4
x2
x∪6
0
1
0
1
0 −16/5
0 −9/5
1
13/5
0
-1/5
0
1
0
0
1
0
0
0
0 −4/5
1/10
0 −1/5
2/5
0
2/5 −3/10
1 −4/5 −2/5
c
3
0
0
0
0
14/5
6/5
1300
1/10 1260
So, the optimal solution is x∗ = (1, 220, 0, 40, 50, 150, 0, 0)T and the optimal value is z ∗ = 1260.
Now suppose the additional constraint is an equality
am+1,1 x1 + am+1,2 x2 + ... + am+1,n xn = bm+1 .
If the optimal solution x∗ satisfies the additional constraint, then it remains
the optimal solution, otherwise we can write the coefficients into the pivot
tableau and solve the problem by using the simplex algorithm.
Remark 4 When we add a constraint to the problem, the rank of the matrix usually increases. If the additional constraint is an inequality, the slack
variable becomes just a basic variable. On the other hand, if the additional
5. SENSITIVITY ANALYSIS
62
constraint is an equality, there is no slack variable to become a basic variable,
so we need a auxiliary variable as a basic variable. After that, we use the
two stage simplex algorithm to eliminate it.
6. ANALYSIS OF AN OIL PRODUCTION PLANNING MODEL
6
63
Analysis of an oil production planning model
The linear programming system Aspen PIMS construct from the problem a
file in MPS format, MPSPROB.mps. We analyze the big size oil production planning model in the structure and quantitative considerations. The
analysis is especially in the feasible and local optimal viewpoints.
With CPLEX we tried solve this model with several linear programming
methods, unfortunately, each of them signal the infeasibility of the model.
During the analysis we want chiefly find out the reasons, what can occur
the infeasibility. The solution structure and the optimal value could vary,
hanging up the applied method, if the model were feasible.
We processed an article from Michael A. Tucker, (LP modelling-Past,
Present and Future), taking feasibility and mathematical model into consideration. In the article author gives a summary of the spreader model methods
in oil industry and their numerical experiences in past, present and future.
In order to analysis file in mps format, we introduce the mps linear programming, industrial standard construction.
The PIMS program applies recourse model, with that we obtain alternate
optimal solutions. We analyze them in the consideration of objective function
and structure. Beside that we examine, how much do the solutions, which
are obtained by recourse model, hurt conditions. We come to the conclusion,
that the solutions hurt great percentage of the conditions.
In order to obtain more accurate model and solutions, it was essential
to make a analyzing system, with which the feasibility can be checked, the
structure of MPS file can be changed. In this section we will also discuss
about this analyzing program, which is developed in C++ programming
language for windows platform. We will see also it’s documentation.
6.1
Short analysis about the structure and size of the
model
Currently, we use the Aspen PIMS program to make the product planning
models and also with it’s help to solve the models. The Aspen PIMS is a
commercial LP systems, which is registered trademark of Aspen Technology,
besides there are Petrofine, registered trademark of KBC Process Technologies and GRTMPS, registered trademark of Haverly System, theses system
are all developed for the oil industry in order to generate the product planning model. We will discuss about the program and it’s background in the
next part of our section.
6. ANALYSIS OF AN OIL PRODUCTION PLANNING MODEL
64
The Aspen PIMS program makes us linear programming models in MPS
format, which is a description about industrial standard linear programming
problems, used in spreader area. This format is adopted by most commercial
codes, and is not restricted to the MPS series of codes developed originally
for IBM computers. For more information, see [12]
Now, let us see a short survey of the structure and qualitative properties of
a linear programming model file, which are generated by PIMS. Our analysis
is based on this file.
At first, let us have a look at the structure of the input matrix, which
can be read out in the following picture.
•First •Prev •Next •Last •Go Back •Full Screen •Close •Quit
During this color picture is the structure easy to understand. The blue
points represent the number, which value is -1. The red points is +1. And
any other non-zero value are symbolized with black points. As appropriate,
the null elements are not drawn on the picture. The green zone means,
that the right-hand-side constant of that constraint condition is non-zero.
The violet columns appropriate to the negative coefficients in the objective
function, and the yellow columns appropriate to the positive coefficients in
the objective function. It is noticeable, that somewhere covers one point up
another in the picture, this is due to the big size of the input matrix and the
accuracy. In the followings let us look over some characteristic data.
6. ANALYSIS OF AN OIL PRODUCTION PLANNING MODEL
The number of decision variables:
The number of constraint conditions:
The number of non-zero elements in the input matrix
The number of elements having value 1
The number of elements having value −1
The number of positive elements (but not 1)
The number of negative elements (but not 1)
The number of equality conditions:
The number of smaller or equality conditions:
The number of smaller or equality conditions:
The number of neutral conditions (objective function):
Conditions according to the value of right-hand-side constants
the right-hand-side constant is 0:
the right-hand-side constant is nonnegative:
the right-hand-side constant is nonpositive:
the right-hand-side constant is 1:
the right-hand-side constant is −1:
the right-hand-side constant is greater than b (b 6= 0)
the right-hand-side constant is smaller than b (b 6= 0)
The number of nonnegative variables
The number of free variables
The number of variables with fix value
The number of variables having lower bound
The number of variables having upper bound
Variables having zero coefficients in objective function
Variables having positive coefficients in objective function
Variables having negative coefficients in objective function
Variables with fixed positive coefficients in objective function
Variables with fixed negative coefficients in objective function
65
6471
5601
37603
6318
3630
6774
20881
5051
295
239
16
5051
238
167
0
0
1
128
6345
41
85
3329
3346
6250
149
72
41
41
First of all, it is worth to consider, that a lot of important decision variables, which have non-zero coefficients in objective function, are prominently
fixed in the model.
In the viewpoint of results, the most important variables are those, belong
to them the coefficients in objective function are non-zero. The number of
such variables is small related to the whole problem, in out example, the
number is only about two hundred. Among them 72 coefficients are negative,
in the case of maximal objective function, such variable play important roles.
While the positive coefficients are 149, (such variables model generally the
realization decision.)
6. ANALYSIS OF AN OIL PRODUCTION PLANNING MODEL
66
We can remark here similar proportion between the right-hand-side constants with value 0 and with value non-zero. According to the analysis very
many constraint (5051) have right-hand-side constants with value zero. Such
equality conditions represent generally balance conditions, processes, by accident material balance. The constraint conditions with none-zero righthand-side constants, which number is 129, model in general the qualitative
or quantitative conditions.
It is important to highlight the big number of fixed variables, it is 85
such variables. The overwhelming majority of such variables, according to
the data 82, belong to non-zero coefficients in the objective function, in other
words, they can be treated as essential decision variables. Such conditions
with fixed value will not participate in the optimum.
Similar consideration deserves about the big number of neutral conditions,
which is 16. According to the description about MPS format about the linear
programming problems [12], the neutral conditions are objective functions.
Another possibility is, if some conditions are set to be neutral, then they
don’t participate in the optimal process. In other words, they are deleted in
the viewpoint of results. In our MPS file belong the 16 neutral rows, there
are 2 objective functions, are 14 constraint conditions.
Any other conclusions can be also followed from the structure of MPSPROB.mps file. It is remarkable, there are a lot of null elements in both
objective function and right-hand-side of the LP model. That tell us, this
problem is both primal and dual degenerate. Consequently, it is numerically
difficult to handle. In other words, if the problem has optimal solution, then
it is very likely that, the problem has more alternate optimal solutions of
different constructions.
6.2
Flow Chart of solution by the PIMS
Now let us inspect, how are the product planning models for oil industry produced with the help of the PIMS programming system. We shall consider it
with modelling aspects, optimization aspects and respectively solution analysis aspects.
At first, let us have a look at the following picture about the flow chart of
solution, which can give us a more accurate, reasonable consideration about
the current modelling steps.
6. ANALYSIS OF AN OIL PRODUCTION PLANNING MODEL
67
Flow Chart
PIMS
Data collection and
processing
Choice of algorithm,
parameter settings
LP generation
Distributive
Recursion
Solving LP by
XPressMP
Solution report
In the previous subsection, we have known, that the PIMS program is
used to generate product planning models. Actually, PIMS is only a modelling language program, which can generate the model in lots of formats,
e.g. mps format, about this format we have already discussed.
Now through the previous picture, the structure of the PIMS program is
perspicuous.
At first, the collected data should be sent to PIMS as input data. It gives
users options to choose the algorithms and parameters. With the initial data
the PIMS generate us a linear programming problem. Because, there are
nonlinear constraints in the model, they are linearized, with guessed values.
After that, PIMS calls the XPressMP Linear programming solver to solve
the problem. If XPressMP find it unsolvable, then the algorithm enters in a
so called distributive recursion, which modify the value of some data in the
matrix or in the right-hand side. Afterwards, PIMS begins the cycle from
the parameter setting again. The cycle is go through, until XPressMP can
solve the modified model, or PIMS find this problem is ”strong infeasible”,
which means, the problem is still unsolvable after many cycle iterations.
As previously mentioned, there are nonlinear, nonconvex constraints in
the model, which are linearized with approximated values. This progress
can not only occur numerical instability but also infeasibility, which means,
that the modified problem is unsolvable. A bit later we will discuss about
linearization in detail. Here about the distributive recursion (DR) we do not
want to spend more words, because of the lack of specialized literature about
commercial technique, it is for us still like a black box.
6. ANALYSIS OF AN OIL PRODUCTION PLANNING MODEL
6.3
68
The oil industrial product planning model
Let us have a look more closer, in more detail at oil industrial product planning model. We will see what a role does the linear programming problem
in that model play. In order to be more familiar with oil industrial product
planning model, we found reference material. Unfortunately, because this
area involves many commercial aspects, very few material are public. This
section is based on the article from Michael A. Tucker [13].
During this article the past, present, future of the roles of linear programming in oil industrial model are easy to survey. Due to the substantial change
of the LP modelling systems, non-linear distributive recursion techniques
have been developed, swing cuts have been semi-automated, multi-period and
multi-refinery modelling capabilities have been improved, reformulated gasoline blending capabilities have been incorporated into the systems. Because
of the substantial change of LP model structure, the yield-driven models with
stream properties are moved to recursed property-driven models.
In past, one typical oil industrial model are characteristic of the followings. The crude unit models were presented by a series of yield structures
for each crude. The characteristics were:
• Each cutting scheme had , including max naphtha, max kerosene, etc.
a separate yield structure for each crude.
• The major side-cuts from each crude (and from certain cuts from each
cutting scheme) are unique streams, with unique names and unique
(fixed) qualities.
• The crude assay table data was generally generated by a crude assay
system containing a library of crude oils. Yields and properties from
the assay system were generally those predicted from laboratory TBP
distillations.
The downstream process unit sub-models were also represented by series
of multiple yield structures.
In the interest to distinguish one crude from another, hundreds of yield
structures for process unit sub-model are frequently generated to represent
each possible crude side-cut at multiple operating conditions and multiple
cutting schemes. In many case, between 4 and 20 versions of each product
stream might the process unit be structured to produce. The main characteristics about this type models are the followings:
• Generally, there were 3 to 10 times as many individual streams in the
model as there were streams in the ”real”refinery.
6. ANALYSIS OF AN OIL PRODUCTION PLANNING MODEL
69
• Generally, there were 10 to 20 times as many final product blending
options as there were actual component blending options available in
the ”real” refinery.
The models having the above mentioned characteristics tended to overoptimize the processing and blending of individual crude and their associated
side-cuts throughout the refinery. Those models frequently overstated the
value difference among individual crudes. The distributive recursion(DR)
are found to handle such problems, that is based on the ideas of Bill Hart
mathematician 1 . The distributive recursion technique provides the critical
linkage between upstream changes in pool qualities to the quality changes
in the downstream destinations. Early versions of the DR technique were
slow and difficultly manageable, today, it has become more faster, better
and more reliable.
Currently, there is an infinite variety of modelling techniques being used
in different companies. We can categorize current modelling in the various
areas of the LP model structure.
The distributive recursion techniques are frequently used to set the properties of the most important products. The base, feed property drivers, and
operating variable shifts all contain coefficients that calculate the appropriate recursed product properties. In such model, the coefficients can be either
fixed or determined by recursion. In general, if the properties of products
remains relatively constant regardless or the feed or operating shifts, then
the property may be fixed, otherwise, they may be determined by recursion.
The application of distributive recursion has eliminated the need for multiple
versions of the same stream. The obtained streams match more closely the
streams in the ”real” refinery.
6.4
Problems about the model and the appropriate
analysis
In the most of the current oil industrial linear programming models have
some degree of pooling and property recursion. The distributive recursion
technique requires initial estimations for some data. the distributive recursion is a method for nonlinear programming problem. As many nonlinear
programming method, there will be risks of local optimal solution, in other
words, the solution is optimal only in the own surrounding, not in the view
of the whole problem. In such a case, the value and features of solutions
depend on the initial estimated value, which is determined by the recursion,
1
Bill Hart, a senior mathematician from Haverly Systems.
6. ANALYSIS OF AN OIL PRODUCTION PLANNING MODEL
70
depend on the applied recursion technique, depend evenly on the properties
of the applied linear programming method.
Example 38 Example for Nonlinear modelling technique: Suppose, one con2 x2 +...+bk xk
≤ 0, where x1 + x2 + ... + xk > 0
straint is : b1 xx1 1+b
+x2 +...+xk
It follows that b1 x1 + b2 x2 + ... + bk xk ≤ 0.
It is important to emphasize, that the local optimal phenomenon is not
a property the linear programming problem. In every linear programming
problem, all optimal solutions are at the same time global optimal. The
local optimal phenomenon is caused by the nonlinear technique underlying
the distribute recursion. The distributive recursion technique may change
the constraint matrix and the right-hand-side vector of the original linear
problem.
The following picture shows us an example for local optima:
The phenomena of Local Optima
Caused by nonlinear nonconvex modeling
techniques
In a case for model containing moderate degree of recursion, one situation
between the following two may occur:
• The model users have experienced local optimal problems, and they
know about the existence of local optimum.
• The model users don’t know the existence of local optimal problems,
however, the local optimum exist, but they have not yet been discovered
by accident or testing.
6. ANALYSIS OF AN OIL PRODUCTION PLANNING MODEL
71
According to our experience, almost every such model, which uses the
recursion, have local optimum problem. This is a very serious problem, that
can evenly lead to a lack of confidence in the results of model. Although
local optimum problem in linear programming model supplied with recursion
technique cannot be completely eliminate, but they can be managed. The
handing of this problem can be a combination of the followings:
• Good built model structure, which avoid unnecessary recursion iterations,
• Correctly set the initial estimated values and recursion control parameters. The system default recursion control parameters are not always
the best settings.
• Testing for, searching and then analyzing the local optimal conditions.
Finding the conditions under which the local optimal occur and correcting these conditions.
There is a trend for the applied oil industrial linear programming problems, that more and more multi-period and multi-refinery models are used.
However, we have to call the attention, that such recursed models are susceptible to be unstable, when attempting to use both multi-period and multi refinery in the same case. There are also limitations on the use of multi-refinery.
In general, no more than 3 refineries may be attempted with recursed models.
Such model using big size recursion can be unstable, as represented in the
following picture.
6. ANALYSIS OF AN OIL PRODUCTION PLANNING MODEL
72
At the present time, there are two main best practice methods for monitoring LP performance, maintaining and updating LP models.
First is an overall refinery backcasting process, which may be used to
identify overall model weaknesses, for example, refinery gain higher than
actual, any profit opportunities. Backcasting is to compare the actual results
of the previous month with the plan and an actuated LP case, where the LP
attempts to match the actual results.
The second major activity is for process engineers to monitor their process
units on a weekly or bi-weekly basis. Lab samples, along with plant historian
data are used to compare the actual process unit results against the LP
predicted results for the same period. Process engineers and planners monitor
and compare the actual against the LP predicted and decide if the LP submodel needs updating. In most cases, a process simulator model may be
re-calibrated and used to generate the LP base and delta correctors on an asneeded basis. With this technique, process unit sub-models may be updated
as frequently as several times a year using plant data and tuned simulator
models.
For the problems, one possible solution is suggested. To work out simulator interfaces, with them, the LP system may be directed to an outside
application during each recursion pass. This outside application may be as
simple as a single non-linear equation or as complex as several large complex
process simulation models.
The current concept is that model coefficients that were early static, now
become dynamic, in other words, changing after each recursion iteration.
The correctors are calculated externally from the model and built it back
into the model. These yield correctors are not updated during recursion.
In such way, the LP model predicted yields become less accurate, if the LP
optimized feed deviates significantly from the base feed quality assumptions.
With the help of simulator interface, the linear feed property correctors
may now be calculated and updated during each recursion pass. This improves the accuracy since the final converged solution of the LP more closely
matches the results of the simulation prediction.
However, the risk of local optimal solutions may increase. Since more and
more coefficients are determined by the recursion method, furthermore the
initial assumptions for feed quality become increasingly important as they
may influence the final solution.
6.4.1
Local optimum and alternative optimal solution
As we saw, one of the most important problems of the oil industrial product
planning model is the existence of local optimal solutions. In principle, the
6. ANALYSIS OF AN OIL PRODUCTION PLANNING MODEL
73
local optimum problem belongs to nonlinear programming and never occurs
in linear programming. In general, a big size nonlinear programming problem
is very difficult to solve, especially, due to the local optimums. It is hard to
gain the global optimal solution. If we are in an optimal solution, we are not
able to decide, whether we are in the global optimum or in a local one. In
addition, we have no information about other local optimums or the global
optimum at all.
In many commercial LP systems, such like Aspen PIMS, the nonlinear
distributive recursion techniques have been enhanced in the linear programming models. This exactly means, that we transform the nonlinear programming system to a linear programming model with the help of the distributive
recursion technique. The algorithm starts with initial estimated data. If
the produced linear programming model is not good enough, then the data
should be modified until the model can be solved. As follows, the solution of
the produced linear programming model usually differs from the solution of
the original nonlinear programming problem. If the model is made through
many recursion iterations, it is possible, that completely different problem is
solved than the original one. Consequently, it is essential to verify, whether
the obtained solution is really the solution of the original problem.
In the second section we have discussed, that a linear programming problem can have alternative optimal solutions, when it is dual degenerate. In our
mps file, it is to note, that there are a lot of zero elements in both the objective function and the right-hand-side of the LP model. That shows us, that
this problem is both primal and dual degenerate. If such a linear problem
has an optimal solution, then it also has alternate optimal solutions besides
due to the dual degeneracy. So, the model is difficult to handle numerically.
Suppose, a linear programming problem is given, the question is, how can
we obtain the alternative optimal solutions of it. The answer are followings:
• It is known from the literate of linear programming that when the
columns of the input matrix or tableau of the problem has been permuted and applied the same algorithm. If the linear problem is dual
degenerate, exist alternative optimal solutions, then different optimal
solution might be computed depending on the permutation.
• As we have mentioned in the second section, if there exist alternate optimal solutions, then the convex combinations of them are also optimal
solutions.
• If we make from the objective function an equality constraint, and add
a new objective function to the problem and solve it again, then the
6. ANALYSIS OF AN OIL PRODUCTION PLANNING MODEL
74
objective value for the original problem remains. Because of the change
in structure, we can find alternate optimal solutions.
• If we solve the problem with pivot algorithm, and we have decided, that
the problem has alternate optimum, then we can get alternate optimal
solutions during continuous pivot iterations.
• If we solve the problem with different algorithms.
In practise, it is very useful to find different alternate optimum. Because
of the different structure of the solutions, the comparing and analyzing can
help us make more appropriate decisions.
We know about the alternate optimal solutions of the linear programming
problem, that the objective values of the different alternate optimal solutions
are same. However, if we change the structure of the original oil industrial
product planning nonlinear programming model , e.g. the columns permutation, then we can also gain different optimal solutions from the recursed
linear programming problems. But it is remarkable, that the objective values of that solutions are generally not equal. The explanation about that is
follows, from the same nonlinear programming problem with different structure, different linear programming problems are obtained by the recursion.
The optimal solutions of such linear programming problems are generally
only the local optimal solutions of the initial nonlinear problem.
As we have mentioned, that the local optimum is a difficult manageable
problem for nonlinear programming. But at the same time, the local optimal
solutions comprise much useful information, with that we can make more
accurate decisions. Unfortunately, in current market, there is not such a
reliable program for the big size nonlinear programming problems as the
CPLEX2 software for linear programming systems. At first we did not have
any tools to obtain and analyze the local optimum, even the CPLEX can
not show us the alternative optimum solutions automatically. On the other
hand, a serviceable tool, which can give us the alternative optimal solutions,
are very demanding.
6.4.2
Infeasibility and being unbounded
We know, that the oil industrial product planning problems generally leads to
nonlinear programming with given objective functions. Nonlinear constraints
are usually replaced with linear constraints with guessed data. So we get a
2
www.ilog.com, CPLEX solves a linear programming problem even with great size in
primal simplex, dual simplex and newton barrier method.
6. ANALYSIS OF AN OIL PRODUCTION PLANNING MODEL
75
linear programming problem. Such problems are solved by the commercial
LP systems, like Aspen PIMS, in which the distributive recursion technique
is applied. Some data, which represent the nonlinear constraint function, of
the initial linear programming model, are estimated and not exactly. If it is
necessary, the distributive recursion changed the guessed, or estimated data
of the problem, until the model is solvable, sometimes even many recursion
iteration are adopted.
Unfortunately, this process involves such risks, that a slightly different
problem can be solved than the original. It can evenly happen, that the
PIMS find, the modified, recursed problem is infeasible or even unbounded,
so it can not solve the problem, as well. To avoid these dangers, as we
mentioned above, we shall pay more attention to set more accurate initial
model, avoid unnecessary recursions.
Beside these attempts, it is quite essential to take the necessary steps
to analyzing the problem and the solutions. For example, it is important
to answer the questions like: are they really the solutions of the original
problem, how many conditions are not satisfied, how situate the solutions
related to the feasible solution set.
Therefore, such a post analyzing, checking system, which contains the
functions as mentioned above, is unavoidably required.
6.5
Model collecting
Above we have talked about the program system PIMS, its technique, its
advantages and disadvantages. We have also discussed about the problem
in detail. Now it is time to summarize our analyzing and collecting steps of
model.
In the following the flow chart with the completed necessary complementary steps can be seen.
6. ANALYSIS OF AN OIL PRODUCTION PLANNING MODEL
76
Completed Flow Chart
PIMS
Data collection and
processing
Report, classifying
changes
Choice of algorithm,
parameter settings
LP generation
Distributive
Recursion
Solving LP by
XPressMP
Solution report
Solution analysis,
parameter resetting
Look-back analysis
It is noticeable, that the model analysis is a sufficient step to get correct initial model before all the algorithm steps. Because our model has a
huge size, in order to update it regularly, the automation is necessary. The
following viewpoints are important for a correct model.
• Zero constraints
• Repeated constraints
• Always true constraints
• Mistype possibilities
• Badly scaled rows
• Free, only once occurring variables
• Neutral rows
• Fixed variables
• Tight cone-like constraints
In the step Solution Analysis, parameter resetting, we shall test the
model. Suppose our LP solver is fixed, and the implementation of DR is
6. ANALYSIS OF AN OIL PRODUCTION PLANNING MODEL
77
analyzed. According to the above discussed, the initial nonlinear programming model is solved as sequential LP-s with the linearization by DR. With
the help of many local optimum, deterministic algorithms, we shall analyze
many different guessed values, different parameters, different LP methods,
so that we can get more accurate optimal solutions.
The sensitivity analysis belongs also to this analysis step. As we have
seen in the last section, the sensitivity analysis and parametric programming
are post-optimal algorithms, it makes the modification of the final linear
programming model easier.
For the time being, the distributive recursion seems like to be a black box
for us. However, we have to make checking analysis, so that we can be more
and more familiar with it. We know, if the PIMS find the model is unsolvable,
then it enters the DR, which changes some values of the data, we want to
know how does it work. So, we can build the model with different guessed
initial values, or we change the right-hand side vector after the algorithm
according to the bounds, then the new model should be solved with PIMS
again. Of course such check and report after optimization shall be completed
by automate program.
In final, the look-back analysis should not be ignored. The changed model
by DR may not identify the original problem. The look back analysis should
be made on the modified model. We want to know, whether the realized
production is feasible, what would be the corresponding objective value, what
are the correct guessed values for the realized production.
6.6
User documentation about the analyzing program
In the last part of this thesis, let us have a look at the analyzing program,
which is developed as a tool for our analyzing, studying about the qualification of the solutions, it is also able to give the possibility for getting more
local optimum and alternative optimal solutions of the models.
At first, we will talk about the problem statements and the goal of the
system. Afterwards, the system requirement and general user’s guide of the
program are presented.
Problem statement and the goal of the system
The task of the system or the problems to solve are the followings: Handling MPS file data directly
Principle tasks:
• Be able to read mps format file, loading mps file.
6. ANALYSIS OF AN OIL PRODUCTION PLANNING MODEL
78
• Be able to modify the structure of the linear programming model. E.g.
the order of the variable can be changed, the objective function can be
transformed to a condition.
• Be able to read solution of that model
• Be able to check, whether the given solution satisfies the constraint
conditions, which is determined by the model
• Be able to count out the right-hand-side vector according to the given
solution
• Be able to count out, how far is the solution away from the feasible
solution set of the model, if it is necessary
• Be able to change the right-hand-side, if the solution is outside of the
feasible solution set
• Be able to modify the model and the mps file.
• Be able to save the counted right-hand-side vectors
• Be able to save the modified model
• Be able to compare MPS models
• Be able to regenerate RHS values from solutions, because the distributive recursion have changed the constraint matrix
• Be able to permute data to find alternate optimal solutions
• Be able to compare structure and value of obtained alternate local
optimal solutions
• Be able to fixe value of objective value, and defining new objective
function: a way to find alternate optimal solutions of LP problem
System requirements
Hardware requirements :
• Pentium II & Celeron Processor
• 5 MB storage capacity on hard disk
• 64 MB RAM
6. ANALYSIS OF AN OIL PRODUCTION PLANNING MODEL
79
• Mouse
Software requirements :
• Windows 98 or later version
General user0 s guide
Starting the program :
Starting the program with double click at the mpseditor.exe file, or Run
mpseditor.exe file.
The functions:
From menu file open, we can give the input mps file. In order to check,
whether one solution is feasible, the program can read the solution through
the button ”VectorInput”. The button on the right side, ”Ax=b” give us
the corresponding ”b” vector. Using the scroll, we can glance through the
rows, or columns, concurrently, the objective function, bounds for variables
and bounds for constraints. Because of the big size, it is more efficient to
use the search button, if we want to check one special row, or column. On
the vector ”x” and ”b”, there are two pop-up menu, on which we can save
the hurt bounds into a txt file, or change the bounds according to the vector
”x” or ”b”, then the modified model can be saved in mps format. If there
are more objective functions, we can choose which appear on the screen.
On the followings, the screen shot of the program can be viewed.
REFERENCES
80
References
[1] Katta G. Murty, Linear Programming, Library of Congress Cataloging in Publication Data, (1983) ISBN 0-471-09725-X.
´s Tibor, Line´aris Programoz´as, k´ezirat, (2002).
[2] Ille
´tal, Linear Programming, W.H.Freeman, New York,
[3] Vasek Chva
(1980), ISBN 0-7167-1195-8.
[4] Fried Ervin, Algebra I. (Elemi ´es line´aris algebra), , National Textbook
Publisher stock company, Budapest, (2000) ISBN9-6319-1176-4.
´s, Egy v´eges criss-cross m´odszer ´es alkalmaz´asai, MTA
[5] Terlaky Tama
SZTAKI Tanyulm´anyok 179/1986, Budapest, (1986).
´s, Criss-cross methods: A fresh view
[6] Fukuda K. and Terlaky Tama
on pivot algorithms, Mathematical Programming 79 369-395, (1997).
´s, Monotonic Build-Up
[7] Kurt M. Anstericher and Terlaky Tama
Simplex Algorithm For Linear Programming, Operations Research 42.
556-561, (1991).
´s Tibor and Me
´sza
´ros Katalin, A New and Constructive Proof
[8] Ille
of Two Basic Results of Linear Programming Yugoslav Journal of Operations Research, 11:15-30, (2001).
[9] R.G.Bland, New Finite Pivoting Rules for the Simplex Method, Mathematics of Operations Research 2, 103-107, (1977).
[10] Komei Fukuda and Makoto Namiki, On extremal behaviors of
Murty’s least index method, Mathematical Programming, (1994).
[11] Deng Chengliang, The theory and method of operational research,
Hua Zhong Technical University Publischer, (2001) ISBN 7-5609-1279-6.
[12] Bruce A. Murtagh, Advanced Linear Programming: Computation
and Practice, McGraw-Hill International Book, New York and London,
(1981).
[13] Michaeil A. Tucker, LP modelling - Past, Present and Future,
www.kbcat.com/pdfs/tech, (Dec, 2001).