0% found this document useful (0 votes)
12 views11 pages

Lec 3

Uploaded by

bsalykbaev89
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
12 views11 pages

Lec 3

Uploaded by

bsalykbaev89
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 11

Simplex method

1. Preparing the model to adapt it to the Simplex method

This is the standard form of the model:

Objective function: max Z=c1·x1 + c2·x2 + ... + cn·xn

Subject to:

a11·x1 + a12·x2 + ... + a1n·xn = b1


a21·x1 + a22·x2 + ... + a2n·xn = b2
...
am1·x1 + am2·x2 + ... + amn·xn = bm
x1,..., xn ≥ 0
Simplex method

Solve using the Simplex method the following problem:

Maximize Z = f(x,y) = 3x + 2y
subject to: 2x + y ≤ 18
2x + 3y ≤ 42
3x + y ≤ 24
x≥0,y≥0

1. Make a change of variables and normalize the sign of the independent terms.
A change is made to the variable naming, establishing the following correspondences:
x becomes X1
y becomes X2
2. Normalize restrictions.
The inequalities become equations by adding slack, surplus and artificial variables as the
following table:

Inequality type Variable that appears


≥ - surplus + artificial
= + artificial
≤ + slack

In this case, a slack variable (X3, X4 and X5) is introduced in each of the restrictions of ≤
type, to convert them into equalities, resulting the system of linear equations:
2·X1 + X2 + X3 = 18 X3,X4,X5 - Basic variables
2·X1 + 3·X2 + X4 = 42 X1,X2 - Non-basic variables
3·X1 + X2 + X5 = 24 if X1=X2=0 then X3=18, X4=42, X5=24, Z=0.

3. Match the objective function to zero.


Z - 3·X1 - 2·X2 - 0·X3 - 0·X4 - 0·X5 = 0

4. Write the initial tableau of Simplex method.

Tableau I . 1st iteration


3 2 0 0 0
Base Cb P0 P1 P2 P3 P4 P5
P3 0 18 2 1 1 0 0
P4 0 42 2 3 0 1 0
P5 0 24 3 1 0 0 1
Z max 0 -3 -2 0 0 0
The initial tableau of Simplex method consists of all the coefficients of the decision
variables of the original problem and the slack, surplus and artificial variables added in
second step (in columns, with P0 as the constant term and Pi as the coefficients of the rest
of Xi variables), and constraints (in rows). The Cb column contains the coefficients of the
variables that are in the base.

The first row consists of the objective function coefficients, while the last row contains the
objective function value and reduced costs Zj - Cj.

The last row is calculated as follows: Zj = Σ(Cbi·Pj) for i = 1..m, where if j = 0, P0 = bi and
C0 = 0, else Pj = aij. Although this is the first tableau of the Simplex method and all Cb are
null, so the calculation can simplified, and by this time Zj = -Cj.
5. Stopping condition.

If the objective is to maximize, when in the last row (indicator row) there is no negative
value between discounted costs (P1 columns below) the stop condition is reached.
In that case, the algorithm reaches the end as there is no improvement possibility.
The Z value (P0 column) is the optimal solution of the problem.

Another possible scenario is all values are negative or zero in the input variable column of
the base. This indicates that the problem is not limited and the solution will always be
improved.
Otherwise, the following steps are executed iteratively.
6. Choice of the input and output base variables.

First, input base variable is determined. For this, column whose value in Z row is the lesser
of all the negatives is chosen. In this example it would be the variable X1 (P1) with -3 as
coefficient.
If there are two or more equal coefficients satisfying the above condition (case of tie), then
choice the basic variable.
The column of the input base variable is called pivot column (in green color).

Once obtained the input base variable, the output base variable is determined. The decision
is based on a simple calculation: divide each independent term (P0 column) between the
corresponding value in the pivot column, if both values are strictly positive (greater than
zero). The row whose result is minimum score is chosen.

If there is any value less than or equal to zero, this quotient will not be performed. If all
values of the pivot column satisfy this condition, the stop condition will be reached and the
problem has an unbounded solution.

In this example: 18/2 [=9] , 42/2 [=21] and 24/3 [=8]


The term of the pivot column which led to the lesser positive quotient in the previous
division indicates the row of the slack variable leaving the base. In this example, it is X5 (P5),
with 3 as coefficient. This row is called pivot row (in green).
If two or more quotients meet the choosing condition (case of tie), other than that basic
variable is chosen (wherever possible).
The intersection of pivot column and pivot row marks the pivot value, in this example, 3.

7. Update tableau.

The new coefficients of the tableau are calculated as follows:


In the pivot row each new value is calculated as: New value = Previous value / Pivot

In the other rows each new value is calculated as: New value = Previous value - (Previous
value in pivot column * New value in pivot row)

So the pivot is normalized (its value becomes 1), while the other values of the pivot column
are canceled (analogous to the Gauss-Jordan method).
Tableau II . 2nd iteration
3 2 0 0 0
Base Cb P0 P1 P2 P3 P4 P5
P3 0 2 0 1/3 1 0 -2/3
P4 0 26 0 7/3 0 1 -2/3
P1 3 8 1 1/3 0 0 1/3
Z max 24 0 -1 0 0 1

8. When checking the stop condition is observed which is not fulfilled since there is one
negative value in the last row, -1. So, continue iteration steps 6 and 7 again.
6.1. The input base variable is X2 (P2), since it is the variable that corresponds to the
column where the coefficient is -1.
6.2. To calculate the output base variable, the constant terms P0 column) are divided by
the terms of the new pivot column: 2 / 1/3 [=6] , 26 / 7/3 [=78/7] and 8 / 1/3 [=24]. As the
lesser positive quotient is 6, the output base variable is X3 (P3).

6.3. The new pivot is 1/3.


7. Updating the values of tableau again is obtained:

Tableau III . 3rd iteration


3 2 0 0 0
Base Cb P0 P1 P2 P3 P4 P5
P2 2 6 0 1 3 0 -2
P4 0 12 0 0 -7 1 4
P1 3 6 1 0 -1 0 1
Z max 30 0 0 3 0 -1

9.Checking again the stop condition reveals that the pivot row has one negative value, -1. It
means that optimal solution is not reached yet and we must continue iterating (steps 6 and 7):

6.1. The input base variable is X5 (P5), since it is the variable that corresponds to the column
where the coefficient is -1.
6.2. To calculate the output base variable, the constant terms (P0) are divided by the terms of
the new pivot column: 6/(-2) [=-3] , 12/4 [=3] , and 6/1 [=6]. In this iteration, the output base
variable is X4 (P4).
6.3. The new pivot is 4.
7. Updating the values of tableau again is obtained:

Tableau IV . 4th iteration


3 2 0 0 0
Base Cb P0 P1 P2 P3 P4 P5
P2 2 12 0 1 -1/2 1/2 0
P5 0 3 0 0 -7/4 1/4 1
P1 3 3 1 0 3/4 -1/4 0
Z max 33 0 0 5/4 1/4 0

End of algorithm. It is noted that in the last row, all the coefficients are positive, so the stop
condition is fulfilled.
The optimal solution is given by the value of Z in the constant terms column (P0 column), in
the example: 33. In the same column, the point where it reaches is shown, watching the
corresponding rows of input decision variables: X1 = 3 and X2 = 12.

You might also like