禁忌搜索算法教程
- 格式:pptx
- 大小:450.17 KB
- 文档页数:49
禁忌搜索算法详解转载现代优化算法之禁忌搜索算法(含题⽬)禁忌搜索算法的实现_Python禁忌搜索算法详解链接:禁忌搜索是由局部搜索算法发展⽽来,爬⼭法是从通⽤局部搜索算法改进⽽来。
在介绍禁忌搜索之前先来熟悉下爬⼭法和局部搜索算法。
局部搜索算法算法的基本思想在搜索过程中,始终选择当前点的邻居中与离⽬标最近者的⽅向搜索。
算法过程(1)随机选择⼀个初始的可能解x0 ∈D,xb=x0,P=N(xb);//D是问题的定义域, xb⽤于记录到⽬标位置的最优解,P为xb的邻域。
(2)如果不满⾜结束条件,则://结束条件为循环次数或P为空等(3)Begin;(4)选择P的⼀个⼦集P',xn为P’的最优解;//P’可根据问题特点,选择适当⼤⼩的⼦集。
可按概率选择(5)如果f(xn)<f(xb),则xb=xn,P=N(xb),转(2);//重新计算P,f(x)为指标函数(6)否则P=P-P',转(2);(7)End;(8)输出计算结果;(9)结束;爬⼭法算法的基本思想将搜索过程⽐作爬⼭过程,在没有任何有关⼭顶的其他信息的情况下,沿着⾼度增加的⽅向爬。
如果相邻状态没有⽐当前值更⾼,则算法停⽌,认为当前值即为顶峰。
算法过程(1)设置初始状态n=s0为当前状态;(2)如果当前状态已达标,算法结束,搜索成功;(3)获取当前状态n的若⼲个临近状态m,计算这些h(m), nextn=min{h(m)};(4) IF h(n) < h(nextn)THEN n:=nextn;ELSE 取当前状态为最佳状态并退出;(5) GOTO (2)步;该算法在单峰的条件下,必能达到⼭顶。
显⽽易见爬⼭法对于复杂情况的求解会遇到以下问题:(1)局部极值(2)⼭脊:造成⼀系列的局部极值(3)⾼原:平坦的局部极值区域——解决办法:继续侧向移动⽬前有些改进的爬⼭法,⽐如随机爬⼭法、⾸选爬⼭法等等不再细说。
禁忌搜索算法算法思想标记已经解得的局部最优解或求解过程,并在进⼀步的迭代中避开这些局部最优解或求解过程。