欢迎来到天天文库
浏览记录
ID:61735200
大小:220.04 KB
页数:16页
时间:2021-03-11
《模拟退火算法解决TSP问题要点.docx》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、智能优化方法课题报告专业班级:电子信息科学与技术12-3班课题名称:模拟退火算法解决TSP问题指导教师:姚睿学生姓名:蒋文斌学号:08123453(课题设计时间:2015年3月28日——2015年4月13日)中国矿业大学计算机学院一、问题描述旅行商(TravelingmonituihuolesmanProblem,称TSP)又名郎担,是威廉·哈密爵士和英国数学家克克曼(T.P.Kirkman)于19世初提出的一个数学,也是著名的合化。是描述的:一名商人要到若干城市去推商品,已知城市个数和各城市的路程(或旅),要求找到一条从城市1出,所有城市且每个城
2、市只能一次,最后回到城市1的路,使的路程(或旅)最小。TSP提出,不少人个很。后来人才逐步意到个只是表述,易于人所理解,而其算复性却是的入模的指数函数,属于相当解的。个数学描述:假有n个城市,并分号,定一个完全无向G=(V,E),V={1,2,⋯,n},n>1。其每一(i,j)E有一非整数耗Ci,j(即上的Ci,j,i,jV)。并(1-1)边(,)在最优线路上Xij{1,0,ij其他G的一条巡回路是V中的每个点恰好一次的回路。一条巡回路的耗是条路上所有的之和。TSP就是要找出G的最小耗回路。人在考解决个,一般首先想到的最原始的一种方法就是:
3、列出每一条可供的路(即定的城市行排列合),算出每条路的里程,最后从中出一条最短的路。假在定的4个城市分A、B、C和D,各城市之的耗己知数,如1-1所示。我可以通一个合的状空来表示所有的合,如1-2所示。图1-1顶点带权图图1-2TSP问题的解空间树1.模拟退火是什么?首先,让我们看看模拟退火是如何工作的,以及为什么它是善于解决旅行商问题。模拟退火(SimulatedAnnealing,简称monituihuo)是一种通用概率算法,用来在一个大的搜寻空间内找寻命题的最优解。该算法是源于对热力学中退火过程的模拟,在某一给定初温下,通过缓慢下降温度参数,使算法能够
4、在多项式时间内给出一个近似最优解。退火与冶金学上的“退火”相似,而与冶金学的淬火有很大区别,前者是温度缓慢下降,后者是温度迅速下降。我们将热力学的理论套用到统计学上,将搜寻空间内每一点想像成空气内的分子;分子的能量,就是它本身的动能;而搜寻空间内的每一点,也像空气分子一样带有“能量”,以表示该点对命题的合适程度。算法先以搜寻空间内一个任意点作起始:每一步先选择一个“邻居”,然后再计算从现有位置到达“邻居”的概率。2.模拟退火的优点先来说下爬山算法:爬山算法是一种简单的贪心搜索算法,该算法每次从当前解的临近解空间中选择一个最优解作为当前解,直到达到一个局部最优
5、解。爬山算法实现很简单,其主要缺点是会陷入局部最优解,而不一定能搜索到全局最优解。如图1-3所示:假设C点为当前解,爬山算法搜索到A点这个局部最优解就会停止搜索,因为在A点无论向那个方向小幅度移动都不能得到更优的解。爬山法是完完全全的贪心法,每次都鼠目寸光的选择一个当前最优解,因此只能搜索到局部的最优值。图1-3爬山算法模拟退火其实也是一种贪心算法,但是它的搜索过程引入了随机因素。模拟退火算法以一定的概率来接受一个比当前解要差的解,因此有可能会跳出这个局部的最优解,达到全局的最优解。以图1-3为例,模拟退火算法在搜索到局部最优解A后,会以一定的概率接受到E的
6、移动。也许经过几次这样的不是局部最优的移动后会到达D点,于是就跳出了局部最大值A。3.模拟退火算法描述:若J(Y(i+1))>=J(Y(i))(即移动后得到更优解),则总是接受该移动。若J(Y(i+1))7、数,且dE<0。这条公式说白了就是:温度越高,出现一次能量差为dE的降温的概率就越大;温度越低,则出现降温的概率就越小。又由于dE是小于0(否就不叫退火了),因此dE/kT<0,所以P(dE)的函数取范是(0,1)。随着温度T的降低,P(dE)会逐降低。我将一次向差解的移看做一次温度跳程,我以概率P(dE)来接受的移。关于爬山算法与模退火,有一个有趣的比:爬山算法:兔子朝着比在高的地方跳去。它找到了不的最高山峰。但是座山不一定是珠穆朗峰。就是爬山算法,它不能保局部最就是全局最。模退火:兔子喝醉了。它随机地跳了很。期,它可能走向高,也可能踏入平地。但8、是,它清醒了并朝最高方向跳去。就是模退火。4.接受函
7、数,且dE<0。这条公式说白了就是:温度越高,出现一次能量差为dE的降温的概率就越大;温度越低,则出现降温的概率就越小。又由于dE是小于0(否就不叫退火了),因此dE/kT<0,所以P(dE)的函数取范是(0,1)。随着温度T的降低,P(dE)会逐降低。我将一次向差解的移看做一次温度跳程,我以概率P(dE)来接受的移。关于爬山算法与模退火,有一个有趣的比:爬山算法:兔子朝着比在高的地方跳去。它找到了不的最高山峰。但是座山不一定是珠穆朗峰。就是爬山算法,它不能保局部最就是全局最。模退火:兔子喝醉了。它随机地跳了很。期,它可能走向高,也可能踏入平地。但
8、是,它清醒了并朝最高方向跳去。就是模退火。4.接受函
此文档下载收益归作者所有