Skip to content

This includes a C++ implementation for the linear programming simplex method

License

Notifications You must be signed in to change notification settings

chashikajw/simplex-algorithm

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 

Repository files navigation

simplex-algorithm

This include C++ implementation for Linear programming Simplex method.

The main method is in this program itself.

Instructions for compiling=>> my IDE codeBlocks;

Run on any gcc compiler=>>

Important ***** Should be compiled in -std=c++11 or c++14 ********* (Other versions' syntax can be different)

Tutorials Point online compiler ==> http://cpp.sh/ or https://www.tutorialspoint.com/compile_cpp_online.php And then go to c++ editor, copy the code and paste it. after that click on compile button and execute it.

If you have -std=c++11 or C++14 you can run in command line; g++ -o output Simplex.cpp ./output

If you correctly compile this Output should like this: Output:

initial array(Not optimal) 2 1 1 1 0 0 1 3 2 0 1 0 2 1 2 0 0 1

final array(Optimal solution) 1 0 0.2 0.6 -0.2 0 0 1 0.6 -0.2 0.4 0 0 0 1 -1 0 1

Answers for the Constraints of variables(variables array) variable1: 48 variable2: 84 variable3: 0

maximum value: 708 How to give inputs to the program =>>>

Example: maximize --> 6x + 5y + 4z

      Subject to  2x + y + z <= 180    slack varibles  2x + y + z + s1 = 180  
		  x + 3y + 2z <= 300                   x + 3y + 2z +s2 = 300
		  2x + y + 2z <= 240                    2x + y + 2z +s3 = 240

You can make arryas like below using this:

colSizeA = 6 // input column size rowSizeA = 3 // input row size float C[N]={-6,-5,-4,0,0,0}; //Initialize the C array with the coefficients of the constraints of the objective function float B[M]={180,300,240};//Initialize the B array constants of the constraints respectively

//initialize the A array by giving all the coefficients of all the variables float A[M][N] = { { 2, 1, 1, 1, 0, 0}, { 1, 3, 2, 0, 1, 0 }, { 2, 1, 2, 0, 0, 1} };

After initializing these arrays make the Simplex class and call CalculateSimplex() method:

             Simplex simplex(vec2D,b,c);
             simplex.CalculateSimplex();

About

This includes a C++ implementation for the linear programming simplex method

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages