布谷鸟算法求解车间调度问题(书籍摘录版)

布谷鸟算法求解车间调度问题

基本原理

布谷鸟算法

理想化描述

  1. 每只布谷鸟选择一个巢并产一个卵
  2. 具有高质量的卵保留到下一代
  3. 可选择巢的数量是固定的,并且布谷鸟的卵被原巢主鸟发现的概率 p a ∈ ( 0 , 1 ) p_a\in(0,1) pa(0,1) ,此情形下,原巢主鸟可能将布谷鸟的卵扔掉或放弃巢穴。

L e ˊ v y L\acute{e}vy Leˊvy飞行

一种典型的随机游走机制,表示一类非高斯随机过程,并与 L e ˊ v y L\acute{e}vy Leˊvy稳定分布有关。
L e ˊ v y L\acute{e}vy Leˊvy是一种连续概率分布,
布谷鸟算法求解车间调度问题(书籍摘录版)_第1张图片
布谷鸟算法求解车间调度问题(书籍摘录版)_第2张图片
布谷鸟算法求解车间调度问题(书籍摘录版)_第3张图片

上述三种情况可使用基本函数表示概率密度分布函数

基本理论框架

布谷鸟算法的基本思想是巢寄生行为及鸟类的 L e ˊ v y L\acute{e}vy Leˊvy飞行。
伪代码:


begin
    目标函数 f ( x ) , x = ( x 1 , ⋅ ⋅ ⋅ , x d ) T f(x),x=(x_1,···,x_d)^T f(x),x=(x1,⋅⋅⋅xd)T
    初始化种群,产生n个巢 x i ( i , 2 , 3 , ⋅ ⋅ ⋅ , n ) x_i(i,2,3,···,n) xii23⋅⋅⋅n
    while(t小于最大迭代次数或终止条件)
      布谷鸟通过飞行产生一个新解并评价适应度 f i f_i fi
      随机选择一个巢穴 f f f
      if f i f_i fi> f j f_j fj
        用新解代替旧解
      end
      丢弃一部分劣解( p a p_a pa)并建立新解
      保留最优解
      对解进行排序并找到当前最优解
    end while
    结果显示
end
当布谷鸟 i i i产生了一个新解 x i t + 1 + α ⊕ L e ˊ v y ( λ ) x_i ^{t+1} + \alpha \oplus L\acute{e}vy(\lambda) xit+1+αLeˊvy(λ)
其中a为步长,一个随机游走是一个马尔可夫决策过程,下一个状态/位置仅由当前状态、转移概率决定。
L e ˊ v y L\acute{e}vy Leˊvy飞行产生的随机游走,其步长服从 L e ˊ v y L\acute{e}vy Leˊvy分布
L e ˊ v y ( λ ) − u = t − λ L\acute{e}vy(\lambda) - u =t^{-\lambda} Leˊvy(λ)u=tλ

改进的布谷鸟算法

教学优化算法

优点: 不需要参数,收敛速度快
缺点: 某些难以优化的问题中容易陷入局部最优

Teacher phase

  教师尝试将班级的平均水平提升到 T A T_A TA,现实操作中可实现平均成绩由 M 1 M_1 M1增加到 M 2 M_2 M2
   M j M_j Mj为平均值, T i T_i Ti为第 i i i次迭代过程中的教师。新旧平均值之间的差距计算公式:
D i f f e r e n t M e a n i = r i ( M n e w − T F M i ) DifferentMean_i = r_i(M_new - T_FM_i) DifferentMeani=ri(MnewTFMi)
  其中 r i r_i ri为0-1之间的随机数, M n e w M_new Mnew为教师水平, T F T_F TF为教学因子,决定着平均值的改变
T F = r o u n d [ 1 + r a n d ( 0 , 1 ) 2 − 1 ] T_F = round[1+rand(0,1){2-1}] TF=round[1+rand(0,1)21]
  由此可进行当前最新解的更新
X n e w , i = X o l d , i + D i f f e r e n t M e a n i X_{new,i} = X_{old,i}+DifferentMean_i Xnew,i=Xold,i+DifferentMeani

Teacher phase

学生之间相互学习增长自己的知识水平。
算法的每次迭代中, i i i次迭代两个不同的学生 X i X_i Xi X j X_j Xj,其中 i ≠ j i\not=j i=j
{ X n e w , i = X o l d , i + r i ( X i − X j ) , f ( X i ) < f ( X j ) X n e w , i = X o l d , i + r i ( X j − X i ) , f ( X j ) < f ( X i ) \left\{ \begin{matrix} X_{new,i}= X_{old,i}+r_{i}(X_i-X_j), f(X_i){Xnew,i=Xold,i+ri(XiXj),f(Xi)<f(Xj)Xnew,i=Xold,i+ri(XjXi),f(Xj)<f(Xi)
如果 X n e w X_{new} Xnew X o l d X_{old} Xold
算法步骤如下:
Step1:
Step2:
Step3:
Step4:
Step5:
Step6:

你可能感兴趣的:(车间调度,java,开发语言)