📄 yalmip.m
字号:
function varargout = yalmip(varargin)
%YALMIP Returns various information about YALMIP
%
% YALMIP can be used to check version numbers and
% find the SDPVAR and SET objects available in workspace
%
% EXAMPLES
% [V,D] = YALMIP('version') % Returns version and release date
% YALMIP('nvars') % Returns total number of declared variables
% YALMIP('info') % Display basic info.
% YALMIP('solver','tag') % Sets the solver 'solvertag' (see sdpsettings) as default solver
%
%
% If you want infoprmation on how to use YALMIP, you are advised to check out
% http://control.ee.ethz.ch/~joloef/wiki/pmwiki.php
%
% See also YALMIPTEST, YALMIPDEMO
% Author Johan L鰂berg
% $Id: yalmip.m,v 1.101 2008/04/14 12:23:06 joloef Exp $
persistent prefered_solver internal_sdpvarstate internal_setstate
if nargin==0
help yalmip
return
end
if isempty(internal_sdpvarstate)
internal_sdpvarstate.monomtable = spalloc(0,0,0); % Polynomial powers table
internal_sdpvarstate.hashedmonomtable = []; % Hashed polynomial powers table
internal_sdpvarstate.hash = [];
internal_sdpvarstate.boundlist = [];
internal_sdpvarstate.variabletype = spalloc(0,0,0); % Pre-calc linear/quadratic/polynomial/sigmonial
internal_sdpvarstate.intVariables = []; % ID of integer variables
internal_sdpvarstate.binVariables = []; % ID of binary variables
internal_sdpvarstate.uncVariables = []; % ID of uncertain variables (not used)
internal_sdpvarstate.parVariables = []; % ID of parametric variables (not used)
internal_sdpvarstate.extVariables = []; % ID of extended variables (for max,min,norm,sin, etc)
internal_sdpvarstate.logicVariables = []; % ID of extended logic variables (for or, nnz, alldifferent etc)
internal_sdpvarstate.complexpair = [];
internal_sdpvarstate.internalconstraints = [];
internal_sdpvarstate.ExtendedMap = [];
internal_sdpvarstate.sosid = 0;
internal_sdpvarstate.sos_index = [];
internal_sdpvarstate.sos_data = [];
internal_sdpvarstate.sos_ParV = [];
internal_sdpvarstate.sos_Q = [];
internal_sdpvarstate.sos_v = [];
internal_sdpvarstate.optSolution.info = 'Initialized by YALMIP';
internal_sdpvarstate.optSolution.variables = [];
internal_sdpvarstate.optSolution.optvar =[];
internal_sdpvarstate.optSolution.values =[];
internal_sdpvarstate.nonCommutingTable = [];
end
if isempty(internal_setstate)
internal_setstate.LMIid = 0;
internal_setstate.duals_index = [];
internal_setstate.duals_data = [];
internal_setstate.duals_associated_index = [];
internal_setstate.duals_associated_data = [];
end
switch varargin{1}
case 'monomtable'
varargout{1} = internal_sdpvarstate.monomtable;
if nargout == 2
varargout{2} = internal_sdpvarstate.variabletype;
elseif nargout == 4
varargout{2} = internal_sdpvarstate.variabletype;
varargout{3} = internal_sdpvarstate.hashedmonomtable;
varargout{4} = internal_sdpvarstate.hash;
end
case 'setmonomtable'
% New monom table
internal_sdpvarstate.monomtable = varargin{2};
if nargin>=4
% User has up-dated the hash tables him self.
internal_sdpvarstate.hashedmonomtable=varargin{4};
internal_sdpvarstate.hash = varargin{5};
end
if size(internal_sdpvarstate.monomtable,2)>length(internal_sdpvarstate.hash)
need_new = size(internal_sdpvarstate.monomtable,1) - length(internal_sdpvarstate.hash);
internal_sdpvarstate.hash = [internal_sdpvarstate.hash ; 3*rand_hash(size(internal_sdpvarstate.monomtable,1),need_new,1)];
end
if size(internal_sdpvarstate.monomtable,1)>size(internal_sdpvarstate.hashedmonomtable,1)
% Need to add some hash values
need_new = size(internal_sdpvarstate.monomtable,1) - size(internal_sdpvarstate.hashedmonomtable,1);
internal_sdpvarstate.hashedmonomtable = [internal_sdpvarstate.hashedmonomtable;internal_sdpvarstate.monomtable(end-need_new+1:end,:)*internal_sdpvarstate.hash];
end
if nargin >= 3
internal_sdpvarstate.variabletype = varargin{3};
if length(internal_sdpvarstate.variabletype) ~=size(internal_sdpvarstate.monomtable,1)
error('ASSERT')
end
else
internal_sdpvarstate.variabletype = zeros(size(internal_sdpvarstate.monomtable,1),1)';
nonlinear = ~(sum(internal_sdpvarstate.monomtable,2)==1 & sum(internal_sdpvarstate.monomtable~=0,2)==1);
if ~isempty(nonlinear)
%mt = internal_sdpvarstate.monomtable;
internal_sdpvarstate.variabletype(nonlinear) = 3;
quadratic = sum(internal_sdpvarstate.monomtable,2)==2;
internal_sdpvarstate.variabletype(quadratic) = 2;
bilinear = max(internal_sdpvarstate.monomtable,[],2)<=1;
internal_sdpvarstate.variabletype(bilinear & quadratic) = 1;
sigmonial = any(0>internal_sdpvarstate.monomtable,2) | any(internal_sdpvarstate.monomtable-fix(internal_sdpvarstate.monomtable),2);
internal_sdpvarstate.variabletype(sigmonial) = 4;
end
end
case 'variabletype'
varargout{1} = internal_sdpvarstate.variabletype;
case {'addextendedvariable','addEvalVariable'}
varargin{2}
disp('Obsolete use of the terms addextendedvariable and addEvalVariable');
error('Obsolete use of the terms addextendedvariable and addEvalVariable');
case {'define','definemulti'}
if strcmpi(varargin{1},'define')
multioutput = 0;
nout = [1 1];
else
multioutput = 1;
nout = varargin{end};
varargin = {varargin{1:end-1}};
end
varargin{2} = strrep(varargin{2},'sdpvar/',''); % Clean due to different behaviour of the function mfilename in ML 5,6 and 7
% Is this operator variable already defined
correct_operator = [];
if ~isempty(internal_sdpvarstate.ExtendedMap)
i = 1;
correct_operator = strcmp(varargin{2},{internal_sdpvarstate.ExtendedMap(:).fcn});
arg1 = varargin{2};
arg2 = {varargin{3:end}};
this_hash = create_trivial_hash(varargin{3});
for i = find(correct_operator)
if this_hash == internal_sdpvarstate.ExtendedMap(i).Hash
if isequal(arg2, {internal_sdpvarstate.ExtendedMap(i).arg{1:end-1}});
if length(internal_sdpvarstate.ExtendedMap(i).computes)>1
varargout{1} = recover(internal_sdpvarstate.ExtendedMap(i).computes);
else
varargout{1} = internal_sdpvarstate.ExtendedMap(i).var;
end
return
end
end
end
else
this_hash = create_trivial_hash(varargin{3});
end
switch varargin{2}
case {'max_internal'}
% MAX is a bit special since we need one
% new variable for each column...
% (can be implemented standard way, but this is better
% for performance, and since MAX is so common...
X = varargin{3:end};
[n,m] = size(X);
if min([n m]) == 1
y = sdpvar(1,1);
internal_sdpvarstate.ExtendedMap(end+1).fcn = varargin{2};
internal_sdpvarstate.ExtendedMap(end).arg = {varargin{3:end},[]};
internal_sdpvarstate.ExtendedMap(end).var = y;
internal_sdpvarstate.ExtendedMap(end).computes = getvariables(y);
internal_sdpvarstate.extVariables = [internal_sdpvarstate.extVariables getvariables(y)];
internal_sdpvarstate.ExtendedMap(end).Hash = this_hash;
else
y = sdpvar(1,m);
for i = 1:m
internal_sdpvarstate.ExtendedMap(end+1).fcn = varargin{2};
internal_sdpvarstate.ExtendedMap(end).arg = {X(:,i),[]};
internal_sdpvarstate.ExtendedMap(end).var = y(i);
internal_sdpvarstate.ExtendedMap(end).computes = getvariables(y(i));
internal_sdpvarstate.ExtendedMap(end).Hash = create_trivial_hash(X(:,i));
end
internal_sdpvarstate.extVariables = [internal_sdpvarstate.extVariables getvariables(y)];
end
case {'abs'}
% ABS is a bit special since we need one
% new variable for each element...
X = varargin{3:end};
y = sdpvar(numel(X),1);
yy = [];
if numel(X)==1
found = 0;
if ~isempty(correct_operator)
this_hash = create_trivial_hash(X);
for j = find(correct_operator)
if this_hash == internal_sdpvarstate.ExtendedMap(j).Hash
if isequal(X,internal_sdpvarstate.ExtendedMap(j).arg{1},1)
y = internal_sdpvarstate.ExtendedMap(j).var;
found = 1;
break
end
end
end
end
if ~found
internal_sdpvarstate.ExtendedMap(end+1).fcn = varargin{2};
internal_sdpvarstate.ExtendedMap(end).arg = {X,[]};
internal_sdpvarstate.ExtendedMap(end).var = y;
internal_sdpvarstate.ExtendedMap(end).computes = getvariables(y);
internal_sdpvarstate.ExtendedMap(end).Hash = create_trivial_hash(X);
yy = y;
end
else
for i = 1:numel(X)
yi = y(i);
% This is a bummer. If we scalarize the abs-operator,
% we have to search through all scalar abs-operators
% to find this single element
found = 0;
if isa(X(i),'double')
found = 1;
y(i) = X(i);
else
if ~isempty(correct_operator)
this_hash = create_trivial_hash(X(i));
for j = find(correct_operator)
if this_hash == internal_sdpvarstate.ExtendedMap(j).Hash
if isequal(X(i),internal_sdpvarstate.ExtendedMap(j).arg{1},1)
y(i) = internal_sdpvarstate.ExtendedMap(j).var;
found = 1;
break
end
end
end
end
end
if ~found
internal_sdpvarstate.ExtendedMap(end+1).fcn = varargin{2};
internal_sdpvarstate.ExtendedMap(end).arg = {X(i),[]};
internal_sdpvarstate.ExtendedMap(end).var = yi;
internal_sdpvarstate.ExtendedMap(end).computes = getvariables(yi);
internal_sdpvarstate.ExtendedMap(end).Hash = create_trivial_hash(X(i));
yy = [yy y(i)];
end
end
end
internal_sdpvarstate.extVariables = [internal_sdpvarstate.extVariables getvariables(yy)];
y = reshape(y,size(X,1),size(X,2));
otherwise
% This is the standard operators. INPUTS -> 1 scalar output
if isequal(varargin{2},'or') | isequal(varargin{2},'xor') | isequal(varargin{2},'and')
y = binvar(1,1);
else
y = sdpvar(nout(1),nout(2));
end
if ~strcmpi({'sort'},varargin{2})
% Oh fuck is this ugly. Sort assumes ordering on some
% variables, and thus assumes no z in between. This
% will be generalized when R^n -> R^m is supported for
% real
z = sdpvar(size(varargin{3},1),size(varargin{3},2),'full'); % Standard format y=f(z),z==arg
else
z = [];
end
for i = 1:nout
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -