Dynamic-Calibration/utils/YALMIP-master/@sdpvar/tan.m

37 lines
841 B
Matlab
Executable File

function varargout = tan (varargin)
%TAN (overloaded)
switch class(varargin{1})
case 'double'
error('Overloaded SDPVAR/TAN CALLED WITH DOUBLE. Report error')
case 'sdpvar'
varargout{1} = InstantiateElementWise(mfilename,varargin{:});
case 'char'
operator = struct('convexity','none','monotonicity','none','definiteness','none','model','callback');
operator.convexhull = [];
operator.bounds = @bounds;
operator.derivative = @(x)(sec(x).^2);
varargout{1} = [];
varargout{2} = operator;
varargout{3} = varargin{3};
otherwise
error('SDPVAR/TAN called with CHAR argument?');
end
function [L,U] = bounds(xL,xU)
n1 = fix((xL+pi/2)/(pi));
n2 = fix((xU+pi/2)/(pi));
if n1==n2
L = tan(xL);
U = tan(xU);
else
L = -inf;
U = inf;
end