irenekay 2013-10-22 09:25 采纳率: 0%
浏览 1632

细菌觅食优化算法迁徙操作的代码

BFO算法在迁徙部分完成:
对每个细菌随机生成一个概率值,若该值<Ped,则该细菌消亡重新生成一个新的。
目前见到的经典BFO代码的迁徙部分都是这么写的:

    for m=1:s
        if  Ped>rand % % Generate random number
            P(1,:,1,1,1)= 50*rand(s,1)';
            P(2,:,1,1,1)= .2*rand(s,1)';
           %P(3,:,1,1,1)= .2*rand(s,1)';
        else
            P(:,m,1,1,ell+1)=P(:,m,1,Nre+1,ell); % Bacteria that are not dispersed
        end
    end
end % Go to next elimination and disperstal

实在不理解,为什么细菌消亡后产生的新值要赋值给P(1,:,1,1,1)而不是P(:,m,1,1,ell+1)?这个新值不是应该用于下一次趋化开始么?
其中,P(维度,第i个细菌,第j-1次趋化,第k次复制,第l次迁徙)

感激不尽!

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
    • ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
    • ¥15 谁有desed数据集呀
    • ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100
    • ¥15 关于#hadoop#的问题
    • ¥15 (标签-Python|关键词-socket)
    • ¥15 keil里为什么main.c定义的函数在it.c调用不了
    • ¥50 切换TabTip键盘的输入法
    • ¥15 可否在不同线程中调用封装数据库操作的类
    • ¥15 微带串馈天线阵列每个阵元宽度计算