




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、会计学1用用MATLAB实现模拟退火算法实现模拟退火算法6.1 算法基本理论6.2 算法的MATLAB实现6.3 应用实例第1页/共30页简单了解退火算法特点简单了解退火算法特点 介绍模拟退火前,先介绍爬山算法。 爬山算法是一种简单的贪心搜索算法,该算法每次从当前解的临近解空间中选择一个最优解作为当前解,直到达到一个局部最优解。第2页/共30页简单了解退火算法特点简单了解退火算法特点爬山算法 如图所示:假设C点为当前解,爬山算法搜索到A点这个局部最优解就会停止搜索,因为在A点无论向那个方向小幅度移动都不能得到更优的解。 模拟退火算法 在搜索到局部最优解A后,会以一定的概率一定的概率接受到E的移
2、动。也许经过几次这样的不是局部最优的移动后会到达D点,于是就跳出了局部最大值A。第3页/共30页 工程中许多实际优化问题的目标函数都是非凸的,存在许多局部最优解。 求解全局优化问题的方法可分为两类: 确定性方法和随机性方法。 确定性算法适用于求解具有一些特殊特征的问题,而梯度法和一般的随机搜索方法则沿着目标函数下降方向搜索,因此常常陷入局部而非全局最优解。 第4页/共30页 模拟退火算法(SA)是一种通用概率算法。用来在一个大的搜索空间内寻找问题的最优解。 1953年,Metropolis等提出了模拟退火的思想。 1983年,Kirkpatrick等将SA引入组合优化领域。 第5页/共30页
3、退火,俗称固体降温 先把固体加热至足够高温,使固体中所有粒子处于无序的状态,然后将温度缓慢下降,粒子渐渐有序,这样只要温度上升得足够高,冷却过程足够慢,则所有粒子最终会处于最低能态。第6页/共30页 算法试图随着控制参数T的降低,使目标函数值f(内能E)也逐渐降低,直至趋于全局最小值(退火中低温时的最低能量状态),算法工作过程就像固体退火过程一样。6.1 算法基本理论算法基本理论模拟退火算法的由来模拟退火退火解粒子状态最优解能量最低的状态目标函数f内能控制参数温度T第7页/共30页以概率接受新状态 第8页/共30页新状态的内能当前状态的内能温度EjEi(更差的解)时,0P10000 结束,输出
4、当前解 YNYNNYYN扰动:数随机产生01的数二变换法三变换法NY第19页/共30页 第20页/共30页 第21页/共30页while t=tf for r=1:Markov_length if (rand 0.5) %随机产生01的数,若小于,则二变换 ind1 = 0; ind2 = 0; while (ind1 = ind2) ind1 = ceil(rand.*amount); ind2 = ceil(rand.*amount); end tmp1 = sol_new(ind1); sol_new(ind1) = sol_new(ind2); sol_new(ind2) = tmp1
5、; else %否则,三变换 ind1 = 0; ind2 = 0; ind3 = 0; while (ind1 = ind2) | (ind1 = ind3) . | (ind2 = ind3) | (abs(ind1-ind2) = 1) ind1 = ceil(rand.*amount); ind2 = ceil(rand.*amount); ind3 = ceil(rand.*amount); end tmp1 = ind1;tmp2 = ind2;tmp3 = ind3; 第22页/共30页 if (ind1 ind2) & (ind2 ind3) elseif (ind1
6、ind3) & (ind3 ind2) ind2 = tmp3;ind3 = tmp2; elseif (ind2 ind1) & (ind1 ind3) ind1 = tmp2;ind2 = tmp1; elseif (ind2 ind3) & (ind3 ind1) ind1 = tmp2;ind2 = tmp3; ind3 = tmp1; elseif (ind3 ind1) & (ind1 ind2) ind1 = tmp3;ind2 = tmp1; ind3 = tmp2; elseif (ind3 ind2) & (ind2 ind1) in
7、d1 = tmp3;ind2 = tmp2; ind3 = tmp1; end % ind1 ind2 ind3 tmplist1 = sol_new(ind1+1):(ind2-1); %u、v之间的城市 sol_new(ind1+1):(ind1+ind3-ind2+1) = . sol_new(ind2):(ind3); %将v到w的城市移到u后面 sol_new(ind1+ind3-ind2+2):ind3) = . tmplist1; %u、v之间的城市移到w后面 end第23页/共30页 第24页/共30页 % 计算目标函数即内能 E_new = 0; for i = 1 : (a
8、mount-1) E_new = E_new + . dist_matrix(sol_new(i),sol_new(i+1); end %从第一个城市到最后一个城市的距离 E_new = E_new + . dist_matrix(sol_new(amount),sol_new(1);第25页/共30页 第26页/共30页if E_new E_current E_current = E_new; sol_current = sol_new; if E_new E_best % 冷却过程中最好的解保存下来 E_best = E_new; sol_best = sol_new; end else % 若新解的目标函数大于当前解的, % 则以一定的概率接受新解 if rand exp(-(E_new-E_current)./t) E_current = E_new; sol_current = sol_new; else sol_new = sol_current; end end第27页/共30页
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 酒店客户服务改进实践研究试题及答案
- 完美应对每个提升期的CAD工程师认证考试试题及答案
- 发电厂辅助蒸汽系统(热力发电厂课件)
- 深度剖析酒店经营管理师试题及答案
- 企业自动化管理培训课件
- 酒店员工招聘与培训中的能力素质模型与实施策略试题及答案
- 纺织机械操作中的常见问题试题及答案
- 纺织机械设备管理的现状与思考试题及答案
- 商务礼仪师考试的行业发展动态分析试题及答案
- 酒店市场份额确定试题及答案
- 应用生态学PPT课件
- 热塑性聚酯弹性体(TPEE)
- 毕业论文机电一体化发展历程及其面临的形势和任务
- 家具厂首件检验记录表
- 《狐假虎威》(公开课)(课堂PPT)
- 半导体分立器件制造公司绩效制度范文
- 凝汽器灌水查漏方案及措施
- 铁板神数详细取数法(共16页)
- 【那个女孩歌词陶喆】陶喆那个女孩歌词分配
- 弧焊(3)电弧焊焊条
- 简历常用icon图标Word简历模板
评论
0/150
提交评论