模拟退火,遗传算法,禁忌搜索,神经网络…

模拟退火,遗传算法,禁忌搜索,神经网络…

ID:29355709

大小:46.37 KB

页数:12页

时间:2018-12-18

模拟退火,遗传算法,禁忌搜索,神经网络…_第1页
模拟退火,遗传算法,禁忌搜索,神经网络…_第2页
模拟退火,遗传算法,禁忌搜索,神经网络…_第3页
模拟退火,遗传算法,禁忌搜索,神经网络…_第4页
模拟退火,遗传算法,禁忌搜索,神经网络…_第5页
资源描述:

《模拟退火,遗传算法,禁忌搜索,神经网络…》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、模拟退火,遗传算法,禁忌搜索,神经网络…在工程实践中,经常会接触到一些比较"新颖"的算法或理论,比如模拟退火,遗传算法,禁忌搜索,神经网络等。这些算法或理论都有一些共同的特性(比如模拟自然过程),通称为"智能算法"。它们在解决一些复杂的工程问题时大有用武之地。这些算法都有什么含义?首先给出个局部搜索,模拟退火,遗传算法,禁忌搜索的形象比喻:为了找出地球上最高的山,一群有志气的兔子们开始想办法。1.兔子朝着比现在高的地方跳去。他们找到了不远处的最高山峰。但是这座山不一定是珠穆朗玛峰。这就是局部搜索,它不能保证局部最优值就是全局最优值。2.兔子喝醉了。他随机地跳了很长时间。这期间,它可能走向高处,

2、也可能踏入平地。但是,他渐渐清醒了并朝最高方向跳去。这就是模拟退火。3.兔子们吃了失忆药片,并被发射到太空,然后随机落到了地球上的某些地方。他们不知道自己的使命是什么。但是,如果你过几年就杀死一部分海拔低的兔子,多产的兔子们自己就会找到珠穆朗玛峰。这就是遗传算法。4.兔子们知道一个兔的力量是渺小的。他们互相转告着,哪里的山已经找过,并且找过的每一座山他们都留下一只兔子做记号。他们制定了下一步去哪里寻找的策略。这就是禁忌搜索。智能优化算法的概述智能优化算法要解决的一般是最优化问题。最优化问题可以分为(1)求解一个函数中,使得函数值最小的自变量取值的函数优化问题和(2)在一个解空间里面,寻找最优解

3、,使目标函数值最小的组合优化问题。典型的组合优化问题有:旅行商问题(TravelingSalesmanProblem,TSP),加工调度问题(SchedulingProblem),0-1背包问题(KnapsackProblem),以及装箱问题(BinPackingProblem)等。优化算法有很多,经典算法包括:有线性规划,动态规划等;改进型局部搜索算法包括爬山法,最速下降法等,本文介绍的模拟退火、遗传算法以及禁忌搜索称作指导性搜索法。而神经网络,混沌搜索则属于系统动态演化方法。优化思想里面经常提到邻域函数,它的作用是指出如何由当前解得到一个(组)新解。其具体实现方式要根据具体问题分析来定。一

4、般而言,局部搜索就是基于贪婪思想利用邻域函数进行搜索,若找到一个比现有值更优的解就弃前者而取后者。但是,它一般只可以得到"局部极小解",就是说,可能这只兔子登"登泰山而小天下",但是却没有找到珠穆朗玛峰。而模拟退火,遗传算法,禁忌搜索,神经网络等从不同的角度和策略实现了改进,取得较好的"全局最小解"。模拟退火算法(SimulatedAnnealing,SA)模拟退火算法的依据是固体物质退火过程和组合优化问题之间的相似性。物质在加热的时候,粒子间的布朗运动增强,到达一定强度后,固体物质转化为液态,这个时候再进行退火,粒子热运动减弱,并逐渐趋于有序,最后达到稳定。模拟退火的解不再像局部搜索那样最后

5、的结果依赖初始点。它引入了一个接受概率p。如果新的点(设为pn)的目标函数f(pn)更好,则p=1,表示选取新点;否则,接受概率p是当前点(设为pc)的目标函数f(pc),新点的目标函数f(pn)以及另一个控制参数"温度"T的函数。也就是说,模拟退火没有像局部搜索那样每次都贪婪地寻找比现在好的点,目标函数差一点的点也有可能接受进来。随着算法的执行,系统温度T逐渐降低,最后终止于某个低温,在该温度下,系统不再接受变化。模拟退火的典型特征是除了接受目标函数的改进外,还接受一个衰减极限,当T较大时,接受较大的衰减,当T逐渐变小时,接受较小的衰减,当T为0时,就不再接受衰减。这一特征意味着模拟退火与局

6、部搜索相反,它能避开局部极小,并且还保持了局部搜索的通用性和简单性。在物理上,先加热,让分子间互相碰撞,变成无序状态,内能加大,然后降温,最后的分子次序反而会更有序,内能比没有加热前更小。就像那只兔子,它喝醉后,对比较近的山峰视而不见,迷迷糊糊地跳一大圈子,反而更有可能找到珠峰。值得注意的是,当T为0时,模拟退火就成为局部搜索的一个特例。模拟退火的伪码表达:proceduresimulatedannealingbegint:=0;initializetemperatureTselectacurrentstringvcatrandom;evaluatevc;repeatrepeatselecta

7、newstringvnintheneighborhoodofvc;(1)iff(vc)thenvc:=vn;elseifrandom[0,1]thenvc:=vn;until(termination-condition)(3)T:=g(T,t);(4)T:=t+1;until(stop-criterion)(5)end;上面的程序中,关键的是(1)新状态产生函数,(2)新状态接受函数,(3)抽样稳

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。