⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mpt_detect_sos.m

📁 optimization toolbox
💻 M
字号:
function [SOS,variables_in_sos] = mpt_detect_sos(Matrices)

binary_var_index = Matrices.binary_var_index;
notbinary_var_index = setdiff(1:Matrices.nu,binary_var_index);

% Detect and extract pure binary equalities. These are used
% to detect SOS constraints, and for pruning
nbin = length(binary_var_index);
only_binary = ~any(Matrices.Aeq(:,notbinary_var_index),2);
Aeq_bin = Matrices.Aeq(find(only_binary),binary_var_index);
%Beq_bin = Beq(find(only_binary),binary_var_index);
beq_bin = Matrices.beq(find(only_binary),:);

% Keep the rest
Matrices.Aeq = Matrices.Aeq(find(~only_binary),:);
Matrices.Beq = Matrices.Beq(find(~only_binary),:);
Matrices.beq = Matrices.beq(find(~only_binary),:);

% Dummy pre-solve to avoid problems
if length(beq_bin)>0
    [ii,jj,kk] = unique([Aeq_bin beq_bin],'rows');
    Aeq_bin = Aeq_bin(jj,:);
    beq_bin = beq_bin(jj,:);
end

% Normalize...
neg_b = find(beq_bin < 0);
Aeq_bin(neg_b,:) = -Aeq_bin(neg_b,:);
beq_bin(neg_b,:) = -beq_bin(neg_b,:);

% Detect and extract simple binary LP constraints
only_binary_lp = find(~any([Matrices.G(:,notbinary_var_index) Matrices.E],2));
Abin = Matrices.G(only_binary_lp,binary_var_index);
bbin = Matrices.W(only_binary_lp);

% Remove pure binary constraints
Matrices.G(only_binary_lp,:) = [];
Matrices.W(only_binary_lp,:) = [];
Matrices.E(only_binary_lp,:) = [];

% % Detect groups with constraints sum(d_i) == d_j
% SOS = [];
% variables_in_sos = [];
% for i = 1:size(Aeq_bin,1)
%     if beq_bin(i) == 0
%         [ix,jx,sx] = find(Aeq_bin(i,:));
%         if all(abs(sx) == 1)
%             j = find(sx == -1);
%             if length(j) == 1 & length(jx)>2
%                 % Aha, we have sum binary(i) == binary(j)
%                 j = jx(j);
%                 jx = setdiff(jx,j);
%                 this_sos = sparse(1:length(jx),jx,1,length(jx),length(binary_var_index));
%                 this_sos(1:end,j)= 1;
%                 this_sos(end+1,1)=0;
%                 if isempty(SOS)
%                     SOS = this_sos;
%                 else
% %                    new_sos  = [];
%                     SOS = kron(ones(size(SOS,1),1),this_sos) | kron(SOS,ones(size(this_sos,1),1));
% %                     for k = 1:size(SOS,1)
% %                         for r = 1:size(this_sos,1)
% %                             new_sos = [new_sos;this_sos(r,:) | SOS(k,:)];
% %                         end
% %                     end
% %                     if ~isequal(new_sos,new_sos2)
% %                         error
% %                     end
% %                    SOS = new_sos;
%                 end
%                 variables_in_sos = [variables_in_sos jx j];
%             end
%         end
%     end
% end

% Detect groups with constraints sum(d_i) == 1
SOS = {};
variables_in_sos = [];
for i = 1:size(Aeq_bin,1)
    if beq_bin(i) == 1
        [ix,jx,sx] = find(Aeq_bin(i,:));
        if all(sx == 1)
            SOS{end+1} = jx;
            variables_in_sos = [variables_in_sos jx];
        end
    end
end

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -