adapting.m

来自「一个一群算法求解TSP问题的很好的粒子」· M 代码 · 共 64 行

M
64
字号
%回路长度计算
%=========================================
%第一种群计算
for i=1:ant_n_A
    dis=0;
    dis_sum=0;
    x1=0;
    x2=0;
    y1=0;
    y2=0;
    
    for j=1:(city_n-1)      %计算前段距离
        x1=pos(tobu_A(i,j),1);     %相邻两点的坐标
        y1=pos(tobu_A(i,j),2);
        x2=pos(tobu_A(i,j+1),1);
        y2=pos(tobu_A(i,j+1),2);
        dis=sqrt((x1-x2)^2+(y1-y2)^2);
        dis_sum=dis_sum+dis;    %距离累积
    end
    % 计算最后一个城市回到第一个城市的距离
    x1=pos(tobu_A(i,1),1);
    y1=pos(tobu_A(i,1),2);
    x2=pos(tobu_A(i,city_n),1);
    y2=pos(tobu_A(i,city_n),2);
    dis=sqrt((x1-x2)^2+(y1-y2)^2);
    dis_sum=dis_sum+dis;    %距离累积
    
    adapt_A(i)=dis_sum;
end

adapt_ave_A(G)=mean(adapt_A);

%============================================
%第二种群计算
for i=1:ant_n_B
    dis=0;
    dis_sum=0;
    x1=0;
    x2=0;
    y1=0;
    y2=0;
    
    for j=1:(city_n-1)      %计算前段距离
        x1=pos(tobu_B(i,j),1);     %相邻两点的坐标
        y1=pos(tobu_B(i,j),2);
        x2=pos(tobu_B(i,j+1),1);
        y2=pos(tobu_B(i,j+1),2);
        dis=sqrt((x1-x2)^2+(y1-y2)^2);
        dis_sum=dis_sum+dis;    %距离累积
    end
    % 计算最后一个城市回到第一个城市的距离
    x1=pos(tobu_B(i,1),1);
    y1=pos(tobu_B(i,1),2);
    x2=pos(tobu_B(i,city_n),1);
    y2=pos(tobu_B(i,city_n),2);
    dis=sqrt((x1-x2)^2+(y1-y2)^2);
    dis_sum=dis_sum+dis;    %距离累积
    
    adapt_B(i)=dis_sum;
end

adapt_ave_B(G)=mean(adapt_B);

⌨️ 快捷键说明

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