⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 branch.asv

📁 采用分支定界算法
💻 ASV
字号:
function [jie,fval,exflag]=branch(f,a,b,aeq,beq,lb,ub,intbegan)
[m,n]=size(a);
global optjie;
global optfval;
global time;
time=time+1;
[jie,fval,exflag]=linprog(f,a,b,aeq,beq,lb,ub);
if exflag<=0   %去掉不必要的分支(无解的分支)
    return;
else
    [t0,k,z]=panduan(jie,intbegan);
    if t0==0
        jie1=jie;
        if fval<=optfval
            optfval=fval;
            optjie=round(jie);
            optjie(1:intbegan-1)=jie(1:intbegan);%disp('dsfsdfsf');
            return;
        end
    elseif fval<optfval %定界,去掉不必要的分支
        a1=a;%第一个分支
        b1=b;       
        al(m+1,:)=zeros(1,n);
        a1(m+1,k)=1;
        b1(m+1)=round(jie(k))-z;
        [jie,fval,exflag]=branch(f,a1,b1,aeq,beq,lb,ub,intbegan);
        %\\\\\\\\\\\\\\\
        a2=a;%第二个分支
        b2=b;
        a2(m+1,:)=zeros(1,n);
        a2(m+1,k)=-1;
        b2(m+1)=z-round(jie(k))-1;
        [jie,fval,exflag]=branch(f,a2,b2,aeq,beq,lb,ub,intbegan);
        return;
    end
end

⌨️ 快捷键说明

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