Dynamic-Calibration/utils/YALMIP-master/operators/xexpintinv.m

33 lines
816 B
Matlab
Executable File

function varargout = xexpintinv(varargin)
%XEXPINTINV EXPINT(1/Z)/Z
switch class(varargin{1})
case 'double'
z = varargin{1};
varargout{1} = (1./z).*expint(1./z);
case 'sdpvar'
varargout{1} = InstantiateElementWise(mfilename,varargin{:});
case 'char'
varargout{1} = [];
varargout{2} = createOperator;
varargout{3} = varargin{3};
otherwise
error('SDPVAR/EXPINT called with CHAR argument?');
end
function operator = createOperator
operator = struct('convexity','none','monotonicity','none','definiteness','positive','model','callback');
operator.derivative = @derivative;
operator.range = [0 1];
operator.domain = [1e-8 inf];
function d = derivative(z);
d = (-1./z.^2).*expint(1./z)+(1./z).*(-z.*exp(-1./z)).*(-1./z.^2);