49 lines
1.8 KiB
Mathematica
49 lines
1.8 KiB
Mathematica
|
|
function varargout = log2(varargin)
|
||
|
|
%LOG2 (overloaded)
|
||
|
|
|
||
|
|
switch class(varargin{1})
|
||
|
|
|
||
|
|
case 'double' % What is the numerical value of this argument (needed for displays etc)
|
||
|
|
% SHOULD NEVER HAPPEN, THIS SHOULD BE CAUGHT BY BUILT-IN
|
||
|
|
error('Overloaded SDPVAR/NORM CALLED WITH DOUBLE. Report error')
|
||
|
|
|
||
|
|
case 'sdpvar' % Overloaded operator for SDPVAR objects.
|
||
|
|
if length(varargin{1}) == 1
|
||
|
|
varargout{1} = yalmip('addEvalVariable',mfilename,varargin{1});
|
||
|
|
else
|
||
|
|
y = [];
|
||
|
|
for i = 1:length(varargin{1})
|
||
|
|
y = [y;yalmip('addEvalVariable',mfilename,extsubsref(varargin{1},i))];
|
||
|
|
end
|
||
|
|
varargout{1} = y;
|
||
|
|
end
|
||
|
|
|
||
|
|
case 'char' % YALMIP sends 'model' when it wants the epigraph or hypograph
|
||
|
|
switch varargin{1}
|
||
|
|
case 'graph'
|
||
|
|
t = varargin{2};
|
||
|
|
X = varargin{3};
|
||
|
|
|
||
|
|
% This is different from so called extended operators
|
||
|
|
% Just do it!
|
||
|
|
F = SetupEvaluationVariable(varargin{:});
|
||
|
|
|
||
|
|
% Now add your own code, such as domain constraints
|
||
|
|
F = F + (X >= 0);
|
||
|
|
|
||
|
|
% Let YALMIP know about convexity etc
|
||
|
|
varargout{1} = F;
|
||
|
|
varargout{2} = struct('convexity','concave','monotonicity','increasing','definiteness','none');
|
||
|
|
varargout{3} = X;
|
||
|
|
|
||
|
|
case 'milp'
|
||
|
|
varargout{1} = [];
|
||
|
|
varargout{2} = [];
|
||
|
|
varargout{3} = [];
|
||
|
|
otherwise
|
||
|
|
error('SDPVAR/LOG called with CHAR argument?');
|
||
|
|
end
|
||
|
|
otherwise
|
||
|
|
error('SDPVAR/LOG called with CHAR argument?');
|
||
|
|
end
|