SimplexTwoPhase

A Dantzig's simplex algorithm to solve linear programming problems (LPP).

View the Project on GitHub guimspace/SimplexTwoPhase

Dantzig’s Simplex Algorithm

License Version

A Dantzig’s simplex algorithm to solve linear programming problems (LPP) with two-phase method to obtain an initial basic feasible solution.

Notice Use SimplexTwoPhase script for educational purposes only. The script is NOT suitable for professional application as it is not meant to be the most efficient, optimized, correct and secure implementation of the Dantzig’s simplex algorithm.

About

The code is written in MATLAB language and supports minization LPP in standard form:

Minimize   cx
subject to Ax = b
            x >= 0

where c is a cost coefficients vector, x is a vector of decision variables, b is a (RHS) vector of minimal requirements to be satisfied (demands), and elements a_ij from A are technological coefficients.

Example

A = [
    1 2 1 0;
    -1 1 0 1
];
b = [4; 1];
c = [-3 1];
[x z] = simplex_two_phase(A, b, c, false)

Result

x =
    4
    0

z =
    -12

Contribute code and ideas

Contributors sign-off that they adhere to the Developer Certificate of Origin (DCO) by adding a Signed-off-by line to commit messages.

$ git commit -s -m 'This is my commit message'

For straight forward patches and minor changes, create a pull request.

For larger changes and feature ideas, please open an issue first for a discussion before implementation.

Reference

Bazaraa, Mokhtar S., et al. Linear Programming and Network Flows, John Wiley & Sons, New Jersey, 2010.