【算法】模拟退火算法解决TSP问题的matlab实现

本文介绍了模拟退火算法在解决旅行商问题(TSP)中的应用,详细阐述了算法框架,包括初始温度设置、新解生成、代价函数计算和Metropolis判别等步骤,并提供了简单的Matlab程序设计思路,讨论了解的质量与参数选择的关系。
摘要由CSDN通过智能技术生成

前言

       模拟退火算法(SA)是较为常见的现代优化算法之一,常用于旅行商(TSP)问题中。数学建模里学生们常常使用该算法,甚至是为了使用这个算法而使用这个算法,让评委老师们审美疲劳。评委老师明确表明使用所谓"神算法"(神经网络,模拟退火,遗传算法等等)而过于牵强者拿不了高分(见:http://special.univs.cn/service/jianmo/sxjmyw/2018/1128/1187951_15.shtml)。希望大家不要觉得它名词高级就认为它能吸引评委眼睛,评委毕竟是教授,不可能被几个名词唬住。

       但是呢,我们是学生,不能因为它不能随便用就不学习它,而在编程的环节中,我们亦有收获,况且爱因斯坦也是从一加一开始学起的,所以模拟退火算法还是有学习的必要的。话说的有点多,下面进入主题。

 

算法框架

       模拟退火算法可以粗分为以下几个步骤:

  1,初始温度的设置、初始解的生成、设置每个温度下产生解的个数。

  2,产生新解。

  3,计算代价函数差。

  4,Metropolis判别。(别被名词吓住,形式上是很简单的一个原则)

  5,降温。

  6,判断温度是否小于一个给定量。是,则结束;否,则跳转到第2步。

       以下对每个步骤做详细的解释。

 

 初始温度的设置、初始解的生成、设置每个温度下产生解的个数:

  初始温度与降温系数、终止温度息息相关,它们仨决定了迭代的次数,具体公式为:终止温度 ≈ 初始温度*(降温系数)^迭代次数,其中1降温系数是(0,1)的一个常数 。对于小规模的问题,一般初始温度取1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值