-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmax_2phase_demo.m
executable file
·256 lines (229 loc) · 7.58 KB
/
max_2phase_demo.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
function [opt mat] = max_2phase_demo( A,B,C)
% for minimising the given objective function C when the constraints AX <=> B is given.
% Matix A is coefficient matrix. B is right-hand side of all the
% inequality.B should hav all +ve elements.
% C should be a row matrix haivng coeficient corresponding to all the variables
% And we assume that we are working with non-negative no.s
% the method used in this algorithm is 'BIG-M' method
[am,an] = size(A);
[bm,bn] = size(B);
[cm,cn] = size(C);
R = min(min(min(A)),min(C))*10^-5;% this value of R will be used in this algo to check the accuracy
%Bcos we are working with various precision degits at various program,
%anything lesser than R is considered as a zero.
% check for matrix A and B
if am ~= bm || bn~=1
disp('Pls check the given input.A & B matrices are inconsistent')
return
end
% check for condition objective matix C
if cm ~= 1
disp(' Pls check the objective matrix.It should be an row matrix');
return
end
%check for the given constraint and objective matrix.
if an ~= cn
disp(' Pls check the objective matrix.Matrices A & C are inconsistent ');
return
end
%check for the elements in matix B.All of them should be +ve.
e = sign(min(B));
if e == -1
disp('Pls check matrix B.All elements in it should be non -ve.')
return
end
% Checking the types of constraits and formation of SIGN(S) matrx
r = menu('Pls select one of the following' , 'All constraints have <= sign',...
'All constraints have >= sign' , 'All constraints have = sign',...
'The constrarints are in mixed from');
switch r
case 1
S = ones(am,1);
case 2
S = -ones(am,1);
case 3
S = zeros(am,1);
otherwise
disp('Pls enter the column matrix corresponding to the signs')
S = input('Enter 1 for <= sign , -1 for >= and 0 for = sign \n');
end
% Check for S matrix
if size(S) ~= [ am,1]
disp(' Pls check the sign matrix')
return
end
%forming initial tebula
X = [ ];
X(1,1) = 0;%this cell will correspod to Z
X(2:bm+1,1) = B;
j=an+1;% for inserting artificial variables R
for i = 1:am
X(i+1,2:an+1) = A(i,:);
s = S(i,1);
switch s
case 1
X(i+1,j+i) = 1;
case -1
X(i+1,j+i) = -1;
X(i+1,j+i+1)=1;
X(1,j+i+1)= -1;
j = j+1;
case 0
X(i+1,j+i)=1;
X(1,j+i)= -1;
end
X
keyboard
end
disp('The intial tebula is ready: ')
X
keyboard
% the initial tebula is formed with indication row is
% corresponding to the function min(r) = { R1 + R2 + ..}
%~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~%
%~~~~~~~~~~ PHASE - 1 ~~~~~~~~~~~~~~~~%
%For this optimisation function is min(r ) = { R1 + R2 + ..}
%i.e to minimise the sum of all the artificial variables
%Removing the inconsistency in representation.
I= find(S<=0);
J= find(X(1,:) == -1);
[ im in ] = size(I);
for k= 1:im
i = I(k,1);
j = J(1,k);
X = elimination(X,i+1,j)
keyboard
end
% the inconsistancy has been removed.
% We can proceed to get min value of 'r' using normal simplex method
[xm xn] = size(X);
[z_v z_i ] = max(X( 1,2:xn));
while z_v > R% this is the required condition for max
% finding entering vector
Min_R = X(2:xm,1)./X(2:xm,z_i+1);%finding min ratio
% but we are looking for min +ve ratio hence we have to manipulate
% Min_R
if max(Min_R) <= 0 || max(Min_R) == inf % this is check for unboundedness
sprintf('Unbounded solution')
return
end
[m_v m_i] = min_positive(Min_R);%Pls see the function min_positive
fprintf('Maximum value in indication row : %.4f \n',z_v)
fprintf('Minimum Ratio : %.2f \n Pivot Element : %.2f \n', m_v,X (m_i+1,z_i + 1))
fprintf( 'Co-ordinates : (%.0f,%.0f)\n' , m_i+1,z_i + 1)
keyboard
X = elimination(X,m_i+1,z_i+1)%Row reduce operations
[z_v z_i ] = max(X( 1,2:xn));
keyboard
end
if abs(X(1,1)) <= R
disp(' The min value of r is 0 & and hence we can proceed for Phase-2');
else
disp(' Min value of r is not 0 and hence no feasible solution');
return
end
%~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~%
%~~~~~~~~~~ PHASE - 2 ~~~~~~~~~~~~~~~~%
%For this optimisation function is the given function i.e z = CX
[ jm jn ] = size(J); %J matrix is defined above as J= find(-1 == X(1,:));
%Formation of intial tebula for phase 2
for jj = 1:jn
X(:,J(1,jj)) = [];
end
X(1,2:cn+1) = - C;%indication rowX
X
keyboard
% Initial tabula is read but we have to remove inconsistancy in
% presentation
sol = X;
%Removing the inconsistency in representation.
for k = 2:an+1
% looking for the colume which forms the rrel for matix A
t = roots( [sol(2:end,k);0] );
[ mt nt ] = size(t);
if t == zeros(mt,1)
X = elimination(X, am-mt+1+1 , k);
end
end
X
keyboard
% We can proceed with normal simplex method
[xm xn] = size(X);
[z_v z_i ] = min(X( 1,2:xn));% finding outgoing vector
while z_v < 0% this is the required condition for max
Min_R = X(2:xm,1)./X(2:xm,z_i+1)
keyboard%finding min ratio
% but we are looking for min +ve ratio hence we have to manipulate
% Min_R
if max(Min_R) <= 0 || max(Min_R) == Inf % this is check for unboundedness
sprintf('Unbounded solution')
return
end
[m_v m_i] = min_positive(Min_R);%Pls see the function min_positive
% Finding entering vector
fprintf('Minimum Ratio : %.2f \n Pivot Element : %.2f \n', m_v,X (m_i+1,z_i + 1))
fprintf( 'Co-ordinates : (%.0f,%.0f)\n' , m_i+1,z_i + 1)
keyboard
X = elimination(X,m_i+1,z_i+1)%Row reduce operations
keyboard
[z_v z_i ] = min(X( 1,2:xn));
end
%The final final tebula is ready. We have to extract solution from final
%tebula
% Obtaining the solution from Final tebula
opt = X(1,1);
sol = X;
for k = 2:an+1
% looking for the colume which forms the rrel for matix A
t = roots( [sol(:,k);0] );
[ mt nt ] = size(t);
if t == zeros(mt,1)
mat(k-1,1) = X(am-mt+1+1,1);
else
mat(k-1,1) = 0;
end
end
%This is a solution for feasibility of solution
if min(mat) < 0
disp('No feasible solution')
return
end
% If solution is feasible than the final result is displayed
disp('Co-efficient matrix correspond to optimum solution ')
mat
disp('and optimum value is')
opt
%There may be some alternate solution exiting.But so far we have not
%checked it.This is a check for alternate solution.
for i = 1:am
Ratio = A(i,:)./C;
if Ratio == Ratio(1,1)*ones(1,an);
disp('The alternate optima exist and hence its not a unique solution')
end
end
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% defining sub-fuction elimination
function Y = elimination(Y,i,j)
% Pivoting (i,j) element of matrix X and eliminating other colume
% elements to zero
[ ym yn ] = size(Y);
a = Y(i,j);
Y(i,:) = Y(i,:)/a;
for k = 1:ym
if k == i
continue
end
Y(k,:) = Y(k,:) - Y(i,:)*Y(k,j);
end
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%defining subfuction min_positive
function [ m_v m_i] = min_positive( Y)
%this function will take a column matrix and returns the samllest
%+ve element's value and its position.
ys = sort(Y);
k = 1;
while ys(k,1) <= 0
k = k + 1;
end
m_v = ys(k,1);
m_i = find(Y==m_v,1,'first');