alldifferent.m

来自「matlab波形优化算法经常要用到的matlab toolbox工具箱:yalm」· M 代码 · 共 36 行

M
36
字号
function varargout=alldifferent(varargin)

switch class(varargin{1})

    case 'double'
        x = varargin{1};
        x = sort(x(:));
        varargout{1} = all(diff(x) > 0);

    case 'sdpvar'
        varargout{1} = set(yalmip('define',mfilename,varargin{:}) == 1);

    case 'char'
        x = varargin{3};
        [nx,mx] = size(x);
        x = reshape(x,nx*mx,1);

        [M,m] = derivebounds(x);

        % Add constraint |x(i)-x(j)| > 1
        pairs = nchoosek(1:nx*mx,2);
        d = binvar(length(pairs),1);
        x1 = x(pairs(:,1));
        x2 = x(pairs(:,2));

        % d(i) = 0  ==> x1>x2
        % d(i) = 1  ==> x2>x1

        F =     set(x1 - x2 > 1-(1+M(pairs(:,2))-m(pairs(:,1))).*d);
        F = F + set(x2 - x1 > 1-(1+M(pairs(:,1))-m(pairs(:,2))).*(1-d));


        varargout{1} = F;
        varargout{2} = struct('convexity','none','monotonicity','none','definiteness','none','extra','marker','model','integer');
        varargout{3} = varargin{3};
end

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?