单纯形法的MATLAB实现

单纯形函数定义如下:

function [y,T]=Optimize(A,b,c)

%作者:MOK
%创作时间:2018/10/10
%A为系数矩阵
%b为常数约束矩阵
%c为目标函数系数矩阵
%y为最优函数值,T为最优化时的单纯形表
%以上条件默认优化问题是标准形式的


l=size(A,2);
r=rank(A);

Choose=nchoosek(1:l,r);
for i=size(Choose,1):-1:1
    choose=Choose(i,:);
    if (det(A(:,choose))~=0)
        B=A(:,choose);
        tem=A;
        tem(:,choose)=[];
        N=tem;
        cB=c(choose);
        tem=c;
        tem(choose)=[];
        cN=tem;
        break
     end
end

T=[(cB)*inv(B)*b,zeros(1,r),cB*(B)^(-1)*N-cN;(B^-1)*b,diag(ones(r,1)),(B^-1)*N];


flag=0;
while(any(T(1,2:end)>0))

frow=T(1,:);
[~,loc1]=max(frow);
fcolumn=T(2:end,loc1);
base=T(2:end,1);
cita=base./fcolumn;
[~,loc2]=min(cita);
loc2=loc2+1;
T(loc2,:)=T(loc2,:)/T(loc2,loc1);
%if (all(T(2:end,loc1)<=0)&&(T(1,loc1)>0))
%    flag=1;
%    break
%end

tem=T(2:end,loc1);
for i=2:(r+1)
    if i~=loc2
    T(i,:)=T(i,:)-tem(i-1)*T(loc2,:);
    end
end
T(1,:)=T(1,:)-T(1,loc1)*T(loc2,:);

check=find(T(1,2:end)>0);
check=check+1;
if (~isempty(check))
for i=1:length(check)
   if all(T(2:end,check(i))<=0)
       flag=1;
       %break
   end
end
end
if flag
    break
end
end



if flag==0
    y=T(1,1);
else
    y=-inf;
end


end

使用方法:

clear;clc
A=[1,2,-2,1,0,0;3,-1,-1,0,1,0;1,1,-1,0,0,-1];
b=[2;3;1];
c=[1,3,-2,0,0,0];
[y,T]=Optimize(A,b,c);

你可能感兴趣的:(单纯形法的MATLAB实现)