Dynamic-Calibration/utils/YALMIP-master/extras/@ncvar/log10.m

49 lines
1.8 KiB
Matlab
Executable File

function varargout = log10(varargin)
%LOG10 (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