maxcut.m

来自「半定规划」· M 代码 · 共 53 行

M
53
字号
%%*******************************************************%% maxcut: MAXCUT problem.%%%% (P)    min  Tr C*X%%        s.t.  diag(X) = e; %%                              %% C = -(diag(B*e)-B)/4. %%%% (dual problem)   max  e'*y%%                  s.t. diag(y) + S = C. %%-------------------------------------------------------%%%% [X,y,objval] = maxcut(B);%%%% B: weighted adjacency matrix of a graph.%%%% DSDP5.0%% Copyright (c) 2004 by%% S. Benson, Y. Ye%% Last modified: Jan 2004%%******************************************************* function [X,y,objval] = maxcut(B);   if ~isreal(B); error('only real B allowed'); end;     n = length(B); e = ones(n,1);    CC = -(spdiags(B*e,0,n,n)-B)/4.0;    b = e;     AC = cell(1,3);   AC{1,1}='SDP';   AC{1,2}=n;   nn=n*(n+1)/2;   AAC=sparse(nn,n);   for k = 1:n; AAC(:,k) = dsparse(k,k,1,n,n); end;    AAC=[AAC sparse(dvec(CC))];   AC{1,3}=AAC;   y0 = -1.1*abs(CC)*e;   OPTIONS=doptions;   OPTIONS.gaptol=0.0001;   OPTIONS.r0=0;   OPTIONS.print=1;   OPTIONS.rho=5;   OPTIONS.zbar=norm(B,1);   [STAT,y,Xv] = dsdp(b,AC,OPTIONS,y0);   [objval,dobj,err] = derror(STAT,y,Xv,b,AC);   X=dmat(Xv{1});return;%%=======================================================

⌨️ 快捷键说明

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