backreg.m

来自「为求解大规模TSP 问题,提出了并行人工免疫系统的塔式主从模型( Towerli」· M 代码 · 共 34 行

M
34
字号
function Var = BackReg(X,Y,alpha)
format long;
sz = size(X);
N = sz(1);
n = sz(2);

Varin = X;
VarLeft = zeros(n,1);
VarAdd = 1:n;
VarInnum = n;

for i=1:n
    [RegCoff,R,F,FX,TX]= MultiLineReg(Varin(:,1:VarInnum),Y);
    [minFX,Vindex] = min(FX);
    if minFX <= fcdf(alpha,1,N-i-n)
        if Vindex == VarAdd(1)
            VarAdd(1:VarInnum-1) = VarAdd(2:VarInnum);
            Varin(:,1:VarInnum-1) = Varin(:,2:VarInnum);
            VarInnum = VarInnum - 1;
        else
            if Vindex == VarAdd(VarInnum)
                VarInnum = VarInnum - 1;
            else
                VarAdd(Vindex:VarInnum-1) = VarAdd(Vindex:VarInnum);
                Varin(:,Vindex:VarInnum-1) = Varin(:,Vindex:VarInnum);
                VarInnum = VarInnum - 1;
            end
        end
    else
        break;
    end        
end
Var = VarAdd;
format short;

⌨️ 快捷键说明

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